mirror of https://github.com/PCSX2/pcsx2.git
gsdx-linux: Refresh the GUI
* Use table everywhere (better alignment) * Factorize Box/Frame creation * Factorize table insertion * Add Anisotropic Filtering support
This commit is contained in:
parent
ae70344fbc
commit
c1ddad2d25
|
@ -96,7 +96,7 @@ GtkWidget* CreateInterlaceComboBox()
|
|||
return combo_box;
|
||||
}
|
||||
|
||||
GtkWidget* CreateMsaaComboBox()
|
||||
GtkWidget* CreateFsaaComboBox()
|
||||
{
|
||||
GtkWidget *combo_box;
|
||||
combo_box = gtk_combo_box_text_new ();
|
||||
|
@ -118,11 +118,35 @@ GtkWidget* CreateFilterComboBox()
|
|||
GtkWidget *combo_box;
|
||||
combo_box = gtk_combo_box_text_new ();
|
||||
|
||||
gtk_combo_box_text_append_text(GTK_COMBO_BOX_TEXT(combo_box), "Always Off");
|
||||
gtk_combo_box_text_append_text(GTK_COMBO_BOX_TEXT(combo_box), "Always On");
|
||||
gtk_combo_box_text_append_text(GTK_COMBO_BOX_TEXT(combo_box), "Always flat");
|
||||
gtk_combo_box_text_append_text(GTK_COMBO_BOX_TEXT(combo_box), "Always bilinear");
|
||||
gtk_combo_box_text_append_text(GTK_COMBO_BOX_TEXT(combo_box), "Normal");
|
||||
|
||||
gtk_combo_box_set_active(GTK_COMBO_BOX(combo_box), theApp.GetConfig("filter", 0));
|
||||
|
||||
gtk_widget_set_tooltip_text(combo_box, "Allow to control the texture interpolation.\nAlways flat is smoother\nAlways flat is more pixelated");
|
||||
|
||||
return combo_box;
|
||||
}
|
||||
|
||||
GtkWidget* CreateAfComboBox()
|
||||
{
|
||||
GtkWidget *combo_box;
|
||||
combo_box = gtk_combo_box_text_new ();
|
||||
|
||||
gtk_combo_box_text_append_text(GTK_COMBO_BOX_TEXT(combo_box), "OFF");
|
||||
gtk_combo_box_text_append_text(GTK_COMBO_BOX_TEXT(combo_box), "2x");
|
||||
gtk_combo_box_text_append_text(GTK_COMBO_BOX_TEXT(combo_box), "4x");
|
||||
gtk_combo_box_text_append_text(GTK_COMBO_BOX_TEXT(combo_box), "8x");
|
||||
gtk_combo_box_text_append_text(GTK_COMBO_BOX_TEXT(combo_box), "16x");
|
||||
|
||||
if (theApp.GetConfig("AnisotropicFiltering", 0)) {
|
||||
int p = round(log2(theApp.GetConfig("MaxAnisotropy", 0)));
|
||||
gtk_combo_box_set_active(GTK_COMBO_BOX(combo_box), p);
|
||||
} else {
|
||||
gtk_combo_box_set_active(GTK_COMBO_BOX(combo_box), 0);
|
||||
}
|
||||
|
||||
return combo_box;
|
||||
}
|
||||
|
||||
|
@ -154,33 +178,38 @@ GtkWidget* CreateGlComboBox(const char* option)
|
|||
return combo;
|
||||
}
|
||||
|
||||
static int s_table_line = 0;
|
||||
static void InsertWidgetInTable(GtkWidget* table, GtkWidget *left, GtkWidget *right = NULL, GtkWidget *third = NULL) {
|
||||
if (!left) {
|
||||
gtk_table_attach_defaults(GTK_TABLE(table), right, 1, 2, s_table_line, s_table_line+1);
|
||||
} else if (!right) {
|
||||
gtk_table_attach_defaults(GTK_TABLE(table), left, 0, 1, s_table_line, s_table_line+1);
|
||||
} else if (right == left) {
|
||||
gtk_table_attach_defaults(GTK_TABLE(table), left, 0, 2, s_table_line, s_table_line+1);
|
||||
} else {
|
||||
gtk_table_attach_defaults(GTK_TABLE(table), left, 0, 1, s_table_line, s_table_line+1);
|
||||
gtk_table_attach_defaults(GTK_TABLE(table), right, 1, 2, s_table_line, s_table_line+1);
|
||||
}
|
||||
if (third) {
|
||||
gtk_table_attach_defaults(GTK_TABLE(table), third, 2, 3, s_table_line, s_table_line+1);
|
||||
}
|
||||
s_table_line++;
|
||||
}
|
||||
|
||||
GtkWidget* CreateTableInBox(GtkWidget* parent_box, const char* frame_title, int row, int col) {
|
||||
GtkWidget* table = gtk_table_new(row, col, false);
|
||||
GtkWidget* container = (frame_title) ? gtk_frame_new (frame_title) : gtk_vbox_new(false, 5);
|
||||
gtk_container_add(GTK_CONTAINER(container), table);
|
||||
gtk_container_add(GTK_CONTAINER(parent_box), container);
|
||||
|
||||
return table;
|
||||
}
|
||||
|
||||
bool RunLinuxDialog()
|
||||
{
|
||||
GtkWidget *dialog;
|
||||
GtkWidget *main_box, *central_box, *advance_box, *res_box, *hw_box, *sw_box, *shader_box;
|
||||
GtkWidget *native_box, *fsaa_box, *resxy_box, *renderer_box, *interlace_box, *threads_box, *filter_box;
|
||||
GtkWidget *hw_table, *shader_table, *res_frame, *hw_frame, *sw_frame, *shader_frame;
|
||||
GtkWidget *interlace_combo_box, *threads_spin;
|
||||
GtkWidget *interlace_label, *threads_label, *native_label, *fsaa_label, *rexy_label, *render_label, *filter_label;
|
||||
|
||||
GtkWidget *fsaa_combo_box, *render_combo_box, *filter_combo_box;
|
||||
GtkWidget *shader, *shader_conf, *shader_label, *shader_conf_label;
|
||||
GtkWidget *shadeboost_check, *paltex_check, *fba_check, *aa_check, *native_res_check, *fxaa_check, *shaderfx_check, *spin_thread_check;
|
||||
GtkWidget *sb_contrast, *sb_brightness, *sb_saturation;
|
||||
GtkWidget *resx_spin, *resy_spin;
|
||||
|
||||
GtkWidget *hack_table, *hack_skipdraw_label, *hack_box, *hack_frame;
|
||||
GtkWidget *hack_alpha_check, *hack_date_check, *hack_offset_check, *hack_skipdraw_spin, *hack_sprite_check, * hack_wild_check, *hack_enble_check, *hack_logz_check, *align_sprite_check, *stretch_hack_check;
|
||||
GtkWidget *hack_tco_label, *hack_tco_entry;
|
||||
GtkWidget *gl_box, *gl_frame, *gl_table;
|
||||
|
||||
GtkWidget *notebook, *page_label[2];
|
||||
|
||||
int return_value;
|
||||
|
||||
GdkPixbuf* logo_pixmap;
|
||||
GtkWidget *logo_image;
|
||||
|
||||
/* Create the widgets */
|
||||
dialog = gtk_dialog_new_with_buttons (
|
||||
"GSdx Config",
|
||||
|
@ -191,120 +220,95 @@ bool RunLinuxDialog()
|
|||
NULL);
|
||||
|
||||
// The main area for the whole dialog box.
|
||||
main_box = gtk_vbox_new(false, 5);
|
||||
central_box = gtk_vbox_new(false, 5);
|
||||
advance_box = gtk_vbox_new(false, 5);
|
||||
|
||||
// The Internal resolution frame and container.
|
||||
res_box = gtk_vbox_new(false, 5);
|
||||
res_frame = gtk_frame_new ("OpenGL Internal Resolution (can cause glitches)");
|
||||
gtk_container_add(GTK_CONTAINER(res_frame), res_box);
|
||||
|
||||
// The extra shader setting frame/container/table
|
||||
shader_box = gtk_vbox_new(false, 5);
|
||||
shader_frame = gtk_frame_new("Custom Shader Settings");
|
||||
gtk_container_add(GTK_CONTAINER(shader_frame), shader_box);
|
||||
shader_table = gtk_table_new(8,2, false);
|
||||
gtk_container_add(GTK_CONTAINER(shader_box), shader_table);
|
||||
|
||||
// The hardware mode frame, container, and table.
|
||||
hw_box = gtk_vbox_new(false, 5);
|
||||
hw_frame = gtk_frame_new ("Hardware Mode Settings");
|
||||
gtk_container_add(GTK_CONTAINER(hw_frame), hw_box);
|
||||
hw_table = gtk_table_new(5,2, false);
|
||||
gtk_container_add(GTK_CONTAINER(hw_box), hw_table);
|
||||
|
||||
// The software mode frame and container. (It doesn't have enough in it for a table.)
|
||||
sw_box = gtk_vbox_new(false, 5);
|
||||
sw_frame = gtk_frame_new ("Software Mode Settings");
|
||||
gtk_container_add(GTK_CONTAINER(sw_frame), sw_box);
|
||||
|
||||
// The hack frame and container.
|
||||
hack_box = gtk_hbox_new(false, 5);
|
||||
hack_frame = gtk_frame_new ("Hacks");
|
||||
gtk_container_add(GTK_CONTAINER(hack_frame), hack_box);
|
||||
hack_table = gtk_table_new(3,3, false);
|
||||
gtk_container_add(GTK_CONTAINER(hack_box), hack_table);
|
||||
GtkWidget* main_box = gtk_vbox_new(false, 5);
|
||||
GtkWidget* central_box = gtk_vbox_new(false, 5);
|
||||
GtkWidget* advance_box = gtk_vbox_new(false, 5);
|
||||
|
||||
// Grab a logo, to make things look nice.
|
||||
logo_pixmap = gdk_pixbuf_from_pixdata(&gsdx_ogl_logo, false, NULL);
|
||||
logo_image = gtk_image_new_from_pixbuf(logo_pixmap);
|
||||
GdkPixbuf* logo_pixmap = gdk_pixbuf_from_pixdata(&gsdx_ogl_logo, false, NULL);
|
||||
GtkWidget* logo_image = gtk_image_new_from_pixbuf(logo_pixmap);
|
||||
gtk_box_pack_start(GTK_BOX(main_box), logo_image, true, true, 0);
|
||||
|
||||
// Create the renderer combo box and label, and stash them in a box.
|
||||
render_label = gtk_label_new ("Renderer:");
|
||||
render_combo_box = CreateRenderComboBox();
|
||||
renderer_box = gtk_hbox_new(false, 5);
|
||||
// Use gtk_box_pack_start instead of gtk_container_add so it lines up nicely.
|
||||
gtk_box_pack_start(GTK_BOX(renderer_box), render_label, false, false, 5);
|
||||
gtk_box_pack_start(GTK_BOX(renderer_box), render_combo_box, false, false, 5);
|
||||
GtkWidget* main_table = CreateTableInBox(main_box , NULL , 2 , 2);
|
||||
|
||||
// Create the interlace combo box and label, and stash them in a box.
|
||||
interlace_label = gtk_label_new ("Interlacing (F5):");
|
||||
interlace_combo_box = CreateInterlaceComboBox();
|
||||
interlace_box = gtk_hbox_new(false, 5);
|
||||
gtk_box_pack_start(GTK_BOX(interlace_box), interlace_label, false, false, 5);
|
||||
gtk_box_pack_start(GTK_BOX(interlace_box), interlace_combo_box, false, false, 5);
|
||||
GtkWidget* res_table = CreateTableInBox(central_box , "OpenGL Internal Resolution" , 3 , 3);
|
||||
GtkWidget* shader_table = CreateTableInBox(central_box , "Custom Shader Settings" , 8 , 2);
|
||||
GtkWidget* hw_table = CreateTableInBox(central_box , "Hardware Mode Settings" , 5 , 2);
|
||||
GtkWidget* sw_table = CreateTableInBox(central_box , "Software Mode Settings" , 5 , 2);
|
||||
|
||||
// Create the filter combo box.
|
||||
filter_label = gtk_label_new ("Force Texture Filtering:");
|
||||
filter_combo_box = CreateFilterComboBox();
|
||||
filter_box = gtk_hbox_new(false, 5);
|
||||
gtk_box_pack_start(GTK_BOX(filter_box), filter_label, false, false, 5);
|
||||
gtk_box_pack_start(GTK_BOX(filter_box), filter_combo_box, false, false, 0);
|
||||
GtkWidget* hack_table = CreateTableInBox(advance_box , "Hacks" , 7 , 2);
|
||||
GtkWidget* gl_table = CreateTableInBox(advance_box , "OpenGL Very Advanced Custom Settings" , 10 , 2);
|
||||
|
||||
// Create the threading spin box and label, and stash them in a box. (Yes, we do a lot of that.)
|
||||
threads_label = gtk_label_new("Extra rendering threads:");
|
||||
threads_spin = gtk_spin_button_new_with_range(0,100,1);
|
||||
// Main
|
||||
GtkWidget* render_label = gtk_label_new ("Renderer:");
|
||||
GtkWidget* render_combo_box = CreateRenderComboBox();
|
||||
GtkWidget* interlace_label = gtk_label_new ("Interlacing (F5):");
|
||||
GtkWidget* interlace_combo_box = CreateInterlaceComboBox();
|
||||
|
||||
s_table_line = 0;
|
||||
InsertWidgetInTable(main_table, render_label, render_combo_box);
|
||||
InsertWidgetInTable(main_table, interlace_label, interlace_combo_box);
|
||||
|
||||
// HW
|
||||
GtkWidget* filter_label = gtk_label_new ("Texture Filtering:");
|
||||
GtkWidget* filter_combo_box = CreateFilterComboBox();
|
||||
|
||||
GtkWidget* af_label = gtk_label_new("Anisotropic Filtering:");
|
||||
GtkWidget* af_combo_box = CreateAfComboBox();
|
||||
|
||||
GtkWidget* paltex_check = gtk_check_button_new_with_label("Allow 8 bits textures");
|
||||
GtkWidget* fba_check = gtk_check_button_new_with_label("Alpha correction (FBA)");
|
||||
|
||||
s_table_line = 0;
|
||||
InsertWidgetInTable(hw_table, filter_label, filter_combo_box);
|
||||
InsertWidgetInTable(hw_table, af_label, af_combo_box);
|
||||
InsertWidgetInTable(hw_table, paltex_check, fba_check);
|
||||
|
||||
// SW
|
||||
GtkWidget* threads_label = gtk_label_new("Extra rendering threads:");
|
||||
GtkWidget* threads_spin = gtk_spin_button_new_with_range(0,100,1);
|
||||
gtk_spin_button_set_value(GTK_SPIN_BUTTON(threads_spin), theApp.GetConfig("extrathreads", 0));
|
||||
threads_box = gtk_hbox_new(false, 0);
|
||||
gtk_box_pack_start(GTK_BOX(threads_box), threads_label, false, false, 5);
|
||||
gtk_box_pack_start(GTK_BOX(threads_box), threads_spin, false, false, 5);
|
||||
|
||||
// A bit of funkiness for the resolution box.
|
||||
native_label = gtk_label_new("Original PS2 Resolution: ");
|
||||
native_res_check = gtk_check_button_new_with_label("Native");
|
||||
native_box = gtk_hbox_new(false, 5);
|
||||
gtk_box_pack_start(GTK_BOX(native_box), native_label, false, false, 5);
|
||||
gtk_box_pack_start(GTK_BOX(native_box), native_res_check, false, false, 5);
|
||||
GtkWidget* aa_check = gtk_check_button_new_with_label("Edge anti-aliasing (AA1)");
|
||||
GtkWidget* spin_thread_check= gtk_check_button_new_with_label("Disable thread sleeping (6+ cores CPU)");
|
||||
|
||||
fsaa_label = gtk_label_new("Or Use Scaling:");
|
||||
fsaa_combo_box = CreateMsaaComboBox();
|
||||
fsaa_box = gtk_hbox_new(false, 5);
|
||||
gtk_box_pack_start(GTK_BOX(fsaa_box), fsaa_label, false, false, 5);
|
||||
gtk_box_pack_start(GTK_BOX(fsaa_box), fsaa_combo_box, false, false, 5);
|
||||
s_table_line = 0;
|
||||
InsertWidgetInTable(sw_table , threads_label , threads_spin);
|
||||
InsertWidgetInTable(sw_table , aa_check);
|
||||
InsertWidgetInTable(sw_table , spin_thread_check , spin_thread_check);
|
||||
|
||||
rexy_label = gtk_label_new("Custom Resolution:");
|
||||
resx_spin = gtk_spin_button_new_with_range(256,8192,1);
|
||||
// Resolution
|
||||
GtkWidget* native_label = gtk_label_new("Original PS2 Resolution: ");
|
||||
GtkWidget* native_res_check = gtk_check_button_new_with_label("Native");
|
||||
|
||||
GtkWidget* fsaa_label = gtk_label_new("Or Use Scaling:");
|
||||
GtkWidget* fsaa_combo_box = CreateFsaaComboBox();
|
||||
|
||||
GtkWidget* resxy_label = gtk_label_new("Custom Resolution:");
|
||||
GtkWidget* resx_spin = gtk_spin_button_new_with_range(256,8192,1);
|
||||
GtkWidget* resy_spin = gtk_spin_button_new_with_range(256,8192,1);
|
||||
gtk_spin_button_set_value(GTK_SPIN_BUTTON(resx_spin), theApp.GetConfig("resx", 1024));
|
||||
resy_spin = gtk_spin_button_new_with_range(256,8192,1);
|
||||
gtk_spin_button_set_value(GTK_SPIN_BUTTON(resy_spin), theApp.GetConfig("resy", 1024));
|
||||
resxy_box = gtk_hbox_new(false, 5);
|
||||
gtk_box_pack_start(GTK_BOX(resxy_box), rexy_label, false, false, 5);
|
||||
gtk_box_pack_start(GTK_BOX(resxy_box), resx_spin, false, false, 5);
|
||||
gtk_box_pack_start(GTK_BOX(resxy_box), resy_spin, false, false, 5);
|
||||
|
||||
|
||||
// shader fx entry
|
||||
shader = gtk_file_chooser_button_new("Select an external shader", GTK_FILE_CHOOSER_ACTION_OPEN);
|
||||
shader_conf = gtk_file_chooser_button_new("Then select a config", GTK_FILE_CHOOSER_ACTION_OPEN);
|
||||
shader_label = gtk_label_new("External shader glsl");
|
||||
shader_conf_label = gtk_label_new("External shader conf");
|
||||
s_table_line = 0;
|
||||
InsertWidgetInTable(res_table, native_label, native_res_check);
|
||||
InsertWidgetInTable(res_table, fsaa_label, fsaa_combo_box);
|
||||
InsertWidgetInTable(res_table, resxy_label, resx_spin, resy_spin);
|
||||
|
||||
// Create our hack settings.
|
||||
hack_alpha_check = gtk_check_button_new_with_label("Alpha Hack");
|
||||
hack_date_check = gtk_check_button_new_with_label("Date Hack");
|
||||
hack_offset_check = gtk_check_button_new_with_label("Offset Hack");
|
||||
hack_skipdraw_label = gtk_label_new("Skipdraw:");
|
||||
hack_skipdraw_spin = gtk_spin_button_new_with_range(0,1000,1);
|
||||
hack_enble_check = gtk_check_button_new_with_label("Enable User Hacks");
|
||||
hack_wild_check = gtk_check_button_new_with_label("Wild arm Hack");
|
||||
hack_sprite_check = gtk_check_button_new_with_label("Sprite Hack");
|
||||
hack_tco_label = gtk_label_new("Texture Offset: 0x");
|
||||
hack_tco_entry = gtk_entry_new();
|
||||
hack_logz_check = gtk_check_button_new_with_label("Log Depth Hack");
|
||||
align_sprite_check = gtk_check_button_new_with_label("Anti vertical line hack");
|
||||
stretch_hack_check = gtk_check_button_new_with_label("Improve 2D sprite scaling accuracy");
|
||||
GtkWidget* hack_alpha_check = gtk_check_button_new_with_label("Alpha Hack");
|
||||
GtkWidget* hack_date_check = gtk_check_button_new_with_label("Date Hack");
|
||||
GtkWidget* hack_offset_check = gtk_check_button_new_with_label("Offset Hack");
|
||||
GtkWidget* hack_skipdraw_label = gtk_label_new("Skipdraw:");
|
||||
GtkWidget* hack_skipdraw_spin = gtk_spin_button_new_with_range(0,1000,1);
|
||||
GtkWidget* hack_enble_check = gtk_check_button_new_with_label("Enable User Hacks");
|
||||
GtkWidget* hack_wild_check = gtk_check_button_new_with_label("Wild arm Hack");
|
||||
GtkWidget* hack_sprite_check = gtk_check_button_new_with_label("Sprite Hack");
|
||||
GtkWidget* hack_tco_label = gtk_label_new("Texture Offset: 0x");
|
||||
GtkWidget* hack_tco_entry = gtk_entry_new();
|
||||
GtkWidget* hack_logz_check = gtk_check_button_new_with_label("Log Depth Hack");
|
||||
GtkWidget* align_sprite_check = gtk_check_button_new_with_label("Anti vertical line hack");
|
||||
GtkWidget* stretch_hack_check = gtk_check_button_new_with_label("Improve 2D sprite scaling accuracy");
|
||||
|
||||
gtk_spin_button_set_value(GTK_SPIN_BUTTON(hack_skipdraw_spin), theApp.GetConfig("UserHacks_SkipDraw", 0));
|
||||
set_hex_entry(hack_tco_entry, theApp.GetConfig("UserHacks_TCOffset", 0));
|
||||
|
@ -320,43 +324,115 @@ bool RunLinuxDialog()
|
|||
gtk_widget_set_tooltip_text(hack_sprite_check, dialog_message(IDC_SPRITEHACK));
|
||||
gtk_widget_set_tooltip_text(hack_tco_label, dialog_message(IDC_TCOFFSETX));
|
||||
gtk_widget_set_tooltip_text(hack_tco_entry, dialog_message(IDC_TCOFFSETX));
|
||||
gtk_widget_set_tooltip_text(hack_logz_check, "Use a logarithm depth instead of a linear depth");
|
||||
gtk_widget_set_tooltip_text(hack_logz_check, "Use a logarithm depth instead of a linear depth (superseeded by ARB_clip_control)");
|
||||
gtk_widget_set_tooltip_text(align_sprite_check, dialog_message(IDC_ALIGN_SPRITE));
|
||||
gtk_widget_set_tooltip_text(stretch_hack_check, dialog_message(IDC_STRETCH_SPRITE));
|
||||
|
||||
|
||||
// Tables are strange. The numbers are for their position: left, right, top, bottom.
|
||||
int l = 0;
|
||||
gtk_table_attach_defaults(GTK_TABLE(hack_table), hack_enble_check, 0, 1, l, l+1);
|
||||
l++;
|
||||
gtk_table_attach_defaults(GTK_TABLE(hack_table), hack_alpha_check, 0, 1, l, l+1);
|
||||
gtk_table_attach_defaults(GTK_TABLE(hack_table), hack_offset_check, 1, 2, l, l+1);
|
||||
l++;
|
||||
gtk_table_attach_defaults(GTK_TABLE(hack_table), hack_sprite_check, 0, 1, l, l+1);
|
||||
gtk_table_attach_defaults(GTK_TABLE(hack_table), hack_wild_check , 1, 2, l, l+1);
|
||||
l++;
|
||||
gtk_table_attach_defaults(GTK_TABLE(hack_table), hack_logz_check, 0, 1, l, l+1);
|
||||
gtk_table_attach_defaults(GTK_TABLE(hack_table), hack_date_check, 1, 2, l, l+1);
|
||||
l++;
|
||||
gtk_table_attach_defaults(GTK_TABLE(hack_table), stretch_hack_check, 0, 1, l, l+1);
|
||||
gtk_table_attach_defaults(GTK_TABLE(hack_table), align_sprite_check, 1, 2, l, l+1);
|
||||
l++;
|
||||
gtk_table_attach_defaults(GTK_TABLE(hack_table), hack_skipdraw_label, 0, 1, l, l+1);
|
||||
gtk_table_attach_defaults(GTK_TABLE(hack_table), hack_skipdraw_spin , 1, 2, l, l+1);
|
||||
l++;
|
||||
gtk_table_attach_defaults(GTK_TABLE(hack_table), hack_tco_label, 0, 1, l, l+1);
|
||||
gtk_table_attach_defaults(GTK_TABLE(hack_table), hack_tco_entry, 1, 2, l, l+1);
|
||||
s_table_line = 0;
|
||||
InsertWidgetInTable(hack_table , hack_enble_check);
|
||||
InsertWidgetInTable(hack_table , hack_alpha_check , hack_offset_check);
|
||||
InsertWidgetInTable(hack_table , hack_sprite_check , hack_wild_check);
|
||||
InsertWidgetInTable(hack_table , hack_logz_check , hack_date_check);
|
||||
InsertWidgetInTable(hack_table , stretch_hack_check , align_sprite_check);
|
||||
InsertWidgetInTable(hack_table , hack_skipdraw_label , hack_skipdraw_spin);
|
||||
InsertWidgetInTable(hack_table , hack_tco_label , hack_tco_entry);
|
||||
|
||||
// Create our checkboxes.
|
||||
shadeboost_check = gtk_check_button_new_with_label("Shade boost");
|
||||
paltex_check = gtk_check_button_new_with_label("Allow 8 bits textures");
|
||||
fba_check = gtk_check_button_new_with_label("Alpha correction (FBA)");
|
||||
aa_check = gtk_check_button_new_with_label("Edge anti-aliasing (AA1)");
|
||||
spin_thread_check= gtk_check_button_new_with_label("Disable thread sleeping (6+ cores CPU)");
|
||||
fxaa_check = gtk_check_button_new_with_label("Fxaa shader");
|
||||
shaderfx_check = gtk_check_button_new_with_label("External shader");
|
||||
// shader
|
||||
GtkWidget* shader = gtk_file_chooser_button_new("Select an external shader", GTK_FILE_CHOOSER_ACTION_OPEN);
|
||||
GtkWidget* shader_conf = gtk_file_chooser_button_new("Then select a config", GTK_FILE_CHOOSER_ACTION_OPEN);
|
||||
GtkWidget* shader_label = gtk_label_new("External shader glsl");
|
||||
GtkWidget* shader_conf_label = gtk_label_new("External shader conf");
|
||||
|
||||
// Set the checkboxes.
|
||||
GtkWidget* shadeboost_check = gtk_check_button_new_with_label("Shade boost");
|
||||
GtkWidget* fxaa_check = gtk_check_button_new_with_label("Fxaa shader");
|
||||
GtkWidget* shaderfx_check = gtk_check_button_new_with_label("External shader");
|
||||
|
||||
// Shadeboost scale
|
||||
#if GTK_MAJOR_VERSION < 3
|
||||
GtkWidget* sb_brightness = gtk_hscale_new_with_range(0, 200, 10);
|
||||
#else
|
||||
GtkWidget* sb_brightness = gtk_scale_new_with_range(GTK_ORIENTATION_HORIZONTAL, 0, 200, 10);
|
||||
#endif
|
||||
GtkWidget* sb_brightness_label = gtk_label_new("Shade Boost Brightness");
|
||||
gtk_scale_set_value_pos(GTK_SCALE(sb_brightness), GTK_POS_RIGHT);
|
||||
gtk_range_set_value(GTK_RANGE(sb_brightness), theApp.GetConfig("ShadeBoost_Brightness", 50));
|
||||
|
||||
#if GTK_MAJOR_VERSION < 3
|
||||
GtkWidget* sb_contrast = gtk_hscale_new_with_range(0, 200, 10);
|
||||
#else
|
||||
GtkWidget* sb_contrast = gtk_scale_new_with_range(GTK_ORIENTATION_HORIZONTAL, 0, 200, 10);
|
||||
#endif
|
||||
GtkWidget* sb_contrast_label = gtk_label_new("Shade Boost Contrast");
|
||||
gtk_scale_set_value_pos(GTK_SCALE(sb_contrast), GTK_POS_RIGHT);
|
||||
gtk_range_set_value(GTK_RANGE(sb_contrast), theApp.GetConfig("ShadeBoost_Contrast", 50));
|
||||
|
||||
#if GTK_MAJOR_VERSION < 3
|
||||
GtkWidget* sb_saturation = gtk_hscale_new_with_range(0, 200, 10);
|
||||
#else
|
||||
GtkWidget* sb_saturation = gtk_scale_new_with_range(GTK_ORIENTATION_HORIZONTAL, 0, 200, 10);
|
||||
#endif
|
||||
GtkWidget* sb_saturation_label = gtk_label_new("Shade Boost Saturation");
|
||||
gtk_scale_set_value_pos(GTK_SCALE(sb_saturation), GTK_POS_RIGHT);
|
||||
gtk_range_set_value(GTK_RANGE(sb_saturation), theApp.GetConfig("ShadeBoost_Saturation", 50));
|
||||
|
||||
// external shader entry
|
||||
gtk_file_chooser_set_filename(GTK_FILE_CHOOSER(shader), theApp.GetConfig("shaderfx_glsl", "dummy.glsl").c_str());
|
||||
gtk_file_chooser_set_filename(GTK_FILE_CHOOSER(shader_conf), theApp.GetConfig("shaderfx_conf", "dummy.ini").c_str());
|
||||
|
||||
s_table_line = 0;
|
||||
InsertWidgetInTable(shader_table , fxaa_check);
|
||||
InsertWidgetInTable(shader_table , shadeboost_check);
|
||||
InsertWidgetInTable(shader_table , sb_brightness_label , sb_brightness);
|
||||
InsertWidgetInTable(shader_table , sb_contrast_label , sb_contrast);
|
||||
InsertWidgetInTable(shader_table , sb_saturation_label , sb_saturation);
|
||||
InsertWidgetInTable(shader_table , shaderfx_check);
|
||||
InsertWidgetInTable(shader_table , shader_label , shader);
|
||||
InsertWidgetInTable(shader_table , shader_conf_label , shader_conf);
|
||||
|
||||
// The GL advance options
|
||||
GtkWidget* gl_bs_label = gtk_label_new("Buffer Storage:");
|
||||
GtkWidget* gl_bs_combo = CreateGlComboBox("override_GL_ARB_buffer_storage");
|
||||
GtkWidget* gl_bt_label = gtk_label_new("Bindless Texture:");
|
||||
GtkWidget* gl_bt_combo = CreateGlComboBox("override_GL_ARB_bindless_texture");
|
||||
GtkWidget* gl_sso_label = gtk_label_new("Separate Shader:");
|
||||
GtkWidget* gl_sso_combo = CreateGlComboBox("override_GL_ARB_separate_shader_objects");
|
||||
GtkWidget* gl_ss_label = gtk_label_new("Shader Subroutine:");
|
||||
GtkWidget* gl_ss_combo = CreateGlComboBox("override_GL_ARB_shader_subroutine");
|
||||
GtkWidget* gl_gs_label = gtk_label_new("Geometry Shader:");
|
||||
GtkWidget* gl_gs_combo = CreateGlComboBox("override_geometry_shader");
|
||||
GtkWidget* gl_ils_label = gtk_label_new("Image Load Store:");
|
||||
GtkWidget* gl_ils_combo = CreateGlComboBox("override_GL_ARB_shader_image_load_store");
|
||||
GtkWidget* gl_cc_label = gtk_label_new("Clip Control (depth accuracy):");
|
||||
GtkWidget* gl_cc_combo = CreateGlComboBox("override_GL_ARB_clip_control");
|
||||
GtkWidget* gl_tb_label = gtk_label_new("Texture Barrier:");
|
||||
GtkWidget* gl_tb_combo = CreateGlComboBox("override_GL_ARB_texture_barrier");
|
||||
|
||||
s_table_line = 0;
|
||||
InsertWidgetInTable(gl_table , gl_gs_label , gl_gs_combo);
|
||||
InsertWidgetInTable(gl_table , gl_bs_label , gl_bs_combo);
|
||||
InsertWidgetInTable(gl_table , gl_bt_label , gl_bt_combo);
|
||||
InsertWidgetInTable(gl_table , gl_sso_label , gl_sso_combo);
|
||||
InsertWidgetInTable(gl_table , gl_ss_label , gl_ss_combo);
|
||||
InsertWidgetInTable(gl_table , gl_ils_label , gl_ils_combo);
|
||||
InsertWidgetInTable(gl_table , gl_cc_label , gl_cc_combo);
|
||||
InsertWidgetInTable(gl_table , gl_tb_label , gl_tb_combo);
|
||||
|
||||
// Handle some nice tab
|
||||
|
||||
GtkWidget* notebook = gtk_notebook_new();
|
||||
GtkWidget* page_label[2];
|
||||
page_label[0] = gtk_label_new("Global Setting");
|
||||
page_label[1] = gtk_label_new("Advance Setting");
|
||||
|
||||
gtk_notebook_append_page(GTK_NOTEBOOK(notebook), central_box, page_label[0]);
|
||||
gtk_notebook_append_page(GTK_NOTEBOOK(notebook), advance_box, page_label[1]);
|
||||
|
||||
// Put everything in the big box.
|
||||
gtk_container_add(GTK_CONTAINER(main_box), notebook);
|
||||
|
||||
{ // Set current value of checkboxes.
|
||||
gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(shadeboost_check) , theApp.GetConfig("shadeboost" , 1));
|
||||
gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(paltex_check) , theApp.GetConfig("paltex" , 0));
|
||||
gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(fba_check) , theApp.GetConfig("fba" , 1));
|
||||
|
@ -376,144 +452,14 @@ bool RunLinuxDialog()
|
|||
gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(hack_wild_check) , theApp.GetConfig("UserHacks_WildHack" , 0));
|
||||
gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(hack_sprite_check) , theApp.GetConfig("UserHacks_SpriteHack" , 0));
|
||||
gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(hack_logz_check) , theApp.GetConfig("logz" , 1));
|
||||
|
||||
// Shadeboost scale
|
||||
#if GTK_MAJOR_VERSION < 3
|
||||
sb_brightness = gtk_hscale_new_with_range(0, 200, 10);
|
||||
#else
|
||||
sb_brightness = gtk_scale_new_with_range(GTK_ORIENTATION_HORIZONTAL, 0, 200, 10);
|
||||
#endif
|
||||
GtkWidget* sb_brightness_label = gtk_label_new("Shade Boost Brightness");
|
||||
gtk_scale_set_value_pos(GTK_SCALE(sb_brightness), GTK_POS_RIGHT);
|
||||
gtk_range_set_value(GTK_RANGE(sb_brightness), theApp.GetConfig("ShadeBoost_Brightness", 50));
|
||||
|
||||
#if GTK_MAJOR_VERSION < 3
|
||||
sb_contrast = gtk_hscale_new_with_range(0, 200, 10);
|
||||
#else
|
||||
sb_contrast = gtk_scale_new_with_range(GTK_ORIENTATION_HORIZONTAL, 0, 200, 10);
|
||||
#endif
|
||||
GtkWidget* sb_contrast_label = gtk_label_new("Shade Boost Contrast");
|
||||
gtk_scale_set_value_pos(GTK_SCALE(sb_contrast), GTK_POS_RIGHT);
|
||||
gtk_range_set_value(GTK_RANGE(sb_contrast), theApp.GetConfig("ShadeBoost_Contrast", 50));
|
||||
|
||||
#if GTK_MAJOR_VERSION < 3
|
||||
sb_saturation = gtk_hscale_new_with_range(0, 200, 10);
|
||||
#else
|
||||
sb_saturation = gtk_scale_new_with_range(GTK_ORIENTATION_HORIZONTAL, 0, 200, 10);
|
||||
#endif
|
||||
GtkWidget* sb_saturation_label = gtk_label_new("Shade Boost Saturation");
|
||||
gtk_scale_set_value_pos(GTK_SCALE(sb_saturation), GTK_POS_RIGHT);
|
||||
gtk_range_set_value(GTK_RANGE(sb_saturation), theApp.GetConfig("ShadeBoost_Saturation", 50));
|
||||
|
||||
// external shader entry
|
||||
gtk_file_chooser_set_filename(GTK_FILE_CHOOSER(shader), theApp.GetConfig("shaderfx_glsl", "dummy.glsl").c_str());
|
||||
gtk_file_chooser_set_filename(GTK_FILE_CHOOSER(shader_conf), theApp.GetConfig("shaderfx_conf", "dummy.ini").c_str());
|
||||
|
||||
// Populate all those boxes we created earlier with widgets.
|
||||
gtk_container_add(GTK_CONTAINER(res_box), native_box);
|
||||
gtk_container_add(GTK_CONTAINER(res_box), fsaa_box);
|
||||
gtk_container_add(GTK_CONTAINER(res_box), resxy_box);
|
||||
|
||||
gtk_container_add(GTK_CONTAINER(sw_box), threads_box);
|
||||
gtk_container_add(GTK_CONTAINER(sw_box), aa_check);
|
||||
gtk_container_add(GTK_CONTAINER(sw_box), spin_thread_check);
|
||||
|
||||
// Tables are strange. The numbers are for their position: left, right, top, bottom.
|
||||
gtk_table_attach_defaults(GTK_TABLE(shader_table), fxaa_check, 0, 1, 0, 1);
|
||||
gtk_table_attach_defaults(GTK_TABLE(shader_table), shadeboost_check, 0, 1, 1, 2);
|
||||
gtk_table_attach_defaults(GTK_TABLE(shader_table), sb_brightness_label, 0, 1, 2, 3);
|
||||
gtk_table_attach_defaults(GTK_TABLE(shader_table), sb_brightness, 1, 2, 2, 3);
|
||||
gtk_table_attach_defaults(GTK_TABLE(shader_table), sb_contrast_label, 0, 1, 3, 4);
|
||||
gtk_table_attach_defaults(GTK_TABLE(shader_table), sb_contrast, 1, 2, 3, 4);
|
||||
gtk_table_attach_defaults(GTK_TABLE(shader_table), sb_saturation_label, 0, 1, 4, 5);
|
||||
gtk_table_attach_defaults(GTK_TABLE(shader_table), sb_saturation, 1, 2, 4, 5);
|
||||
gtk_table_attach_defaults(GTK_TABLE(shader_table), shaderfx_check, 0, 1, 5, 6);
|
||||
gtk_table_attach_defaults(GTK_TABLE(shader_table), shader_label, 0, 1, 6, 7);
|
||||
gtk_table_attach_defaults(GTK_TABLE(shader_table), shader, 1, 2, 6, 7);
|
||||
gtk_table_attach_defaults(GTK_TABLE(shader_table), shader_conf_label, 0, 1, 7, 8);
|
||||
gtk_table_attach_defaults(GTK_TABLE(shader_table), shader_conf, 1, 2, 7, 8);
|
||||
|
||||
// Tables are strange. The numbers are for their position: left, right, top, bottom.
|
||||
gtk_table_attach_defaults(GTK_TABLE(hw_table), filter_box, 0, 1, 0, 1);
|
||||
gtk_table_attach_defaults(GTK_TABLE(hw_table), paltex_check, 0, 1, 1, 2);
|
||||
gtk_table_attach_defaults(GTK_TABLE(hw_table), fba_check, 1, 2, 1, 2);
|
||||
|
||||
// The GL advance options
|
||||
gl_box = gtk_vbox_new(false, 5);
|
||||
gl_frame = gtk_frame_new ("OpenGL Very Advanced Custom Settings");
|
||||
gtk_container_add(GTK_CONTAINER(gl_frame), gl_box);
|
||||
gl_table = gtk_table_new(10, 2, false);
|
||||
gtk_container_add(GTK_CONTAINER(gl_box), gl_table);
|
||||
|
||||
GtkWidget* gl_bs_label = gtk_label_new("Buffer Storage:");
|
||||
GtkWidget* gl_bs_combo = CreateGlComboBox("override_GL_ARB_buffer_storage");
|
||||
GtkWidget* gl_bt_label = gtk_label_new("Bindless Texture:");
|
||||
GtkWidget* gl_bt_combo = CreateGlComboBox("override_GL_ARB_bindless_texture");
|
||||
GtkWidget* gl_sso_label = gtk_label_new("Separate Shader:");
|
||||
GtkWidget* gl_sso_combo = CreateGlComboBox("override_GL_ARB_separate_shader_objects");
|
||||
GtkWidget* gl_ss_label = gtk_label_new("Shader Subroutine:");
|
||||
GtkWidget* gl_ss_combo = CreateGlComboBox("override_GL_ARB_shader_subroutine");
|
||||
GtkWidget* gl_gs_label = gtk_label_new("Geometry Shader:");
|
||||
GtkWidget* gl_gs_combo = CreateGlComboBox("override_geometry_shader");
|
||||
GtkWidget* gl_ils_label = gtk_label_new("Image Load Store:");
|
||||
GtkWidget* gl_ils_combo = CreateGlComboBox("override_GL_ARB_shader_image_load_store");
|
||||
GtkWidget* gl_cc_label = gtk_label_new("Clip Control (depth accuracy):");
|
||||
GtkWidget* gl_cc_combo = CreateGlComboBox("override_GL_ARB_clip_control");
|
||||
GtkWidget* gl_tb_label = gtk_label_new("Texture Barrier:");
|
||||
GtkWidget* gl_tb_combo = CreateGlComboBox("override_GL_ARB_texture_barrier");
|
||||
|
||||
gtk_table_attach_defaults(GTK_TABLE(gl_table), gl_gs_label, 0, 1, 0, 1);
|
||||
gtk_table_attach_defaults(GTK_TABLE(gl_table), gl_gs_combo, 1, 2, 0, 1);
|
||||
gtk_table_attach_defaults(GTK_TABLE(gl_table), gl_bs_label, 0, 1, 1, 2);
|
||||
gtk_table_attach_defaults(GTK_TABLE(gl_table), gl_bs_combo, 1, 2, 1, 2);
|
||||
gtk_table_attach_defaults(GTK_TABLE(gl_table), gl_bt_label, 0, 1, 2, 3);
|
||||
gtk_table_attach_defaults(GTK_TABLE(gl_table), gl_bt_combo, 1, 2, 2, 3);
|
||||
gtk_table_attach_defaults(GTK_TABLE(gl_table), gl_sso_label, 0, 1, 3, 4);
|
||||
gtk_table_attach_defaults(GTK_TABLE(gl_table), gl_sso_combo, 1, 2, 3, 4);
|
||||
gtk_table_attach_defaults(GTK_TABLE(gl_table), gl_ss_label, 0, 1, 4, 5);
|
||||
gtk_table_attach_defaults(GTK_TABLE(gl_table), gl_ss_combo, 1, 2, 4, 5);
|
||||
gtk_table_attach_defaults(GTK_TABLE(gl_table), gl_ils_label, 0, 1, 5, 6);
|
||||
gtk_table_attach_defaults(GTK_TABLE(gl_table), gl_ils_combo, 1, 2, 5, 6);
|
||||
gtk_table_attach_defaults(GTK_TABLE(gl_table), gl_cc_label, 0, 1, 6, 7);
|
||||
gtk_table_attach_defaults(GTK_TABLE(gl_table), gl_cc_combo, 1, 2, 6, 7);
|
||||
gtk_table_attach_defaults(GTK_TABLE(gl_table), gl_tb_label, 0, 1, 7, 8);
|
||||
gtk_table_attach_defaults(GTK_TABLE(gl_table), gl_tb_combo, 1, 2, 7, 8);
|
||||
// those one are properly detected so no need a gui
|
||||
#if 0
|
||||
override_GL_ARB_copy_image = -1
|
||||
override_GL_ARB_explicit_uniform_location = -1
|
||||
override_GL_ARB_gpu_shader5 = -1
|
||||
override_GL_ARB_shading_language_420pack = -1
|
||||
#endif
|
||||
|
||||
// Handle some nice tab
|
||||
notebook = gtk_notebook_new();
|
||||
page_label[0] = gtk_label_new("Global Setting");
|
||||
page_label[1] = gtk_label_new("Advance Setting");
|
||||
|
||||
gtk_notebook_append_page(GTK_NOTEBOOK(notebook), central_box, page_label[0]);
|
||||
gtk_notebook_append_page(GTK_NOTEBOOK(notebook), advance_box, page_label[1]);
|
||||
|
||||
// Put everything in the big box.
|
||||
gtk_container_add(GTK_CONTAINER(main_box), renderer_box);
|
||||
gtk_container_add(GTK_CONTAINER(main_box), interlace_box);
|
||||
gtk_container_add(GTK_CONTAINER(main_box), notebook);
|
||||
|
||||
gtk_container_add(GTK_CONTAINER(central_box), res_frame);
|
||||
gtk_container_add(GTK_CONTAINER(central_box), shader_frame);
|
||||
gtk_container_add(GTK_CONTAINER(central_box), hw_frame);
|
||||
gtk_container_add(GTK_CONTAINER(central_box), sw_frame);
|
||||
|
||||
gtk_container_add(GTK_CONTAINER(advance_box), hack_frame);
|
||||
gtk_container_add(GTK_CONTAINER(advance_box), gl_frame);
|
||||
}
|
||||
|
||||
// Put the box in the dialog and show it to the world.
|
||||
gtk_container_add (GTK_CONTAINER(gtk_dialog_get_content_area(GTK_DIALOG(dialog))), main_box);
|
||||
gtk_widget_show_all (dialog);
|
||||
return_value = gtk_dialog_run (GTK_DIALOG (dialog));
|
||||
|
||||
if (return_value == GTK_RESPONSE_ACCEPT)
|
||||
{
|
||||
if (return_value == GTK_RESPONSE_ACCEPT) {
|
||||
int mode_height = 0, mode_width = 0;
|
||||
|
||||
mode_width = theApp.GetConfig("ModeWidth", 640);
|
||||
|
@ -540,6 +486,12 @@ override_GL_ARB_shading_language_420pack = -1
|
|||
if (gtk_combo_box_get_active(GTK_COMBO_BOX(interlace_combo_box)) != -1)
|
||||
theApp.SetConfig( "interlace", (int)gtk_combo_box_get_active(GTK_COMBO_BOX(interlace_combo_box)));
|
||||
|
||||
if (gtk_combo_box_get_active(GTK_COMBO_BOX(af_combo_box)) != -1) {
|
||||
int af = gtk_combo_box_get_active(GTK_COMBO_BOX(af_combo_box));
|
||||
theApp.SetConfig("AnisotropicFiltering", (af) ? 1 : 0);
|
||||
theApp.SetConfig("MaxAnisotropy", round(exp2(af)));
|
||||
}
|
||||
|
||||
theApp.SetConfig("extrathreads", (int)gtk_spin_button_get_value(GTK_SPIN_BUTTON(threads_spin)));
|
||||
|
||||
theApp.SetConfig("filter", (int)gtk_combo_box_get_active(GTK_COMBO_BOX(filter_combo_box)));
|
||||
|
|
Loading…
Reference in New Issue