Fourth page of options, grid settings, is complete.

Originally committed to SVN as r704.
This commit is contained in:
Rodrigo Braz Monteiro 2007-01-03 23:29:03 +00:00
parent 0fec62dfd6
commit a632611cad
5 changed files with 128 additions and 17 deletions

View file

@ -65,6 +65,25 @@ BaseGrid::BaseGrid(wxWindow* parent, wxWindowID id, const wxPoint& pos, const wx
bmp = NULL; bmp = NULL;
holding = false; holding = false;
// Set scrollbar
scrollBar = new wxScrollBar(this,GRID_SCROLLBAR,wxDefaultPosition,wxDefaultSize,wxSB_VERTICAL);
scrollBar->SetScrollbar(0,10,100,10);
// Set style
UpdateStyle();
}
//////////////
// Destructor
BaseGrid::~BaseGrid() {
delete bmp;
}
////////////////
// Update style
void BaseGrid::UpdateStyle() {
// Set font // Set font
wxString fontname = Options.AsText(_T("Grid Font Face")); wxString fontname = Options.AsText(_T("Grid Font Face"));
if (fontname.IsEmpty()) fontname = _T("Tahoma"); if (fontname.IsEmpty()) fontname = _T("Tahoma");
@ -81,20 +100,13 @@ BaseGrid::BaseGrid(wxWindow* parent, wxWindowID id, const wxPoint& pos, const wx
lineHeight = fh+4; lineHeight = fh+4;
} }
// Set scrollbar
scrollBar = new wxScrollBar(this,GRID_SCROLLBAR,wxDefaultPosition,wxDefaultSize,wxSB_VERTICAL);
scrollBar->SetScrollbar(0,10,100,10);
// Set column widths // Set column widths
for (int i=0;i<10;i++) showCol[i] = Options.AsBool(_T("Grid show column ") + IntegerToString(i)); for (int i=0;i<10;i++) showCol[i] = Options.AsBool(_T("Grid show column ") + IntegerToString(i));
SetColumnWidths(); SetColumnWidths();
}
// Update
////////////// AdjustScrollbar();
// Destructor Refresh();
BaseGrid::~BaseGrid() {
delete bmp;
} }

View file

@ -110,6 +110,7 @@ public:
void Clear(); void Clear();
void UpdateMaps(); void UpdateMaps();
void UpdateStyle();
int GetRows() const; int GetRows() const;
wxArrayInt GetRangeArray(int n1,int n2); wxArrayInt GetRangeArray(int n1,int n2);

View file

@ -50,6 +50,7 @@
#include "colour_button.h" #include "colour_button.h"
#include "subs_edit_box.h" #include "subs_edit_box.h"
#include "subs_edit_ctrl.h" #include "subs_edit_ctrl.h"
#include "subs_grid.h"
/////////////// ///////////////
@ -197,8 +198,10 @@ DialogOptions::DialogOptions(wxWindow *parent)
// Second static box // Second static box
wxControl *control; wxControl *control;
wxString labels2[9] = { _("Normal"), _("Brackets"), _("Slashes and Parentheses"), _("Tags"), _("Parameters") , _("Error"), _("Error Background"), _("Line Break"), _("Modified Background") }; wxString labels2[9] = { _("Normal"), _("Brackets"), _("Slashes and Parentheses"), _("Tags"), _("Parameters") ,
wxString options2[11] = { _T("Normal"), _T("Brackets"), _T("Slashes"), _T("Tags"), _T("Parameters") , _T("Error"), _T("Error Background"), _T("Line Break"), _T("Edit box need enter background"), _T("Edit Font Face"), _T("Edit Font Size") }; _("Error"), _("Error Background"), _("Line Break"), _("Modified Background") };
wxString options2[11] = { _T("Normal"), _T("Brackets"), _T("Slashes"), _T("Tags"), _T("Parameters") ,
_T("Error"), _T("Error Background"), _T("Line Break"), _T("Edit box need enter background"), _T("Edit Font Face"), _T("Edit Font Size") };
for (int i=0;i<9;i++) { for (int i=0;i<9;i++) {
wxString caption = labels2[i]+_T(": "); wxString caption = labels2[i]+_T(": ");
wxString option = options2[i]; wxString option = options2[i];
@ -212,6 +215,8 @@ DialogOptions::DialogOptions(wxWindow *parent)
editSizer4->Add(control,1,wxALIGN_CENTER,0); editSizer4->Add(control,1,wxALIGN_CENTER,0);
} }
editSizer4->AddGrowableCol(1,1); editSizer4->AddGrowableCol(1,1);
// Third sizer
editSizer5->Add(new wxStaticText(editPage,-1,_("Font: ")),0,wxALIGN_CENTER_VERTICAL | wxRIGHT,10); editSizer5->Add(new wxStaticText(editPage,-1,_("Font: ")),0,wxALIGN_CENTER_VERTICAL | wxRIGHT,10);
control = new wxTextCtrl(editPage,-1); control = new wxTextCtrl(editPage,-1);
Bind(control,options2[9]); Bind(control,options2[9]);
@ -231,6 +236,83 @@ DialogOptions::DialogOptions(wxWindow *parent)
editPage->SetSizer(editMainSizer); editPage->SetSizer(editMainSizer);
} }
// Grid page
{
// Sizers
wxSizer *gridMainSizer = new wxBoxSizer(wxVERTICAL);
wxSizer *gridSizer1 = new wxStaticBoxSizer(wxVERTICAL,gridPage,_("Options"));
wxSizer *gridSizer2 = new wxStaticBoxSizer(wxVERTICAL,gridPage,_("Style"));
wxFlexGridSizer *gridSizer3 = new wxFlexGridSizer(11,2,2,2);
wxSizer *gridSizer4 = new wxBoxSizer(wxHORIZONTAL);
wxSizer *gridSizer5 = new wxBoxSizer(wxHORIZONTAL);
// First sizer
wxString labels1[2] = { _("Allow grid to take focus"), _("Highlight subtitles that are currently visible in video") };
wxString options1[2] = { _T("Grid allow focus"), _T("Highlight subs in frame") };
for (int i=0;i<2;i++) {
wxCheckBox *control = new wxCheckBox(gridPage,-1,labels1[i]);
Bind(control,options1[i]);
gridSizer1->Add(control,1,wxEXPAND | wxALL,5);
}
// Second sizer
wxControl *control;
wxString labels2[12] = { _("Standard Foreground"), _("Standard Background"), _("Selection Foreground"),
_("Selection Background"), _("Comment Background"), _("Selected Comment Background"),
_("Collision Foreground"), _("Line In Frame Background"), _("Header"),
_("Left Column"), _("Active Line Border"), _("Lines") };
wxString options2[12] = { _T("standard foreground"), _T("background"), _T("selection foreground"),
_("selection background"), _T("comment background"), _T("selected comment background"),
_T("collision foreground") , _T("inframe background"), _T("header"),
_T("left column"), _T("active border"), _T("lines") };
for (int i=0;i<12;i++) {
wxString caption = labels2[i] + _T(": ");
wxString option = _T("Grid ") + options2[i];
control = new ColourButton(gridPage,-1,wxSize(40,10));
Bind(control,option);
gridSizer3->Add(new wxStaticText(gridPage,-1,caption),0,wxALIGN_CENTER_VERTICAL|wxRIGHT,5);
gridSizer3->Add(control,1,wxALIGN_CENTER,0);
}
gridSizer3->AddGrowableCol(0,1);
// Third sizer
gridSizer4->Add(new wxStaticText(gridPage,-1,_("Font: ")),0,wxALIGN_CENTER_VERTICAL | wxRIGHT,10);
control = new wxTextCtrl(gridPage,-1);
Bind(control,_T("Grid font face"));
gridSizer4->Add(control,1,wxEXPAND | wxRIGHT,5);
control = new wxTextCtrl(gridPage,-1,_T(""),wxDefaultPosition,wxSize(50,-1),0,NumValidator(NULL,false));;
Bind(control,_T("Grid font size"));
gridSizer4->Add(control,0,wxEXPAND | wxRIGHT,0);
// Fourth sizer
gridSizer5->Add(new wxStaticText(gridPage,-1,_("Replace override tags with: ")),0,wxALIGN_CENTER_VERTICAL | wxRIGHT,10);
control = new wxTextCtrl(gridPage,-1);
Bind(control,_T("Grid hide overrides char"));
gridSizer5->Add(control,1,wxEXPAND | wxRIGHT,5);
// Sizers
gridSizer2->Add(gridSizer3,1,wxEXPAND | wxALL,5);
gridSizer2->Add(gridSizer4,0,wxEXPAND | wxALL,5);
gridSizer2->Add(gridSizer5,0,wxEXPAND | wxALL,5);
gridMainSizer->Add(gridSizer1,0,wxEXPAND | wxALL,0);
gridMainSizer->Add(gridSizer2,0,wxEXPAND | wxALL,0);
gridMainSizer->AddStretchSpacer(1);
gridMainSizer->Fit(gridPage);
gridPage->SetSizer(gridMainSizer);
}
// Video page
// TODO
// Audio page
// TODO
// Audio display page
// TODO
// Automation page
// TODO
// List book // List book
book->AddPage(generalPage,_("General"),true); book->AddPage(generalPage,_("General"),true);
book->AddSubPage(filePage,_("File Save/Load"),true); book->AddSubPage(filePage,_("File Save/Load"),true);
@ -337,6 +419,7 @@ void DialogOptions::WriteToOptions(bool justApply) {
// Flags // Flags
bool mustRestart = false; bool mustRestart = false;
bool editBox = false; bool editBox = false;
bool grid = false;
// For each bound item // For each bound item
for (unsigned int i=0;i<binds.size();i++) { for (unsigned int i=0;i<binds.size();i++) {
@ -393,6 +476,7 @@ void DialogOptions::WriteToOptions(bool justApply) {
ModType type = Options.GetModType(binds[i].option); ModType type = Options.GetModType(binds[i].option);
if (type == MOD_RESTART) mustRestart = true; if (type == MOD_RESTART) mustRestart = true;
if (type == MOD_EDIT_BOX) editBox = true; if (type == MOD_EDIT_BOX) editBox = true;
if (type == MOD_GRID) grid = true;
} }
} }
@ -413,11 +497,18 @@ void DialogOptions::WriteToOptions(bool justApply) {
// Other modifications // Other modifications
if (!mustRestart || justApply) { if (!mustRestart || justApply) {
// Edit box
if (editBox) { if (editBox) {
FrameMain *frame = (FrameMain*) GetParent(); FrameMain *frame = (FrameMain*) GetParent();
frame->EditBox->TextEdit->SetStyles(); frame->EditBox->TextEdit->SetStyles();
frame->EditBox->TextEdit->UpdateStyle(); frame->EditBox->TextEdit->UpdateStyle();
} }
// Grid
if (grid) {
FrameMain *frame = (FrameMain*) GetParent();
frame->SubsBox->UpdateStyle();
}
} }
} }

View file

@ -176,6 +176,11 @@ void OptionsManager::LoadDefaults() {
wxColour grid = wxColour(128,128,128); wxColour grid = wxColour(128,128,128);
wxColour collision = wxColour(255,0,0); wxColour collision = wxColour(255,0,0);
// Grid
SetModificationType(MOD_GRID);
SetBool(_T("Grid allow focus"),true);
SetBool(_T("Highlight subs in frame"),true);
// Grid cosmetic // Grid cosmetic
SetColour(_T("Grid standard foreground"),textCol); SetColour(_T("Grid standard foreground"),textCol);
SetColour(_T("Grid selection background"),selection); SetColour(_T("Grid selection background"),selection);
@ -189,16 +194,15 @@ void OptionsManager::LoadDefaults() {
SetColour(_T("Grid left column"),labels); SetColour(_T("Grid left column"),labels);
SetColour(_T("Grid active border"),active); SetColour(_T("Grid active border"),active);
SetColour(_T("Grid lines"),grid); SetColour(_T("Grid lines"),grid);
wchar_t temp = 0x2600;
SetText(_T("Grid hide overrides char"),temp);
SetBool(_T("Grid allow focus"),true);
SetBool(_T("Highlight subs in frame"),true);
#if defined(__WINDOWS__) #if defined(__WINDOWS__)
SetInt(_T("Grid font size"),8); SetInt(_T("Grid font size"),8);
#else #else
SetInt(_T("Grid font size"),10); SetInt(_T("Grid font size"),10);
#endif #endif
SetText(_T("Grid Font Face"),_T("")); SetText(_T("Grid Font Face"),_T(""));
wchar_t temp = 0x2600;
SetText(_T("Grid hide overrides char"),temp);
SetModificationType(MOD_AUTOMATIC);
// Audio Cosmetic // Audio Cosmetic
SetInt(_T("Audio Spectrum Cutoff"),32); SetInt(_T("Audio Spectrum Cutoff"),32);

View file

@ -50,7 +50,10 @@ enum ModType {
MOD_OFF = -1, MOD_OFF = -1,
MOD_AUTOMATIC, MOD_AUTOMATIC,
MOD_RESTART, MOD_RESTART,
MOD_EDIT_BOX MOD_EDIT_BOX,
MOD_GRID,
MOD_VIDEO,
MOD_AUDIO
}; };