mirror of
https://github.com/TTimo/GtkRadiant.git
synced 2025-01-25 02:41:22 +00:00
Icons for right click entity menu
This commit is contained in:
parent
491aee4b19
commit
28da96daac
2 changed files with 79 additions and 11 deletions
|
@ -421,8 +421,22 @@ gint HandleCommand( GtkWidget *widget, gpointer data ){
|
||||||
g_pParentWnd->OnPlugIn( id, str );
|
g_pParentWnd->OnPlugIn( id, str );
|
||||||
}
|
}
|
||||||
else if ( id >= ID_ENTITY_START && id <= ID_ENTITY_END ) {
|
else if ( id >= ID_ENTITY_START && id <= ID_ENTITY_END ) {
|
||||||
char *str;
|
const char *str;
|
||||||
gtk_label_get( GTK_LABEL( GTK_BIN( widget )->child ), &str );
|
|
||||||
|
if( GTK_IS_MENU_ITEM( widget ) ) {
|
||||||
|
GtkWidget *label = GTK_WIDGET( g_object_get_data( G_OBJECT( widget ), "classname-label" ) );
|
||||||
|
if( label )
|
||||||
|
{
|
||||||
|
str = gtk_label_get_text( GTK_LABEL( label ) );
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
str = gtk_menu_item_get_label( GTK_MENU_ITEM( widget ) );
|
||||||
|
}
|
||||||
|
} else if( GTK_IS_LABEL( widget ) ) {
|
||||||
|
str = gtk_label_get_text( GTK_LABEL( widget ) );
|
||||||
|
} else {
|
||||||
|
str = gtk_label_get_text( GTK_LABEL( gtk_bin_get_child( GTK_BIN( widget ) ) ) );
|
||||||
|
}
|
||||||
g_pParentWnd->ActiveXY()->OnEntityCreate( str );
|
g_pParentWnd->ActiveXY()->OnEntityCreate( str );
|
||||||
}
|
}
|
||||||
else{ switch ( id )
|
else{ switch ( id )
|
||||||
|
|
|
@ -1458,6 +1458,58 @@ qboolean XYWnd::DragDelta( int x, int y, vec3_t move ){
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GtkWidget * create_entity_menu_item( GtkWidget *submenu, CString strName )
|
||||||
|
{
|
||||||
|
GtkWidget *item, *box, *icon, *label;
|
||||||
|
CString filepath;
|
||||||
|
GdkPixbuf *pixbuf;
|
||||||
|
|
||||||
|
filepath = g_pGameDescription->mEnginePath;
|
||||||
|
filepath += g_pGameDescription->mBaseGame;
|
||||||
|
filepath += "/icons/entity_icons/";
|
||||||
|
filepath += strName;
|
||||||
|
filepath += ".png";
|
||||||
|
|
||||||
|
item = gtk_menu_item_new();
|
||||||
|
|
||||||
|
box = gtk_hbox_new( FALSE, 6 );
|
||||||
|
|
||||||
|
gtk_container_add( GTK_CONTAINER( item ), box );
|
||||||
|
gtk_widget_show( box );
|
||||||
|
|
||||||
|
pixbuf = gdk_pixbuf_new_from_file( filepath, NULL );
|
||||||
|
if( !pixbuf ) {
|
||||||
|
filepath = g_strGameToolsPath;
|
||||||
|
filepath += "entity_icons/";
|
||||||
|
filepath += g_pGameDescription->mBaseGame;
|
||||||
|
filepath += "/";
|
||||||
|
filepath += strName;
|
||||||
|
filepath += ".png";
|
||||||
|
pixbuf = gdk_pixbuf_new_from_file( filepath, NULL );
|
||||||
|
if( !pixbuf ) {
|
||||||
|
filepath = g_strGameToolsPath;
|
||||||
|
filepath += "entity_icons/";
|
||||||
|
filepath += strName;
|
||||||
|
filepath += ".png";
|
||||||
|
pixbuf = gdk_pixbuf_new_from_file( filepath, NULL );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if( pixbuf ) {
|
||||||
|
icon = gtk_image_new_from_pixbuf( pixbuf );
|
||||||
|
gtk_box_pack_start( GTK_BOX( box ), icon, FALSE, FALSE, 0 );
|
||||||
|
gtk_widget_show( icon );
|
||||||
|
|
||||||
|
g_object_unref( pixbuf );
|
||||||
|
}
|
||||||
|
label = gtk_label_new( strName );
|
||||||
|
gtk_box_pack_start( GTK_BOX( box ), label, TRUE, TRUE, 0 );
|
||||||
|
gtk_misc_set_alignment( GTK_MISC( label ), 0.0f, 0.5f );
|
||||||
|
gtk_widget_show( label );
|
||||||
|
|
||||||
|
g_object_set_data( G_OBJECT( item ), "classname-label", label );
|
||||||
|
|
||||||
|
return item;
|
||||||
|
}
|
||||||
void XYWnd::HandleDrop(){
|
void XYWnd::HandleDrop(){
|
||||||
if ( g_PrefsDlg.m_bRightClick == false ) {
|
if ( g_PrefsDlg.m_bRightClick == false ) {
|
||||||
return;
|
return;
|
||||||
|
@ -1527,12 +1579,14 @@ void XYWnd::HandleDrop(){
|
||||||
CString strRight = strName.Right( strName.GetLength() - n_ - 1 );
|
CString strRight = strName.Right( strName.GetLength() - n_ - 1 );
|
||||||
if ( strLeft == strActive ) { // this is a child
|
if ( strLeft == strActive ) { // this is a child
|
||||||
assert( submenu );
|
assert( submenu );
|
||||||
item = gtk_menu_item_new_with_label( strName );
|
CheckMenuSplitting( submenu );
|
||||||
|
item = create_entity_menu_item( submenu, strName );
|
||||||
|
|
||||||
g_signal_connect( G_OBJECT( item ), "activate", G_CALLBACK( HandleCommand ),
|
g_signal_connect( G_OBJECT( item ), "activate", G_CALLBACK( HandleCommand ),
|
||||||
GINT_TO_POINTER( nID++ ) );
|
GINT_TO_POINTER( nID++ ) );
|
||||||
|
|
||||||
gtk_widget_show( item );
|
gtk_widget_show( item );
|
||||||
CheckMenuSplitting( submenu );
|
gtk_menu_shell_append( GTK_MENU_SHELL( submenu ), item );
|
||||||
gtk_menu_append( GTK_MENU( submenu ), item );
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -1541,7 +1595,7 @@ void XYWnd::HandleDrop(){
|
||||||
// we use submenu_root cause we may have been cascading submenu
|
// we use submenu_root cause we may have been cascading submenu
|
||||||
item = gtk_menu_item_new_with_label( strActive );
|
item = gtk_menu_item_new_with_label( strActive );
|
||||||
gtk_widget_show( item );
|
gtk_widget_show( item );
|
||||||
gtk_menu_append( GTK_MENU( menu ), item );
|
gtk_menu_shell_append( GTK_MENU_SHELL( menu ), item );
|
||||||
gtk_menu_item_set_submenu( GTK_MENU_ITEM( item ), submenu_root );
|
gtk_menu_item_set_submenu( GTK_MENU_ITEM( item ), submenu_root );
|
||||||
g_ptrMenus.Add( submenu_root );
|
g_ptrMenus.Add( submenu_root );
|
||||||
submenu = NULL;
|
submenu = NULL;
|
||||||
|
@ -1551,11 +1605,11 @@ void XYWnd::HandleDrop(){
|
||||||
|
|
||||||
submenu = gtk_menu_new();
|
submenu = gtk_menu_new();
|
||||||
submenu_root = submenu;
|
submenu_root = submenu;
|
||||||
item = gtk_menu_item_new_with_label( strName );
|
item = create_entity_menu_item( submenu, strName );
|
||||||
g_signal_connect( G_OBJECT( item ), "activate", G_CALLBACK( HandleCommand ),
|
g_signal_connect( G_OBJECT( item ), "activate", G_CALLBACK( HandleCommand ),
|
||||||
GINT_TO_POINTER( nID++ ) );
|
GINT_TO_POINTER( nID++ ) );
|
||||||
gtk_widget_show( item );
|
gtk_widget_show( item );
|
||||||
gtk_menu_append( GTK_MENU( submenu ), item );
|
gtk_menu_shell_append( GTK_MENU_SHELL( submenu ), item );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -1565,7 +1619,7 @@ void XYWnd::HandleDrop(){
|
||||||
// we use submenu_root cause we may have been cascading submenu
|
// we use submenu_root cause we may have been cascading submenu
|
||||||
item = gtk_menu_item_new_with_label( strActive );
|
item = gtk_menu_item_new_with_label( strActive );
|
||||||
gtk_widget_show( item );
|
gtk_widget_show( item );
|
||||||
gtk_menu_append( GTK_MENU( menu ), item );
|
gtk_menu_shell_append( GTK_MENU_SHELL( menu ), item );
|
||||||
gtk_menu_item_set_submenu( GTK_MENU_ITEM( item ), submenu_root );
|
gtk_menu_item_set_submenu( GTK_MENU_ITEM( item ), submenu_root );
|
||||||
g_ptrMenus.Add( submenu_root );
|
g_ptrMenus.Add( submenu_root );
|
||||||
submenu = NULL;
|
submenu = NULL;
|
||||||
|
@ -1573,11 +1627,11 @@ void XYWnd::HandleDrop(){
|
||||||
}
|
}
|
||||||
strActive = "";
|
strActive = "";
|
||||||
|
|
||||||
item = gtk_menu_item_new_with_label( strName );
|
item = create_entity_menu_item( menu, strName );
|
||||||
g_signal_connect( G_OBJECT( item ), "activate", G_CALLBACK( HandleCommand ),
|
g_signal_connect( G_OBJECT( item ), "activate", G_CALLBACK( HandleCommand ),
|
||||||
GINT_TO_POINTER( nID++ ) );
|
GINT_TO_POINTER( nID++ ) );
|
||||||
gtk_widget_show( item );
|
gtk_widget_show( item );
|
||||||
gtk_menu_append( GTK_MENU( menu ), item );
|
gtk_menu_shell_append( GTK_MENU_SHELL( menu ), item );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue