wxNotebookPage* PreferencesWindow::CreateEditorPage() { wxNotebookPage* editor_page = newd wxPanel(book, wxID_ANY); wxSizer* sizer = newd wxBoxSizer(wxVERTICAL); sizer->Add(group_actions_chkbox = newd wxCheckBox(editor_page, wxID_ANY, wxT("Group same-type actions"))); group_actions_chkbox->SetValue(settings.getBoolean(Config::GROUP_ACTIONS)); group_actions_chkbox->SetToolTip(wxT("This will group actions of the same type (drawing, selection..) when several take place in consecutive order.")); sizer->Add(duplicate_id_warn_chkbox = newd wxCheckBox(editor_page, wxID_ANY, wxT("Warn for duplicate IDs"))); duplicate_id_warn_chkbox->SetValue(settings.getBoolean(Config::WARN_FOR_DUPLICATE_ID)); duplicate_id_warn_chkbox->SetToolTip(wxT("Warns for most kinds of duplicate IDs.")); sizer->Add(house_remove_chkbox = newd wxCheckBox(editor_page, wxID_ANY, wxT("House brush removes items"))); house_remove_chkbox->SetValue(settings.getBoolean(Config::HOUSE_BRUSH_REMOVE_ITEMS)); house_remove_chkbox->SetToolTip(wxT("When this option is checked, the house brush will automaticly remove items that will respawn every time the map is loaded.")); sizer->Add(auto_assign_doors_chkbox = newd wxCheckBox(editor_page, wxID_ANY, wxT("Auto-assign door ids"))); auto_assign_doors_chkbox->SetValue(settings.getBoolean(Config::AUTO_ASSIGN_DOORID)); auto_assign_doors_chkbox->SetToolTip(wxT("This will auto-assign unique door ids to all doors placed with the door brush (or doors painted over with the house brush).\nDoes NOT affect doors placed using the RAW palette.")); sizer->Add(doodad_erase_same_chkbox = newd wxCheckBox(editor_page, wxID_ANY, wxT("Doodad brush only erases same"))); doodad_erase_same_chkbox->SetValue(settings.getBoolean(Config::DOODAD_BRUSH_ERASE_LIKE)); doodad_erase_same_chkbox->SetToolTip(wxT("The doodad brush will only erase items that belongs to the current brush.")); sizer->Add(eraser_leave_unique_chkbox = newd wxCheckBox(editor_page, wxID_ANY, wxT("Eraser leaves unique items"))); eraser_leave_unique_chkbox->SetValue(settings.getBoolean(Config::ERASER_LEAVE_UNIQUE)); eraser_leave_unique_chkbox->SetToolTip(wxT("The eraser will leave containers with items in them, items with unique or action id and items.")); sizer->Add(allow_spawnless_chkbox = newd wxCheckBox(editor_page, wxID_ANY, wxT("Allow creatures without spawn"))); allow_spawnless_chkbox->SetValue(settings.getBoolean(Config::ALLOW_CREATURES_WITHOUT_SPAWN)); allow_spawnless_chkbox->SetToolTip(wxT("When this option is checked, you can place creatures without placing a spawn, they will NOT be saved, however.")); sizer->Add(allow_multiple_orderitems_chkbox = newd wxCheckBox(editor_page, wxID_ANY, wxT("Prevent toporder conflict"))); allow_multiple_orderitems_chkbox->SetValue(settings.getBoolean(Config::RAW_LIKE_SIMONE)); allow_multiple_orderitems_chkbox->SetToolTip(wxT("When this option is checked, you can not place several items with the same toporder on one tile using a RAW Brush.")); sizer->Add(20,10); sizer->Add(merge_move_chkbox = newd wxCheckBox(editor_page, wxID_ANY, wxT("Use merge move"))); merge_move_chkbox->SetValue(settings.getBoolean(Config::MERGE_MOVE)); merge_move_chkbox->SetToolTip(wxT("Moved tiles won't replace already placed tiles.")); sizer->Add(merge_paste_chkbox = newd wxCheckBox(editor_page, wxID_ANY, wxT("Use merge paste"))); merge_paste_chkbox->SetValue(settings.getBoolean(Config::MERGE_PASTE)); merge_paste_chkbox->SetToolTip(wxT("Pasted tiles won't replace already placed tiles.")); editor_page->SetSizerAndFit(sizer); return editor_page; }
wxNotebookPage* PreferencesWindow::CreateGeneralPage() { wxNotebookPage* general_page = newd wxPanel(book, wxID_ANY); wxSizer* sizer = newd wxBoxSizer(wxVERTICAL); wxStaticText* tmptext; sizer->Add(always_make_backup_chkbox = newd wxCheckBox(general_page, wxID_ANY, wxT("Always make map backup"))); always_make_backup_chkbox->SetValue(settings.getInteger(Config::ALWAYS_MAKE_BACKUP) == 1); sizer->Add(create_on_startup_chkbox = newd wxCheckBox(general_page, wxID_ANY, wxT("Create map on startup"))); create_on_startup_chkbox->SetValue(settings.getInteger(Config::CREATE_MAP_ON_STARTUP) == 1); sizer->Add(update_check_on_startup_chkbox = newd wxCheckBox(general_page, wxID_ANY, wxT("Check for updates on startup"))); update_check_on_startup_chkbox->SetValue(settings.getInteger(Config::USE_UPDATER) == 1); sizer->Add(only_one_instance_chkbox = newd wxCheckBox(general_page, wxID_ANY, wxT("Open all maps in the same instance"))); only_one_instance_chkbox->SetValue(settings.getInteger(Config::ONLY_ONE_INSTANCE) == 1); only_one_instance_chkbox->SetToolTip(wxT("When checked, maps opened using the shell will all be opened in the same instance.")); wxFlexGridSizer* grid_sizer = newd wxFlexGridSizer(2, 10, 10); grid_sizer->AddGrowableCol(1); grid_sizer->Add(tmptext = newd wxStaticText(general_page, wxID_ANY, wxT("Undo queue size: ")), 0); undo_size_spin = newd wxSpinCtrl(general_page, wxID_ANY, i2ws(settings.getInteger(Config::UNDO_SIZE)), wxDefaultPosition, wxDefaultSize, wxSP_ARROW_KEYS, 0, 0x10000000); grid_sizer->Add(undo_size_spin, 0); SetWindowToolTip(tmptext, undo_size_spin, wxT("How many action you can undo, be aware that a high value will increase memory usage.")); grid_sizer->Add(tmptext = newd wxStaticText(general_page, wxID_ANY, wxT("Undo maximum memory size (MB): ")), 0); undo_mem_size_spin = newd wxSpinCtrl(general_page, wxID_ANY, i2ws(settings.getInteger(Config::UNDO_MEM_SIZE)), wxDefaultPosition, wxDefaultSize, wxSP_ARROW_KEYS, 0, 4096); grid_sizer->Add(undo_mem_size_spin, 0); SetWindowToolTip(tmptext, undo_mem_size_spin, wxT("The approximite limit for the memory usage of the undo queue.")); grid_sizer->Add(tmptext = newd wxStaticText(general_page, wxID_ANY, wxT("Worker Threads: ")), 0); worker_threads_spin = newd wxSpinCtrl(general_page, wxID_ANY, i2ws(settings.getInteger(Config::WORKER_THREADS)), wxDefaultPosition, wxDefaultSize, wxSP_ARROW_KEYS, 1, 64); grid_sizer->Add(worker_threads_spin, 0); SetWindowToolTip(tmptext, worker_threads_spin, wxT("How many threads the editor will use for intensive operations. This should be equivalent to the amount of logical processors in your system.")); sizer->Add(20,10); sizer->Add(grid_sizer); general_page->SetSizerAndFit(sizer); return general_page; }
BrushThicknessPanel::BrushThicknessPanel(wxWindow* parent) : PalettePanel(parent, wxID_ANY) { wxSizer* thickness_sizer = newd wxBoxSizer(wxVERTICAL); wxSizer* thickness_sub_sizer = newd wxBoxSizer(wxHORIZONTAL); thickness_sub_sizer->Add(20,10); use_button = newd wxCheckBox(this, PALETTE_DOODAD_USE_THICKNESS, wxT("Use custom thickness")); thickness_sub_sizer->Add(use_button); thickness_sizer->Add(thickness_sub_sizer, 1, wxEXPAND); slider = newd wxSlider(this, PALETTE_DOODAD_SLIDER, 5, 1, 10, wxDefaultPosition); thickness_sizer->Add(slider, 1, wxEXPAND); SetSizerAndFit(thickness_sizer); }
EditHouseDialog::EditHouseDialog(wxWindow* parent, Map* map, House* house) : wxDialog(parent, wxID_ANY, wxT("House"), wxDefaultPosition, wxSize(250,160)), map(map), what_house(house) { ASSERT(map); ASSERT(house); // Create topsizer wxSizer* sizer = newd wxBoxSizer(wxVERTICAL); wxSizer* tmpsizer; house_name = wxstr(house->name); house_id = i2ws(house->id); house_rent = i2ws(house->rent); // House options tmpsizer = newd wxStaticBoxSizer(wxHORIZONTAL, this, wxT("Name")); name_field = newd wxTextCtrl(this, wxID_ANY, wxT(""), wxDefaultPosition, wxSize(230,20), 0, wxTextValidator(wxFILTER_ASCII, &house_name)); tmpsizer->Add(name_field); sizer->Add(tmpsizer, wxSizerFlags().Border(wxALL, 20)); tmpsizer = newd wxStaticBoxSizer(wxHORIZONTAL, this, wxT("Rent / ID")); rent_field = newd wxTextCtrl(this, wxID_ANY, wxT(""), wxDefaultPosition, wxSize(160,20), 0, wxTextValidator(wxFILTER_NUMERIC, &house_rent)); tmpsizer->Add(rent_field); id_field = newd wxTextCtrl(this, wxID_ANY, wxT(""), wxDefaultPosition, wxSize(70,20), 0, wxTextValidator(wxFILTER_NUMERIC, &house_id)); id_field->Enable(false); tmpsizer->Add(id_field); sizer->Add(tmpsizer, wxSizerFlags().Border(wxALL, 20)); // House options guildhall_field = newd wxCheckBox(this, wxID_ANY, wxT("Guildhall"), wxDefaultPosition); sizer->Add(guildhall_field, wxSizerFlags().Border(wxRIGHT | wxLEFT | wxBOTTOM, 20)); guildhall_field->SetValue(house->guildhall); // OK/Cancel buttons tmpsizer = newd wxBoxSizer(wxHORIZONTAL); tmpsizer->Add(newd wxButton(this, wxID_OK, wxT("OK")), wxSizerFlags(1).Center()); tmpsizer->Add(newd wxButton(this, wxID_CANCEL, wxT("Cancel")), wxSizerFlags(1).Center()); sizer->Add(tmpsizer, wxSizerFlags(1).Center().Border(wxRIGHT | wxLEFT | wxBOTTOM, 20)); SetSizerAndFit(sizer); }
wxNotebookPage* PreferencesWindow::CreateGeneralPage() { wxNotebookPage* general_page = newd wxPanel(book, wxID_ANY); wxSizer* sizer = newd wxBoxSizer(wxVERTICAL); wxStaticText* tmptext; always_make_backup_chkbox = newd wxCheckBox(general_page, wxID_ANY, "Always make map backup"); always_make_backup_chkbox->SetValue(g_settings.getInteger(Config::ALWAYS_MAKE_BACKUP) == 1); sizer->Add(always_make_backup_chkbox, 0, wxLEFT | wxTOP, 5); create_on_startup_chkbox = newd wxCheckBox(general_page, wxID_ANY, "Create map on startup"); create_on_startup_chkbox->SetValue(g_settings.getInteger(Config::CREATE_MAP_ON_STARTUP) == 1); sizer->Add(create_on_startup_chkbox, 0, wxLEFT | wxTOP, 5); update_check_on_startup_chkbox = newd wxCheckBox(general_page, wxID_ANY, "Check for updates on startup"); update_check_on_startup_chkbox->SetValue(g_settings.getInteger(Config::USE_UPDATER) == 1); sizer->Add(update_check_on_startup_chkbox, 0, wxLEFT | wxTOP, 5); only_one_instance_chkbox = newd wxCheckBox(general_page, wxID_ANY, "Open all maps in the same instance"); only_one_instance_chkbox->SetValue(g_settings.getInteger(Config::ONLY_ONE_INSTANCE) == 1); only_one_instance_chkbox->SetToolTip("When checked, maps opened using the shell will all be opened in the same instance."); sizer->Add(only_one_instance_chkbox, 0, wxLEFT | wxTOP, 5); sizer->AddSpacer(10); wxFlexGridSizer* grid_sizer = newd wxFlexGridSizer(2, 10, 10); grid_sizer->AddGrowableCol(1); grid_sizer->Add(tmptext = newd wxStaticText(general_page, wxID_ANY, "Undo queue size: "), 0); undo_size_spin = newd wxSpinCtrl(general_page, wxID_ANY, i2ws(g_settings.getInteger(Config::UNDO_SIZE)), wxDefaultPosition, wxDefaultSize, wxSP_ARROW_KEYS, 0, 0x10000000); grid_sizer->Add(undo_size_spin, 0); SetWindowToolTip(tmptext, undo_size_spin, "How many action you can undo, be aware that a high value will increase memory usage."); grid_sizer->Add(tmptext = newd wxStaticText(general_page, wxID_ANY, "Undo maximum memory size (MB): "), 0); undo_mem_size_spin = newd wxSpinCtrl(general_page, wxID_ANY, i2ws(g_settings.getInteger(Config::UNDO_MEM_SIZE)), wxDefaultPosition, wxDefaultSize, wxSP_ARROW_KEYS, 0, 4096); grid_sizer->Add(undo_mem_size_spin, 0); SetWindowToolTip(tmptext, undo_mem_size_spin, "The approximite limit for the memory usage of the undo queue."); grid_sizer->Add(tmptext = newd wxStaticText(general_page, wxID_ANY, "Worker Threads: "), 0); worker_threads_spin = newd wxSpinCtrl(general_page, wxID_ANY, i2ws(g_settings.getInteger(Config::WORKER_THREADS)), wxDefaultPosition, wxDefaultSize, wxSP_ARROW_KEYS, 1, 64); grid_sizer->Add(worker_threads_spin, 0); SetWindowToolTip(tmptext, worker_threads_spin, "How many threads the editor will use for intensive operations. This should be equivalent to the amount of logical processors in your system."); grid_sizer->Add(tmptext = newd wxStaticText(general_page, wxID_ANY, "Replace count: "), 0); replace_size_spin = newd wxSpinCtrl(general_page, wxID_ANY, i2ws(g_settings.getInteger(Config::REPLACE_SIZE)), wxDefaultPosition, wxDefaultSize, wxSP_ARROW_KEYS, 0, 100000); grid_sizer->Add(replace_size_spin, 0); SetWindowToolTip(tmptext, replace_size_spin, "How many items you can replace on the map using the Replace Item tool."); sizer->Add(grid_sizer, 0, wxALL, 5); sizer->AddSpacer(10); wxString position_choices[] = { " {x = 0, y = 0, z = 0}", " {\"x\":0,\"y\":0,\"z\":0}", " x, y, z", " (x, y, z)", " Position(x, y, z)" }; int radio_choices = sizeof(position_choices) / sizeof(wxString); position_format = newd wxRadioBox(general_page, wxID_ANY, "Copy Position Format", wxDefaultPosition, wxDefaultSize, radio_choices, position_choices, 1, wxRA_SPECIFY_COLS); position_format->SetSelection(g_settings.getInteger(Config::COPY_POSITION_FORMAT)); sizer->Add(position_format, 0, wxALL | wxEXPAND, 5); SetWindowToolTip(tmptext, position_format, "The position format when copying from the map."); general_page->SetSizerAndFit(sizer); return general_page; }
wxNotebookPage* PreferencesWindow::CreateClientPage() { wxNotebookPage* client_page = newd wxPanel(book, wxID_ANY); // Refresh g_settings ClientVersion::saveVersions(); ClientVersionList versions = ClientVersion::getAllVisible(); wxSizer* topsizer = newd wxBoxSizer(wxVERTICAL); wxFlexGridSizer* options_sizer = newd wxFlexGridSizer(2, 10, 10); options_sizer->AddGrowableCol(1); // Default client version choice control default_version_choice = newd wxChoice(client_page, wxID_ANY); wxStaticText* default_client_tooltip = newd wxStaticText(client_page, wxID_ANY, "Default client version:"); options_sizer->Add(default_client_tooltip, 0, wxLEFT | wxTOP, 5); options_sizer->Add(default_version_choice, 0, wxTOP, 5); SetWindowToolTip(default_client_tooltip, default_version_choice, "This will decide what client version will be used when new maps are created."); // Check file sigs checkbox check_sigs_chkbox = newd wxCheckBox(client_page, wxID_ANY, "Check file signatures"); check_sigs_chkbox->SetValue(g_settings.getBoolean(Config::CHECK_SIGNATURES)); check_sigs_chkbox->SetToolTip("When this option is not checked, the editor will load any OTB/DAT/SPR combination without complaints. This may cause graphics bugs."); options_sizer->Add(check_sigs_chkbox, 0, wxLEFT | wxRIGHT | wxTOP, 5); // Add the grid sizer topsizer->Add(options_sizer, wxSizerFlags(0).Expand()); topsizer->AddSpacer(10); wxScrolledWindow *client_list_window = newd wxScrolledWindow(client_page, wxID_ANY, wxDefaultPosition, wxSize(400, 350), wxSUNKEN_BORDER); wxFlexGridSizer* client_list_sizer = newd wxFlexGridSizer(2, 10, 10); client_list_sizer->AddGrowableCol(1); client_list_window->SetVirtualSize( 500, 1000 ); int version_counter = 0; for(ClientVersionList::iterator version_iter = versions.begin(); version_iter != versions.end(); ++version_iter) { const ClientVersion* version = *version_iter; if(!version->isVisible()) continue; default_version_choice->Append(wxstr(version->getName())); wxString searchtip; searchtip << "Version " << wxstr(version->getName()) << " search path"; wxStaticText *tmp_text = newd wxStaticText(client_list_window, wxID_ANY, searchtip); client_list_sizer->Add(tmp_text, 0); wxDirPickerCtrl* dir_picker = newd wxDirPickerCtrl(client_list_window, wxID_ANY, version->getClientPath().GetFullPath()); version_dir_pickers.push_back(dir_picker); client_list_sizer->Add(dir_picker, 0); wxString tooltip; tooltip << "The editor will look for " << wxstr(version->getName()) << " DAT & SPR here."; tmp_text->SetToolTip(tooltip); dir_picker->SetToolTip(tooltip); if(version->getID() == g_settings.getInteger(Config::DEFAULT_CLIENT_VERSION)) default_version_choice->SetSelection(version_counter); version_counter++; } // Set the sizers client_list_window->SetSizer(client_list_sizer); client_list_window->FitInside(); client_list_window->SetScrollRate(5, 5); topsizer->Add(client_list_window, 0, wxALL, 5); client_page->SetSizerAndFit(topsizer); return client_page; }
wxNotebookPage* PreferencesWindow::CreateUIPage() { wxNotebookPage* ui_page = newd wxPanel(book, wxID_ANY); wxSizer* sizer = newd wxBoxSizer(wxVERTICAL); wxFlexGridSizer* subsizer = newd wxFlexGridSizer(2, 10, 10); subsizer->AddGrowableCol(1); terrain_palette_style_choice = AddPaletteStyleChoice( ui_page, subsizer, "Terrain Palette Style:", "Configures the look of the terrain palette.", g_settings.getString(Config::PALETTE_TERRAIN_STYLE)); doodad_palette_style_choice = AddPaletteStyleChoice( ui_page, subsizer, "Doodad Palette Style:", "Configures the look of the doodad palette.", g_settings.getString(Config::PALETTE_DOODAD_STYLE)); item_palette_style_choice = AddPaletteStyleChoice( ui_page, subsizer, "Item Palette Style:", "Configures the look of the item palette.", g_settings.getString(Config::PALETTE_ITEM_STYLE)); raw_palette_style_choice = AddPaletteStyleChoice( ui_page, subsizer, "RAW Palette Style:", "Configures the look of the raw palette.", g_settings.getString(Config::PALETTE_RAW_STYLE)); sizer->Add(subsizer, 0, wxALL, 5); sizer->AddSpacer(10); large_terrain_tools_chkbox = newd wxCheckBox(ui_page, wxID_ANY, "Use large terrain palette tool & size icons"); large_terrain_tools_chkbox->SetValue(g_settings.getBoolean(Config::USE_LARGE_TERRAIN_TOOLBAR)); sizer->Add(large_terrain_tools_chkbox, 0, wxLEFT | wxTOP, 5); large_doodad_sizebar_chkbox = newd wxCheckBox(ui_page, wxID_ANY, "Use large doodad size palette icons"); large_doodad_sizebar_chkbox->SetValue(g_settings.getBoolean(Config::USE_LARGE_DOODAD_SIZEBAR)); sizer->Add(large_doodad_sizebar_chkbox, 0, wxLEFT | wxTOP, 5); large_item_sizebar_chkbox = newd wxCheckBox(ui_page, wxID_ANY, "Use large item size palette icons"); large_item_sizebar_chkbox->SetValue(g_settings.getBoolean(Config::USE_LARGE_ITEM_SIZEBAR)); sizer->Add(large_item_sizebar_chkbox, 0, wxLEFT | wxTOP, 5); large_house_sizebar_chkbox = newd wxCheckBox(ui_page, wxID_ANY, "Use large house palette size icons"); large_house_sizebar_chkbox->SetValue(g_settings.getBoolean(Config::USE_LARGE_HOUSE_SIZEBAR)); sizer->Add(large_house_sizebar_chkbox, 0, wxLEFT | wxTOP, 5); large_raw_sizebar_chkbox = newd wxCheckBox(ui_page, wxID_ANY, "Use large raw palette size icons"); large_raw_sizebar_chkbox->SetValue(g_settings.getBoolean(Config::USE_LARGE_RAW_SIZEBAR)); sizer->Add(large_raw_sizebar_chkbox, 0, wxLEFT | wxTOP, 5); large_container_icons_chkbox = newd wxCheckBox(ui_page, wxID_ANY, "Use large container view icons"); large_container_icons_chkbox->SetValue(g_settings.getBoolean(Config::USE_LARGE_CONTAINER_ICONS)); sizer->Add(large_container_icons_chkbox, 0, wxLEFT | wxTOP, 5); large_pick_item_icons_chkbox = newd wxCheckBox(ui_page, wxID_ANY, "Use large item picker icons"); large_pick_item_icons_chkbox->SetValue(g_settings.getBoolean(Config::USE_LARGE_CHOOSE_ITEM_ICONS)); sizer->Add(large_pick_item_icons_chkbox, 0, wxLEFT | wxTOP, 5); sizer->AddSpacer(10); switch_mousebtn_chkbox = newd wxCheckBox(ui_page, wxID_ANY, "Switch mousebuttons"); switch_mousebtn_chkbox->SetValue(g_settings.getBoolean(Config::SWITCH_MOUSEBUTTONS)); switch_mousebtn_chkbox->SetToolTip("Switches the right and center mouse button."); sizer->Add(switch_mousebtn_chkbox, 0, wxLEFT | wxTOP, 5); doubleclick_properties_chkbox = newd wxCheckBox(ui_page, wxID_ANY, "Double click for properties"); doubleclick_properties_chkbox->SetValue(g_settings.getBoolean(Config::DOUBLECLICK_PROPERTIES)); doubleclick_properties_chkbox->SetToolTip("Double clicking on a tile will bring up the properties menu for the top item."); sizer->Add(doubleclick_properties_chkbox, 0, wxLEFT | wxTOP, 5); inversed_scroll_chkbox = newd wxCheckBox(ui_page, wxID_ANY, "Use inversed scroll"); inversed_scroll_chkbox->SetValue(g_settings.getFloat(Config::SCROLL_SPEED) < 0); inversed_scroll_chkbox->SetToolTip("When this checkbox is checked, dragging the map using the center mouse button will be inversed (default RTS behaviour)."); sizer->Add(inversed_scroll_chkbox, 0, wxLEFT | wxTOP, 5); sizer->AddSpacer(10); sizer->Add(newd wxStaticText(ui_page, wxID_ANY, "Scroll speed: "), 0, wxLEFT | wxTOP, 5); int true_scrollspeed = int(std::abs(g_settings.getFloat(Config::SCROLL_SPEED)) * 10); scroll_speed_slider = newd wxSlider(ui_page, wxID_ANY, true_scrollspeed, 1, max(true_scrollspeed, 100)); scroll_speed_slider->SetToolTip("This controls how fast the map will scroll when you hold down the center mouse button and move it around."); sizer->Add(scroll_speed_slider, 0, wxEXPAND, 5); sizer->Add(newd wxStaticText(ui_page, wxID_ANY, "Zoom speed: "), 0, wxLEFT | wxTOP, 5); int true_zoomspeed = int(g_settings.getFloat(Config::ZOOM_SPEED) * 10); zoom_speed_slider = newd wxSlider(ui_page, wxID_ANY, true_zoomspeed, 1, max(true_zoomspeed, 100)); zoom_speed_slider->SetToolTip("This controls how fast you will zoom when you scroll the center mouse button."); sizer->Add(zoom_speed_slider, 0, wxEXPAND, 5); ui_page->SetSizerAndFit(sizer); return ui_page; }
wxNotebookPage* PreferencesWindow::CreateGraphicsPage() { wxWindow* tmp; wxNotebookPage* graphics_page = newd wxPanel(book, wxID_ANY); wxSizer* sizer = newd wxBoxSizer(wxVERTICAL); hide_items_when_zoomed_chkbox = newd wxCheckBox(graphics_page, wxID_ANY, "Hide items when zoomed out"); hide_items_when_zoomed_chkbox->SetValue(g_settings.getBoolean(Config::HIDE_ITEMS_WHEN_ZOOMED)); sizer->Add(hide_items_when_zoomed_chkbox, 0, wxLEFT | wxTOP, 5); SetWindowToolTip(hide_items_when_zoomed_chkbox, "When this option is checked, \"loose\" items will be hidden when you zoom very far out."); icon_selection_shadow_chkbox = newd wxCheckBox(graphics_page, wxID_ANY, "Use icon selection shadow"); icon_selection_shadow_chkbox->SetValue(g_settings.getBoolean(Config::USE_GUI_SELECTION_SHADOW)); sizer->Add(icon_selection_shadow_chkbox, 0, wxLEFT | wxTOP, 5); SetWindowToolTip(icon_selection_shadow_chkbox, "When this option is checked, selected items in the palette menu will be shaded."); use_memcached_chkbox = newd wxCheckBox(graphics_page, wxID_ANY, "Use memcached sprites"); use_memcached_chkbox->SetValue(g_settings.getBoolean(Config::USE_MEMCACHED_SPRITES)); sizer->Add(use_memcached_chkbox, 0, wxLEFT | wxTOP, 5); SetWindowToolTip(use_memcached_chkbox, "When this is checked, sprites will be loaded into memory at startup and unpacked at runtime. This is faster but consumes more memory.\nIf it is not checked, the editor will use less memory but there will be a performance decrease due to reading sprites from the disk."); sizer->AddSpacer(10); wxFlexGridSizer* subsizer = newd wxFlexGridSizer(2, 10, 10); subsizer->AddGrowableCol(1); // Icon background color icon_background_choice = newd wxChoice(graphics_page, wxID_ANY); icon_background_choice->Append("Black background"); icon_background_choice->Append("Gray background"); icon_background_choice->Append("White background"); if(g_settings.getInteger(Config::ICON_BACKGROUND) == 255) { icon_background_choice->SetSelection(2); } else if(g_settings.getInteger(Config::ICON_BACKGROUND) == 88) { icon_background_choice->SetSelection(1); } else { icon_background_choice->SetSelection(0); } subsizer->Add(tmp = newd wxStaticText(graphics_page, wxID_ANY, "Icon background color: "), 0); subsizer->Add(icon_background_choice, 0); SetWindowToolTip(icon_background_choice, tmp, "This will change the background color on icons in all windows."); // Cursor colors subsizer->Add(tmp = newd wxStaticText(graphics_page, wxID_ANY, "Cursor color: "), 0); subsizer->Add(cursor_color_pick = newd wxColourPickerCtrl(graphics_page, wxID_ANY, wxColor( g_settings.getInteger(Config::CURSOR_RED), g_settings.getInteger(Config::CURSOR_GREEN), g_settings.getInteger(Config::CURSOR_BLUE), g_settings.getInteger(Config::CURSOR_ALPHA) )), 0); SetWindowToolTip(icon_background_choice, tmp, "The color of the main cursor on the map (while in drawing mode)."); // Alternate cursor color subsizer->Add(tmp = newd wxStaticText(graphics_page, wxID_ANY, "Secondary cursor color: "), 0); subsizer->Add(cursor_alt_color_pick = newd wxColourPickerCtrl(graphics_page, wxID_ANY, wxColor( g_settings.getInteger(Config::CURSOR_ALT_RED), g_settings.getInteger(Config::CURSOR_ALT_GREEN), g_settings.getInteger(Config::CURSOR_ALT_BLUE), g_settings.getInteger(Config::CURSOR_ALT_ALPHA) )), 0); SetWindowToolTip(icon_background_choice, tmp, "The color of the secondary cursor on the map (for houses and flags)."); // Screenshot dir subsizer->Add(tmp = newd wxStaticText(graphics_page, wxID_ANY, "Screenshot directory: "), 0); screenshot_directory_picker = newd wxDirPickerCtrl(graphics_page, wxID_ANY); subsizer->Add(screenshot_directory_picker); wxString ss = wxstr(g_settings.getString(Config::SCREENSHOT_DIRECTORY)); screenshot_directory_picker->SetPath(ss); SetWindowToolTip(screenshot_directory_picker, "Screenshot taken in the editor will be saved to this directory."); // Screenshot format screenshot_format_choice = newd wxChoice(graphics_page, wxID_ANY); screenshot_format_choice->Append("PNG"); screenshot_format_choice->Append("JPG"); screenshot_format_choice->Append("TGA"); screenshot_format_choice->Append("BMP"); if(g_settings.getString(Config::SCREENSHOT_FORMAT) == "png") { screenshot_format_choice->SetSelection(0); } else if(g_settings.getString(Config::SCREENSHOT_FORMAT) == "jpg") { screenshot_format_choice->SetSelection(1); } else if(g_settings.getString(Config::SCREENSHOT_FORMAT) == "tga") { screenshot_format_choice->SetSelection(2); } else if(g_settings.getString(Config::SCREENSHOT_FORMAT) == "bmp") { screenshot_format_choice->SetSelection(3); } else { screenshot_format_choice->SetSelection(0); } subsizer->Add(tmp = newd wxStaticText(graphics_page, wxID_ANY, "Screenshot format: "), 0); subsizer->Add(screenshot_format_choice, 0); SetWindowToolTip(screenshot_format_choice, tmp, "This will affect the screenshot format used by the editor.\nTo take a screenshot, press F11."); sizer->Add(subsizer, 1, wxEXPAND | wxALL, 5); // Advanced g_settings /* wxCollapsiblePane* pane = newd wxCollapsiblePane(graphics_page, PANE_ADVANCED_GRAPHICS, "Advanced g_settings"); { wxSizer* pane_sizer = newd wxBoxSizer(wxVERTICAL); pane_sizer->Add(texture_managment_chkbox = newd wxCheckBox(pane->GetPane(), wxID_ANY, "Use texture managment")); if(g_settings.getInteger(Config::TEXTURE_MANAGEMENT)) { texture_managment_chkbox->SetValue(true); } pane_sizer->AddSpacer(8); wxFlexGridSizer* pane_grid_sizer = newd wxFlexGridSizer(2, 10, 10); pane_grid_sizer->AddGrowableCol(1); pane_grid_sizer->Add(tmp = newd wxStaticText(pane->GetPane(), wxID_ANY, "Texture clean interval: "), 0); clean_interval_spin = newd wxSpinCtrl(pane->GetPane(), wxID_ANY, i2ws(g_settings.getInteger(Config::TEXTURE_CLEAN_PULSE)), wxDefaultPosition, wxDefaultSize, wxSP_ARROW_KEYS, 0, 0x1000000); pane_grid_sizer->Add(clean_interval_spin, 0); SetWindowToolTip(clean_interval_spin, tmp, "This controls how often the editor tries to free hardware texture resources."); pane_grid_sizer->Add(tmp = newd wxStaticText(pane->GetPane(), wxID_ANY, "Texture longevity: "), 0); texture_longevity_spin = newd wxSpinCtrl(pane->GetPane(), wxID_ANY, i2ws(g_settings.getInteger(Config::TEXTURE_LONGEVITY)), wxDefaultPosition, wxDefaultSize, wxSP_ARROW_KEYS, 0, 0x1000000); pane_grid_sizer->Add(texture_longevity_spin, 0); SetWindowToolTip(texture_longevity_spin, tmp, "This controls for how long (in seconds) that the editor will keep textures in memory before it cleans them up."); pane_grid_sizer->Add(tmp = newd wxStaticText(pane->GetPane(), wxID_ANY, "Texture clean threshold: "), 0); texture_threshold_spin = newd wxSpinCtrl(pane->GetPane(), wxID_ANY, i2ws(g_settings.getInteger(Config::TEXTURE_CLEAN_THRESHOLD)), wxDefaultPosition, wxDefaultSize, wxSP_ARROW_KEYS, 100, 0x1000000); pane_grid_sizer->Add(texture_threshold_spin, 0); SetWindowToolTip(texture_threshold_spin, tmp, "This controls how many textures the editor will hold in memory before it attempts to clean up old textures. However, an infinite amount MIGHT be loaded."); pane_grid_sizer->Add(tmp = newd wxStaticText(pane->GetPane(), wxID_ANY, "Software clean threshold: "), 0); software_threshold_spin = newd wxSpinCtrl(pane->GetPane(), wxID_ANY, i2ws(g_settings.getInteger(Config::SOFTWARE_CLEAN_THRESHOLD)), wxDefaultPosition, wxDefaultSize, wxSP_ARROW_KEYS, 100, 0x1000000); pane_grid_sizer->Add(software_threshold_spin, 0); SetWindowToolTip(software_threshold_spin, tmp, "This controls how many GUI sprites (icons) the editor will hold in memory at the same time."); pane_grid_sizer->Add(tmp = newd wxStaticText(pane->GetPane(), wxID_ANY, "Software clean amount: "), 0); software_clean_amount_spin = newd wxSpinCtrl(pane->GetPane(), wxID_ANY, i2ws(g_settings.getInteger(Config::SOFTWARE_CLEAN_SIZE)), wxDefaultPosition, wxDefaultSize, wxSP_ARROW_KEYS, 1, 0x1000000); pane_grid_sizer->Add(software_clean_amount_spin, 0); SetWindowToolTip(software_clean_amount_spin, tmp, "How many sprites the editor will free at once when the limit is exceeded."); pane_sizer->Add(pane_grid_sizer, 0, wxEXPAND); pane->GetPane()->SetSizerAndFit(pane_sizer); pane->Collapse(); } sizer->Add(pane, 0); */ graphics_page->SetSizerAndFit(sizer); return graphics_page; }