gtk: added gui hotkey config dialog

This commit is contained in:
punkrockguy318 2012-08-07 00:40:52 +00:00
parent d2c378a434
commit 05d1b19f1e
3 changed files with 115 additions and 35 deletions

View File

@ -1,5 +1,6 @@
08-Aug-2012 - prg - all: updated FSF address 06-Aug-2012 - prg - gtk: added hotkey gui config
08-Aug-2012 - prg - sdl: added SDL.Input.EnableOppositeDirectional option. allows/disallows simultaneous right+left / up+down. 04-Aug-2012 - prg - all: updated FSF address
04-Aug-2012 - prg - sdl: added SDL.Input.EnableOppositeDirectional option. allows/disallows simultaneous right+left / up+down.
25-Jul-2012 - AnS - Taseditor: auto-starting Note editing when creating Marker by double-click 25-Jul-2012 - AnS - Taseditor: auto-starting Note editing when creating Marker by double-click
19-Jul-2012 - AnS - Taseditor: Lua registermanual allows changing the "Run function" button caption; Markers are always restored when deploying Bookmarks 19-Jul-2012 - AnS - Taseditor: Lua registermanual allows changing the "Run function" button caption; Markers are always restored when deploying Bookmarks
01-Jul-2012 - AnS - new hotkey "Run Manual Lua function" 01-Jul-2012 - AnS - new hotkey "Run Manual Lua function"

View File

@ -78,6 +78,33 @@ bool checkGTKVersion(int major_required, int minor_required)
} }
} }
// This function configures a single hotkey
int configHotkey(char* hotkeyString)
{
SDL_Surface *screen;
SDL_Event event;
KillVideo();
screen = SDL_SetVideoMode(420, 200, 8, 0);
//SDL_WM_SetCaption("Press a key to bind...", 0);
int newkey = 0;
while(1)
{
SDL_WaitEvent(&event);
switch (event.type)
{
case SDL_KEYDOWN:
newkey = event.key.keysym.sym;
g_config->setOption(hotkeyString, newkey);
extern FCEUGI *GameInfo;
InitVideo(GameInfo);
return 0;
}
}
return 0;
}
// This function configures a single button on a gamepad // This function configures a single button on a gamepad
int configGamepadButton(GtkButton* button, gpointer p) int configGamepadButton(GtkButton* button, gpointer p)
{ {
@ -424,47 +451,68 @@ void openNetworkConfig()
g_signal_connect(win, "response", G_CALLBACK(netResponse), NULL); g_signal_connect(win, "response", G_CALLBACK(netResponse), NULL);
} }
// handler prototype
static void tree_selection_changed_cb (GtkTreeSelection *selection, gpointer data);
void flushGtkEvents()
{
while (gtk_events_pending ())
gtk_main_iteration_do (FALSE);
return;
}
enum
{
COMMAND_COLUMN,
KEY_COLUMN,
N_COLUMNS
};
int populate_hotkey_tree_store()
{
return 0;
}
GtkWidget* HotkeyWin;
// creates and opens hotkey config window // creates and opens hotkey config window
void openHotkeyConfig() void openHotkeyConfig()
{ {
std::string prefix = "SDL.Hotkeys.";
GtkWidget* win = gtk_dialog_new_with_buttons("Hotkey Configuration", GtkWidget* win = gtk_dialog_new_with_buttons("Hotkey Configuration",
GTK_WINDOW(MainWindow), GTK_WINDOW(MainWindow),
(GtkDialogFlags)(GTK_DIALOG_DESTROY_WITH_PARENT), (GtkDialogFlags)(GTK_DIALOG_DESTROY_WITH_PARENT),
GTK_STOCK_CLOSE, GTK_STOCK_CLOSE,
GTK_RESPONSE_OK, GTK_RESPONSE_OK,
NULL); NULL);
HotkeyWin = win;
GtkWidget *tree; GtkWidget *tree;
GtkWidget *vbox; GtkWidget *vbox;
vbox = gtk_dialog_get_content_area(GTK_DIALOG(win)); vbox = gtk_dialog_get_content_area(GTK_DIALOG(win));
enum
{
COMMAND_COLUMN,
// ACTION_COLUMN,
KEY_COLUMN,
N_COLUMNS
};
GtkTreeStore* store = gtk_tree_store_new(N_COLUMNS, G_TYPE_STRING, G_TYPE_INT);
GtkTreeIter iter; // parent
GtkTreeIter iter2; // child
gtk_tree_store_append(store, &iter, NULL); // aquire iter GtkTreeStore *hotkey_store = gtk_tree_store_new(N_COLUMNS, G_TYPE_STRING, G_TYPE_INT);
std::string prefix = "SDL.Hotkeys.";
int keycode; GtkTreeIter iter; // parent
for(int i=0; i<HK_MAX; i++) GtkTreeIter iter2; // child
{
const char* optionName = (prefix + HotkeyStrings[i]).c_str(); gtk_tree_store_append(hotkey_store, &iter, NULL); // aquire iter
g_config->getOption(optionName, &keycode);
gtk_tree_store_set(store, &iter, int keycode;
COMMAND_COLUMN, optionName, for(int i=0; i<HK_MAX; i++)
// ACTION_COLUMN, "This hotkey does this.", {
KEY_COLUMN, keycode, const char* optionName = (prefix + HotkeyStrings[i]).c_str();
-1); g_config->getOption(optionName, &keycode);
gtk_tree_store_append(store, &iter, NULL); // acquire child iterator gtk_tree_store_set(hotkey_store, &iter,
} COMMAND_COLUMN, optionName,
tree = gtk_tree_view_new_with_model(GTK_TREE_MODEL(store)); KEY_COLUMN, keycode,
-1);
gtk_tree_store_append(hotkey_store, &iter, NULL); // acquire child iterator
}
tree = gtk_tree_view_new_with_model(GTK_TREE_MODEL(hotkey_store));
GtkCellRenderer *renderer; GtkCellRenderer *renderer;
GtkTreeViewColumn* column; GtkTreeViewColumn* column;
@ -472,17 +520,49 @@ void openHotkeyConfig()
renderer = gtk_cell_renderer_text_new(); renderer = gtk_cell_renderer_text_new();
column = gtk_tree_view_column_new_with_attributes("Command", renderer, "text", COMMAND_COLUMN, NULL); column = gtk_tree_view_column_new_with_attributes("Command", renderer, "text", COMMAND_COLUMN, NULL);
gtk_tree_view_append_column(GTK_TREE_VIEW(tree), column); gtk_tree_view_append_column(GTK_TREE_VIEW(tree), column);
// column = gtk_tree_view_column_new_with_attributes("Action", renderer, "text", ACTION_COLUMN, NULL);
// gtk_tree_view_append_column(GTK_TREE_VIEW(tree), column);
column = gtk_tree_view_column_new_with_attributes("Key", renderer, "text", KEY_COLUMN, NULL); column = gtk_tree_view_column_new_with_attributes("Key", renderer, "text", KEY_COLUMN, NULL);
gtk_tree_view_append_column(GTK_TREE_VIEW(tree), column); gtk_tree_view_append_column(GTK_TREE_VIEW(tree), column);
gtk_container_add(GTK_CONTAINER(win),vbox); // gtk_container_add(GTK_CONTAINER(win),vbox);
gtk_box_pack_start(GTK_BOX(vbox), tree , TRUE, TRUE, 5); gtk_box_pack_start(GTK_BOX(vbox), tree , TRUE, TRUE, 5);
gtk_widget_show_all(win); gtk_widget_show_all(win);
g_signal_connect(win, "delete-event", G_CALLBACK(closeDialog), NULL); g_signal_connect(win, "delete-event", G_CALLBACK(closeDialog), NULL);
g_signal_connect(win, "response", G_CALLBACK(closeDialog), NULL); g_signal_connect(win, "response", G_CALLBACK(closeDialog), NULL);
// prototype for selection handler callback
GtkTreeSelection *select;
select = gtk_tree_view_get_selection (GTK_TREE_VIEW (tree));
gtk_tree_selection_set_mode(select, GTK_SELECTION_SINGLE);
g_signal_connect ( G_OBJECT (select), "changed", G_CALLBACK (tree_selection_changed_cb),
NULL);
}
static void tree_selection_changed_cb (GtkTreeSelection *selection, gpointer data)
{
GtkTreeIter iter;
GtkTreeModel *model;
char* hotkey;
if (gtk_tree_selection_get_selected (selection, &model, &iter))
{
gtk_tree_model_get (model, &iter, 0, &hotkey, -1);
gtk_widget_hide(HotkeyWin);
flushGtkEvents();
configHotkey(hotkey);
g_signal_emit_by_name(HotkeyWin, "destroy-event");
openHotkeyConfig();
g_free (hotkey);
}
} }
GtkWidget* typeCombo; GtkWidget* typeCombo;
@ -2053,7 +2133,7 @@ static char* menuXml =
" </menu>" " </menu>"
" <menu action='OptionsMenuAction'>" " <menu action='OptionsMenuAction'>"
" <menuitem action='GamepadConfigAction' />" " <menuitem action='GamepadConfigAction' />"
// " <menuitem action='HotkeyConfigAction' />" " <menuitem action='HotkeyConfigAction' />"
" <menuitem action='SoundConfigAction' />" " <menuitem action='SoundConfigAction' />"
" <menuitem action='VideoConfigAction' />" " <menuitem action='VideoConfigAction' />"
" <menuitem action='PaletteConfigAction' />" " <menuitem action='PaletteConfigAction' />"
@ -2112,7 +2192,7 @@ static GtkActionEntry normal_entries[] = {
#if GTK_MAJOR_VERSION == 3 || (GTK_MAJOR_VERSION == 2 && GTK_MINOR_VERSION >= 24) #if GTK_MAJOR_VERSION == 3 || (GTK_MAJOR_VERSION == 2 && GTK_MINOR_VERSION >= 24)
{"GamepadConfigAction", "input-gaming", "_Gamepad Config", NULL, NULL, G_CALLBACK(openGamepadConfig)}, {"GamepadConfigAction", "input-gaming", "_Gamepad Config", NULL, NULL, G_CALLBACK(openGamepadConfig)},
#endif #endif
// {"HotkeyConfigAction", "input", "_Hotkey Config", NULL, NULL, G_CALLBACK(openHotkeyConfig)}, {"HotkeyConfigAction", "input", "_Hotkey Config", NULL, NULL, G_CALLBACK(openHotkeyConfig)},
{"SoundConfigAction", "audio-x-generic", "_Sound Config", NULL, NULL, G_CALLBACK(openSoundConfig)}, {"SoundConfigAction", "audio-x-generic", "_Sound Config", NULL, NULL, G_CALLBACK(openSoundConfig)},
{"VideoConfigAction", "video-display", "_Video Config", NULL, NULL, G_CALLBACK(openVideoConfig)}, {"VideoConfigAction", "video-display", "_Video Config", NULL, NULL, G_CALLBACK(openVideoConfig)},
{"PaletteConfigAction", GTK_STOCK_SELECT_COLOR, "_Palette Config", NULL, NULL, G_CALLBACK(openPaletteConfig)}, {"PaletteConfigAction", GTK_STOCK_SELECT_COLOR, "_Palette Config", NULL, NULL, G_CALLBACK(openPaletteConfig)},

View File

@ -973,7 +973,6 @@ ButtonConfigBegin ()
{ {
SDL_QuitSubSystem (SDL_INIT_VIDEO); SDL_QuitSubSystem (SDL_INIT_VIDEO);
bcpv = KillVideo (); bcpv = KillVideo ();
printf ("test");
} }
#else #else