Convert the Subtitles and Audio pages.

Originally committed to SVN as r4691.
This commit is contained in:
Amar Takhar 2010-07-18 19:29:54 +00:00
parent dff3cb78f6
commit 1613a5961f
2 changed files with 106 additions and 48 deletions

View file

@ -148,6 +148,10 @@ class OptionPage: public wxPanel {
public: public:
wxSizer *sizer; wxSizer *sizer;
void CellSkip(wxFlexGridSizer *&flex) {
flex->Add(new wxStaticText(this, wxID_ANY , wxEmptyString), 0, wxALL, 5);
}
OptionPage(wxTreebook *book, wxString name): wxPanel(book, -1) { OptionPage(wxTreebook *book, wxString name): wxPanel(book, -1) {
book->AddPage(this, name, true); book->AddPage(this, name, true);
sizer = new wxBoxSizer(wxVERTICAL); sizer = new wxBoxSizer(wxVERTICAL);
@ -197,6 +201,32 @@ public:
} }
} }
void OptionChoice(wxFlexGridSizer *&flex, const wxString &name, const wxArrayString &choices, const char *opt_name) {
agi::OptionValue *opt = OPT_GET(opt_name);
int type = opt->GetType();
wxString selection;
switch (type) {
case agi::OptionValue::Type_Int: {
selection = choices.Item(opt->GetInt());
break;
}
case agi::OptionValue::Type_String: {
selection.assign(opt->GetString());
break;
}
default:
throw PreferenceNotSupported("Unsupported type");
}
flex->Add(new wxStaticText(this, wxID_ANY, name), 1, wxALIGN_CENTRE_VERTICAL);
wxComboBox *cb = new wxComboBox(this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, choices, wxCB_READONLY | wxCB_DROPDOWN);
cb->SetValue(selection);
flex->Add(cb, 1, wxEXPAND, 0);
}
wxFlexGridSizer* PageSizer(wxString name) { wxFlexGridSizer* PageSizer(wxString name) {
wxSizer *tmp_sizer = new wxStaticBoxSizer(wxHORIZONTAL, this, name); wxSizer *tmp_sizer = new wxStaticBoxSizer(wxHORIZONTAL, this, name);
sizer->Add(tmp_sizer, 0,wxEXPAND, 5); sizer->Add(tmp_sizer, 0,wxEXPAND, 5);
@ -207,6 +237,9 @@ public:
return flex; return flex;
} }
}; };
@ -275,58 +308,58 @@ public:
}; };
void Preferences::Subtitles(wxTreebook *book) { class Subtitles: public OptionPage {
PAGE_CREATE(_("Subtitles")) public:
Subtitles(wxTreebook *book): OptionPage(book, _("Subtitles")) {
PAGE_SIZER(_("Options"), general) wxFlexGridSizer *general = PageSizer(_("Options"));
OptionAdd(general, _("Enable call tips"), "App/Call Tips");
OptionAdd(general, _("Enable syntax highlighting"), "Subtitle/Highlight/Syntax");
OptionAdd(general, _("Link commiting of times"), "Subtitle/Edit Box/Link Time Boxes Commit");
OptionAdd(general, _("Overwrite-Insertion in time boxes"), "Subtitle/Time Edit/Insert Mode");
OptionAdd(panel, general_flex, _("Enable call tips"), "App/Call Tips"); wxFlexGridSizer *grid = PageSizer(_("Grid"));
OptionAdd(panel, general_flex, _("Enable syntax highlighting"), "Subtitle/Highlight/Syntax"); OptionAdd(grid, _("Allow grid to take focus"), "Subtitle/Grid/Focus Allow");
OptionAdd(panel, general_flex, _("Link commiting of times"), "Subtitle/Edit Box/Link Time Boxes Commit"); OptionAdd(grid, _("Highlight visible subtitles"), "Subtitle/Grid/Highlight Subtitles in Frame");
OptionAdd(panel, general_flex, _("Overwrite-Insertion in time boxes"), "Subtitle/Time Edit/Insert Mode");
PAGE_SIZER(_("Grid"), grid) SetSizerAndFit(sizer);
OptionAdd(panel, grid_flex, _("Allow grid to take focus"), "Subtitle/Grid/Focus Allow"); }
OptionAdd(panel, grid_flex, _("Highlight visible subtitles"), "Subtitle/Grid/Highlight Subtitles in Frame"); };
PAGE_END()
}
void Preferences::Audio(wxTreebook *book) { class Audio: public OptionPage {
PAGE_CREATE(_("Audio")) public:
Audio(wxTreebook *book): OptionPage(book, _("Audio")) {
PAGE_SIZER(_("Options"), general) wxFlexGridSizer *general = PageSizer(_("Options"));
OptionAdd(panel, general_flex, _("Grab times from line upon selection"), "Audio/Grab Times on Select"); OptionAdd(general, _("Grab times from line upon selection"), "Audio/Grab Times on Select");
OptionAdd(panel, general_flex, _("Default mouse wheel to zoom"), "Audio/Wheel Default to Zoom"); OptionAdd(general, _("Default mouse wheel to zoom"), "Audio/Wheel Default to Zoom");
OptionAdd(panel, general_flex, _("Lock scroll on cursor"), "Audio/Lock Scroll on Cursor"); OptionAdd(general, _("Lock scroll on cursor"), "Audio/Lock Scroll on Cursor");
OptionAdd(panel, general_flex, _("Snap to keyframes"), "Audio/Display/Snap/Keyframes"); OptionAdd(general, _("Snap to keyframes"), "Audio/Display/Snap/Keyframes");
OptionAdd(panel, general_flex, _("Snap to adjacent lines"), "Audio/Display/Snap/Other Lines"); OptionAdd(general, _("Snap to adjacent lines"), "Audio/Display/Snap/Other Lines");
OptionAdd(panel, general_flex, _("Auto-focus on mouse over"), "Audio/Auto/Focus"); OptionAdd(general, _("Auto-focus on mouse over"), "Audio/Auto/Focus");
OptionAdd(panel, general_flex, _("Play audio when stepping in video"), "Audio/Plays When Stepping Video"); OptionAdd(general, _("Play audio when stepping in video"), "Audio/Plays When Stepping Video");
CellSkip(general);
CELL_SKIP(general_flex) OptionAdd(general, _("Default timing length"), "Timing/Default Duration", 0, 36000);
OptionAdd(general, _("Default lead-in length"), "Audio/Lead/IN", 0, 36000);
OptionAdd(panel, general_flex, _("Default timing length"), "Timing/Default Duration", 0, 36000); OptionAdd(general, _("Default lead-out length"), "Audio/Lead/OUT", 0, 36000);
OptionAdd(panel, general_flex, _("Default lead-in length"), "Audio/Lead/IN", 0, 36000);
OptionAdd(panel, general_flex, _("Default lead-out length"), "Audio/Lead/OUT", 0, 36000);
const wxString dtl_arr[3] = { _("Don't show"), _("Show previous"), _("Show all") }; const wxString dtl_arr[3] = { _("Don't show"), _("Show previous"), _("Show all") };
wxArrayString choice_dtl(3, dtl_arr); wxArrayString choice_dtl(3, dtl_arr);
OptionChoice(panel, general_flex, _("Show inactive lines"), choice_dtl, "Audio/Inactive Lines Display Mode"); OptionChoice(general, _("Show inactive lines"), choice_dtl, "Audio/Inactive Lines Display Mode");
OptionAdd(general, _("Start-marker drag sensitivity"), "Audio/Start Drag Sensitivity", 1, 15);
OptionAdd(panel, general_flex, _("Start-marker drag sensitivity"), "Audio/Start Drag Sensitivity", 1, 15); wxFlexGridSizer *display = PageSizer(_("Display Visual Options"));
OptionAdd(display, _("Secondary lines"), "Audio/Display/Draw/Secondary Lines");
OptionAdd(display, _("Selection background"), "Audio/Display/Draw/Selection Background");
OptionAdd(display, _("Timeline"), "Audio/Display/Draw/Timeline");
OptionAdd(display, _("Cursor time"), "Audio/Display/Draw/Cursor Time");
OptionAdd(display, _("Keyframes"), "Audio/Display/Draw/Keyframes");
OptionAdd(display, _("Video position"), "Audio/Display/Draw/Video Position");
PAGE_SIZER(_("Display Visual Options"), display) SetSizerAndFit(sizer);
OptionAdd(panel, display_flex, _("Secondary lines"), "Audio/Display/Draw/Secondary Lines"); }
OptionAdd(panel, display_flex, _("Selection background"), "Audio/Display/Draw/Selection Background"); };
OptionAdd(panel, display_flex, _("Timeline"), "Audio/Display/Draw/Timeline");
OptionAdd(panel, display_flex, _("Cursor time"), "Audio/Display/Draw/Cursor Time");
OptionAdd(panel, display_flex, _("Keyframes"), "Audio/Display/Draw/Keyframes");
OptionAdd(panel, display_flex, _("Video position"), "Audio/Display/Draw/Video Position");
PAGE_END()
}
void Preferences::Video(wxTreebook *book) { void Preferences::Video(wxTreebook *book) {
@ -575,9 +608,9 @@ Preferences::Preferences(wxWindow *parent): wxDialog(parent, -1, _("Preferences"
book = new wxTreebook(this, -1, wxDefaultPosition, wxDefaultSize); book = new wxTreebook(this, -1, wxDefaultPosition, wxDefaultSize);
general = new General(book); general = new General(book);
subtitles = new Subtitles(book);
audio = new Audio(book);
Subtitles(book);
Audio(book);
Video(book); Video(book);
Interface(book); Interface(book);
Interface_Colours(book); Interface_Colours(book);

View file

@ -29,6 +29,20 @@
#include "browse_button.h" #include "browse_button.h"
class General; class General;
class Subtitles;
class Audio;
//class Video;
//class Interface;
//class Interface_Colours;
//class Interface_Hotkeys;
//class Paths;
//class File_Associations;
//class Backup;
//class Automation;
//class Advanced;
//class Advanced_Interface;
//class Advanced_Audio;
//class Advanced_Video;
class Preferences: public wxDialog { class Preferences: public wxDialog {
wxTreebook *book; wxTreebook *book;
@ -38,15 +52,26 @@ class Preferences: public wxDialog {
void OnApply(wxCommandEvent &event); void OnApply(wxCommandEvent &event);
General *general; General *general;
Subtitles *subtitles;
Audio *audio;
// Video *video;
// Interface *interface;
// Interface_Colours *interface_colours;
// Interface_Hotkeys *interface_hotkeys;
// Paths *paths;
// File_Associations *file_associations;
// Backup *backup;
// Automation *automation;
// Advanced *advanced;
// Advanced_Interface *advanced_interface;
// Advanced_Audio *advanced_audio;
// Advanced_Video *advanced_video;
// void OptionAdd(wxPanel *parent, wxFlexGridSizer *flex, const wxString &name, const char *opt_name); // void OptionAdd(wxPanel *parent, wxFlexGridSizer *flex, const wxString &name, const char *opt_name);
void OptionAdd(wxPanel *parent, wxFlexGridSizer *flex, const wxString &name, const char *opt_name, double min=0, double max=100, double inc=1); void OptionAdd(wxPanel *parent, wxFlexGridSizer *flex, const wxString &name, const char *opt_name, double min=0, double max=100, double inc=1);
void OptionChoice(wxPanel *parent, wxFlexGridSizer *flex, const wxString &name, const wxArrayString &choices, const char *opt_name); void OptionChoice(wxPanel *parent, wxFlexGridSizer *flex, const wxString &name, const wxArrayString &choices, const char *opt_name);
void OptionBrowse(wxPanel *parent, wxFlexGridSizer *flex, const wxString &name, BrowseType browse_type, const char *opt_name); void OptionBrowse(wxPanel *parent, wxFlexGridSizer *flex, const wxString &name, BrowseType browse_type, const char *opt_name);
void General_old(wxTreebook *book);
void Subtitles(wxTreebook *book);
void Audio(wxTreebook *book);
void Video(wxTreebook *book); void Video(wxTreebook *book);
void Interface(wxTreebook *book); void Interface(wxTreebook *book);
void Interface_Colours(wxTreebook *book); void Interface_Colours(wxTreebook *book);