--- np2/x11/gtk2/gtk_menu.c 2007/01/02 13:11:01 1.5 +++ np2/x11/gtk2/gtk_menu.c 2007/02/04 11:51:14 1.10 @@ -1,4 +1,4 @@ -/* $Id: gtk_menu.c,v 1.5 2007/01/02 13:11:01 monaka Exp $ */ +/* $Id: gtk_menu.c,v 1.10 2007/02/04 11:51:14 monaka Exp $ */ /* * Copyright (c) 2004 NONAKA Kimihiro (aw9k-nnk@asahi-net.or.jp) @@ -108,6 +108,7 @@ static GtkActionEntry menu_entries[] = { { "SASI1Menu", NULL, "SASI-_1", NULL, NULL, NULL }, { "SASI2Menu", NULL, "SASI-_2", NULL, NULL, NULL }, #endif +{ "ScrnSizeMenu", NULL, "Size", NULL, NULL, NULL }, { "SoundMenu", NULL, "_Sound", NULL, NULL, NULL }, /* MenuItem */ @@ -263,6 +264,16 @@ static GtkRadioActionEntry rotate_entrie }; static const guint n_rotate_entries = G_N_ELEMENTS(rotate_entries); +static GtkRadioActionEntry screensize_entries[] = { +{ "320x200", NULL, "320x200", NULL, NULL, 4 }, +{ "480x300", NULL, "480x300", NULL, NULL, 6 }, +{ "640x400", NULL, "640x400", NULL, NULL, 8 }, +{ "800x500", NULL, "800x500", NULL, NULL, 10 }, +{ "960x600", NULL, "960x600", NULL, NULL, 12 }, +{ "1280x800", NULL, "1280x800", NULL, NULL, 16 }, +}; +static const guint n_screensize_entries = G_N_ELEMENTS(screensize_entries); + static void cb_beepvol(gint idx); static void cb_f12key(gint idx); static void cb_framerate(gint idx); @@ -270,6 +281,7 @@ static void cb_joykey(gint idx); static void cb_memory(gint idx); static void cb_rotate(gint idx); static void cb_screenmode(gint idx); +static void cb_screensize(gint idx); static void cb_soundboard(gint idx); static const struct { @@ -284,6 +296,7 @@ static const struct { { memory_entries, G_N_ELEMENTS(memory_entries), cb_memory }, { rotate_entries, G_N_ELEMENTS(rotate_entries), cb_rotate }, { screenmode_entries, G_N_ELEMENTS(screenmode_entries), cb_screenmode }, + { screensize_entries, G_N_ELEMENTS(screensize_entries), cb_screensize }, { soundboard_entries, G_N_ELEMENTS(soundboard_entries), cb_soundboard }, }; static const guint n_radiomenu_entries = G_N_ELEMENTS(radiomenu_entries); @@ -298,7 +311,6 @@ static const gchar *ui_info = " \n" " \n" " \n" -" \n" " \n" " \n" " \n" @@ -340,11 +352,22 @@ static const gchar *ui_info = " \n" " \n" " \n" -" \n" +" \n" " \n" " \n" " \n" " \n" +#if defined(SUPPORT_SCREENSIZE) +" \n" +" \n" +" \n" +" \n" +" \n" +" \n" +" \n" +" \n" +" \n" +#endif " \n" " \n" " \n" @@ -486,6 +509,8 @@ xmenu_select_item_by_index(MENU_HDL hdl, xmenu_select_item_by_index(NULL, rotate_entries, n_rotate_entries, v); #define xmenu_select_screenmode(v) \ xmenu_select_item_by_index(NULL, screenmode_entries, n_screenmode_entries, v); +#define xmenu_select_screensize(v) \ + xmenu_select_item_by_index(NULL, screensize_entries, n_screensize_entries, v); #define xmenu_select_soundboard(v) \ xmenu_select_item_by_index(NULL, soundboard_entries, n_soundboard_entries, v); @@ -524,9 +549,13 @@ cb_bmpsave(GtkAction *action, gpointer u g_object_set(G_OBJECT(dialog), "show-hidden", TRUE, NULL); gtk_file_chooser_set_select_multiple(GTK_FILE_CHOOSER(dialog), FALSE); + if (strlen(bmpfilefolder) == 0) { + g_strlcpy(bmpfilefolder, modulefile, sizeof(bmpfilefolder)); + file_cutname(bmpfilefolder); + } utf8 = g_filename_to_utf8(bmpfilefolder, -1, NULL, NULL, NULL); if (utf8) { - gtk_file_chooser_set_current_folder(GTK_FILE_CHOOSER(dialog), utf8); + gtk_file_chooser_set_filename(GTK_FILE_CHOOSER(dialog), utf8); g_free(utf8); } @@ -996,6 +1025,10 @@ cb_newdisk(GtkAction *action, gpointer u g_object_set(G_OBJECT(dialog), "show-hidden", TRUE, NULL); gtk_file_chooser_set_select_multiple(GTK_FILE_CHOOSER(dialog), FALSE); + if (strlen(fddfolder) == 0) { + g_strlcpy(fddfolder, modulefile, sizeof(fddfolder)); + file_cutname(fddfolder); + } utf8 = g_filename_to_utf8(fddfolder, -1, NULL, NULL, NULL); if (utf8) { gtk_file_chooser_set_current_folder(GTK_FILE_CHOOSER(dialog), utf8); @@ -1036,11 +1069,8 @@ cb_newdisk(GtkAction *action, gpointer u } gtk_file_chooser_set_filter(GTK_FILE_CHOOSER(dialog), filter[0]); - if (gtk_dialog_run(GTK_DIALOG(dialog)) != GTK_RESPONSE_OK) { - gtk_widget_destroy(dialog); - install_idle_process(); - return; - } + if (gtk_dialog_run(GTK_DIALOG(dialog)) != GTK_RESPONSE_OK) + goto end; utf8 = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog)); if (utf8 == NULL) @@ -1649,6 +1679,19 @@ cb_screenmode(gint idx) } static void +cb_screensize(gint idx) +{ + guint value; + + if (idx >= 0) { + value = screensize_entries[idx].value; + } else { + value = 0; + } + scrnmng_setmultiple(value); +} + +static void cb_soundboard(gint idx) { guint value; @@ -1691,6 +1734,73 @@ cb_radio(GtkRadioAction *action, GtkRadi /* * create menubar */ +static GtkWidget *menubar; +static guint menubar_timerid; + +#define EVENT_MASK (GDK_ENTER_NOTIFY_MASK|GDK_LEAVE_NOTIFY_MASK) + +static gboolean +menubar_timeout(gpointer p) +{ + + UNUSED(p); + + if (menubar_timerid) { + g_source_remove(menubar_timerid); + menubar_timerid = 0; + } + + if (scrnmode & SCRNMODE_FULLSCREEN) { + xmenu_hide(); + } + + return TRUE; +} + +/* + - Signal: gboolean GtkWidget::enter_notify_event (GtkWidget *widget, + GdkEventCrossing *event, gpointer user_data) +*/ +static gboolean +enter_notify_evhandler(GtkWidget *w, GdkEventCrossing *ev, gpointer p) +{ + + UNUSED(w); + UNUSED(ev); + UNUSED(p); + + if (menubar_timerid) { + g_source_remove(menubar_timerid); + menubar_timerid = 0; + } + + return TRUE; +} + +/* + - Signal: gboolean GtkWidget::leave_notify_event (GtkWidget *widget, + GdkEventCrossing *event, gpointer user_data) +*/ +static gboolean +leave_notify_evhandler(GtkWidget *w, GdkEventCrossing *ev, gpointer p) +{ + + UNUSED(w); + UNUSED(ev); + UNUSED(p); + + if (menubar_timerid) { + g_source_remove(menubar_timerid); + menubar_timerid = 0; + } + + if (scrnmode & SCRNMODE_FULLSCREEN) { + menubar_timerid = g_timeout_add(1000, menubar_timeout, NULL); + } + + return TRUE; +} + static void equip_fddrive(GtkUIManager *ui_manager, guint no) { @@ -1724,7 +1834,6 @@ equip_fddrive(GtkUIManager *ui_manager, GtkWidget * create_menu(void) { - GtkWidget *menubar; GError *err = NULL; gint rv; guint i; @@ -1781,6 +1890,7 @@ create_menu(void) xmenu_select_memory(np2cfg.EXTMEM); xmenu_select_rotate(scrnmode & SCRNMODE_ROTATEMASK); xmenu_select_screenmode(scrnmode & SCRNMODE_FULLSCREEN); + xmenu_select_screensize(SCREEN_DEFMUL); xmenu_select_soundboard(np2cfg.SOUND_SW); if (np2cfg.fddequip) { @@ -1792,5 +1902,44 @@ create_menu(void) } menubar = gtk_ui_manager_get_widget(menu_hdl.ui_manager, "/MainMenu"); + + gtk_widget_add_events(menubar, EVENT_MASK); + g_signal_connect(GTK_OBJECT(menubar), "enter_notify_event", + GTK_SIGNAL_FUNC(enter_notify_evhandler), NULL); + g_signal_connect(GTK_OBJECT(menubar), "leave_notify_event", + GTK_SIGNAL_FUNC(leave_notify_evhandler), NULL); + return menubar; } + +void +xmenu_hide(void) +{ + + gtk_widget_hide(menubar); +} + +void +xmenu_show(void) +{ + + gtk_widget_show(menubar); +} + +void +xmenu_toggle_menu(void) +{ + + if (GTK_WIDGET_VISIBLE(menubar)) + xmenu_hide(); + else + xmenu_show(); +} + +void +xmenu_select_screen(UINT8 mode) +{ + + xmenu_select_rotate(mode & SCRNMODE_ROTATEMASK); + xmenu_select_screenmode(mode & SCRNMODE_FULLSCREEN); +}