onepad: fix up a few things in the tree code.

git-svn-id: http://pcsx2.googlecode.com/svn/trunk@3167 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
arcum42 2010-06-05 09:22:26 +00:00
parent eb3ebc422a
commit fb89acafe9
1 changed files with 18 additions and 21 deletions

View File

@ -59,7 +59,7 @@ class keys_tree
GtkTreeView *view; GtkTreeView *view;
bool has_columns; bool has_columns;
void populate() void repopulate()
{ {
GtkTreeIter toplevel; GtkTreeIter toplevel;
@ -115,7 +115,7 @@ class keys_tree
gtk_tree_view_column_set_visible(col, visible); gtk_tree_view_column_set_visible(col, visible);
} }
void create_columns(GtkWidget *view) void create_columns()
{ {
if (!has_columns) if (!has_columns)
{ {
@ -133,13 +133,10 @@ class keys_tree
return GTK_WIDGET(view); return GTK_WIDGET(view);
} }
void new_tree()
{
view = GTK_TREE_VIEW(gtk_tree_view_new());
}
void init() void init()
{ {
has_columns = false;
view = GTK_TREE_VIEW(gtk_tree_view_new());
treestore = gtk_tree_store_new(NUM_COLS, treestore = gtk_tree_store_new(NUM_COLS,
G_TYPE_STRING, G_TYPE_STRING,
G_TYPE_STRING, G_TYPE_STRING,
@ -147,23 +144,22 @@ class keys_tree
G_TYPE_UINT, G_TYPE_UINT,
G_TYPE_UINT); G_TYPE_UINT);
populate();
create_columns(GTK_WIDGET(view));
model = GTK_TREE_MODEL(treestore); model = GTK_TREE_MODEL(treestore);
gtk_tree_view_set_model(view, model); gtk_tree_view_set_model(view, model);
g_object_unref(model); /* destroy model automatically with view */ g_object_unref(model); /* destroy model automatically with view */
gtk_tree_selection_set_mode(gtk_tree_view_get_selection(view), GTK_SELECTION_SINGLE);
gtk_tree_selection_set_mode(gtk_tree_view_get_selection(view), }
GTK_SELECTION_SINGLE);
void update()
{
create_columns();
repopulate();
} }
void clear_all() void clear_all()
{ {
clearPAD(); clearPAD();
init(); update();
} }
bool get_selected(int &pad, int &key) bool get_selected(int &pad, int &key)
@ -186,7 +182,7 @@ class keys_tree
if (get_selected(pad, key)) if (get_selected(pad, key))
{ {
set_key(pad, key, 0); set_key(pad, key, 0);
init(); update();
} }
} }
void modify_selected() void modify_selected()
@ -195,6 +191,7 @@ class keys_tree
if (get_selected(pad, key)) if (get_selected(pad, key))
{ {
config_key(pad,key); config_key(pad,key);
// Config key calls update.
} }
} }
}; };
@ -320,7 +317,7 @@ void config_key(int pad, int key)
} }
} }
fir->init(); fir->update();
} }
void on_conf_key(GtkButton *button, gpointer user_data) void on_conf_key(GtkButton *button, gpointer user_data)
@ -365,7 +362,7 @@ void pad_changed(GtkComboBox *box, gpointer user_data)
{ {
int temp = gtk_combo_box_get_active(box); int temp = gtk_combo_box_get_active(box);
if (temp != -1) current_pad = temp; if (temp != -1) current_pad = temp;
fir->init(); fir->update();
int options = (conf.options >> (16 * current_pad)); int options = (conf.options >> (16 * current_pad));
gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(rev_lx_check), (options & PADOPTION_REVERTLX)); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(rev_lx_check), (options & PADOPTION_REVERTLX));
@ -482,7 +479,7 @@ void DisplayDialog()
gtk_combo_box_set_active(GTK_COMBO_BOX(joy_choose_cbox), Get_Current_Joystick()); gtk_combo_box_set_active(GTK_COMBO_BOX(joy_choose_cbox), Get_Current_Joystick());
g_signal_connect(GTK_OBJECT (joy_choose_cbox), "changed", G_CALLBACK(joy_changed), NULL); g_signal_connect(GTK_OBJECT (joy_choose_cbox), "changed", G_CALLBACK(joy_changed), NULL);
fir->new_tree(); fir->init();
keys_tree_clear_btn = gtk_button_new_with_label("Clear All"); keys_tree_clear_btn = gtk_button_new_with_label("Clear All");
g_signal_connect(GTK_OBJECT (keys_tree_clear_btn), "clicked", G_CALLBACK(on_clear_clicked), NULL); g_signal_connect(GTK_OBJECT (keys_tree_clear_btn), "clicked", G_CALLBACK(on_clear_clicked), NULL);
gtk_widget_set_size_request(keys_tree_clear_btn, 64, 24); gtk_widget_set_size_request(keys_tree_clear_btn, 64, 24);
@ -604,7 +601,7 @@ void DisplayDialog()
gtk_container_add (GTK_CONTAINER (GTK_DIALOG(dialog)->vbox), main_frame); gtk_container_add (GTK_CONTAINER (GTK_DIALOG(dialog)->vbox), main_frame);
fir->init(); fir->update();
gtk_widget_show_all (dialog); gtk_widget_show_all (dialog);