Icons for right click entity menu

This commit is contained in:
Pan7 2017-03-17 13:47:32 +01:00
parent 491aee4b19
commit 28da96daac
2 changed files with 79 additions and 11 deletions

View file

@ -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 )

View file

@ -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 );
} }
} }
} }