Added a commit button to the subtitles edit box for the shortcut-impaired.

Originally committed to SVN as r1319.
This commit is contained in:
Rodrigo Braz Monteiro 2007-06-30 20:00:07 +00:00
parent 3e411f1eed
commit 6f283a819e
4 changed files with 55 additions and 33 deletions

View file

@ -118,6 +118,7 @@ Please visit http://aegisub.net to download latest version
o Fixed glitches related to the Duration time edit box. (AMZ) o Fixed glitches related to the Duration time edit box. (AMZ)
o Tweaked the behavior of the margin boxes, now they no longer show padding zeros. (AMZ) o Tweaked the behavior of the margin boxes, now they no longer show padding zeros. (AMZ)
o Actor and Effect fields now show a "ghosted" caption saying their name when they are not focused on and blank. (AMZ) o Actor and Effect fields now show a "ghosted" caption saying their name when they are not focused on and blank. (AMZ)
o Added a "Commit" button that duplicates the Enter/Ctrl+Enter functionality, since those shortcuts were not obvious to everyone. (AMZ)
- Changes to Fonts Collector: - Changes to Fonts Collector:
o Changed the font searching engine to something slower, but far more reliable. (jfs/AMZ) o Changed the font searching engine to something slower, but far more reliable. (jfs/AMZ)
o Added option to just verify if you have the fonts. (AMZ) o Added option to just verify if you have the fonts. (AMZ)

View file

@ -75,8 +75,8 @@
// FrameMain constructor // FrameMain constructor
FrameMain::FrameMain (wxArrayString args) FrameMain::FrameMain (wxArrayString args)
// FIXME: 800x600 default window size is tiny on high-res monitors, but maximised is not always desirable either // FIXME: 860x600 default window size is tiny on high-res monitors, but maximised is not always desirable either
: wxFrame ((wxFrame*)NULL,-1,_T(""),wxDefaultPosition,wxSize(800,600),wxDEFAULT_FRAME_STYLE | wxCLIP_CHILDREN) : wxFrame ((wxFrame*)NULL,-1,_T(""),wxDefaultPosition,wxSize(860,600),wxDEFAULT_FRAME_STYLE | wxCLIP_CHILDREN)
{ {
#ifdef __WXGTK__ #ifdef __WXGTK__
/* XXX HACK XXX /* XXX HACK XXX

View file

@ -132,6 +132,8 @@ SubsEditBox::SubsEditBox (wxWindow *parent,SubtitlesGrid *gridp) : wxPanel(paren
Color3->SetToolTip(_("Outline color")); Color3->SetToolTip(_("Outline color"));
Color4 = new wxBitmapButton(this,BUTTON_COLOR4,wxBITMAP(button_color_four),wxDefaultPosition,wxSize(30,20)); Color4 = new wxBitmapButton(this,BUTTON_COLOR4,wxBITMAP(button_color_four),wxDefaultPosition,wxSize(30,20));
Color4->SetToolTip(_("Shadow color")); Color4->SetToolTip(_("Shadow color"));
CommitButton = new wxButton(this,BUTTON_COMMIT,_("Commit"),wxDefaultPosition,wxSize(55,20));
CommitButton->SetToolTip(_T("Commits the text (Enter). Hold Ctrl to stay in line (Ctrl+Enter)."));
ByTime = new wxRadioButton(this,RADIO_TIME_BY_TIME,_("Time"),wxDefaultPosition,wxDefaultSize,wxRB_GROUP); ByTime = new wxRadioButton(this,RADIO_TIME_BY_TIME,_("Time"),wxDefaultPosition,wxDefaultSize,wxRB_GROUP);
ByTime->SetToolTip(_("Time by h:mm:ss.cs")); ByTime->SetToolTip(_("Time by h:mm:ss.cs"));
ByFrame = new wxRadioButton(this,RADIO_TIME_BY_FRAME,_("Frame")); ByFrame = new wxRadioButton(this,RADIO_TIME_BY_FRAME,_("Frame"));
@ -168,7 +170,8 @@ SubsEditBox::SubsEditBox (wxWindow *parent,SubtitlesGrid *gridp) : wxPanel(paren
MiddleBotSizer->Add(Color1); MiddleBotSizer->Add(Color1);
MiddleBotSizer->Add(Color2); MiddleBotSizer->Add(Color2);
MiddleBotSizer->Add(Color3); MiddleBotSizer->Add(Color3);
MiddleBotSizer->Add(Color4,0,wxRIGHT,10); MiddleBotSizer->Add(Color4,0,wxRIGHT,5);
MiddleBotSizer->Add(CommitButton,0,wxRIGHT,10);
MiddleBotSizer->Add(ByTime,0,wxRIGHT | wxALIGN_CENTER,5); MiddleBotSizer->Add(ByTime,0,wxRIGHT | wxALIGN_CENTER,5);
MiddleBotSizer->Add(ByFrame,0,wxRIGHT | wxALIGN_CENTER,5); MiddleBotSizer->Add(ByFrame,0,wxRIGHT | wxALIGN_CENTER,5);
@ -379,6 +382,7 @@ BEGIN_EVENT_TABLE(SubsEditBox, wxPanel)
EVT_BUTTON(BUTTON_ITALICS,SubsEditBox::OnButtonItalics) EVT_BUTTON(BUTTON_ITALICS,SubsEditBox::OnButtonItalics)
EVT_BUTTON(BUTTON_UNDERLINE,SubsEditBox::OnButtonUnderline) EVT_BUTTON(BUTTON_UNDERLINE,SubsEditBox::OnButtonUnderline)
EVT_BUTTON(BUTTON_STRIKEOUT,SubsEditBox::OnButtonStrikeout) EVT_BUTTON(BUTTON_STRIKEOUT,SubsEditBox::OnButtonStrikeout)
EVT_BUTTON(BUTTON_COMMIT,SubsEditBox::OnButtonCommit)
EVT_SIZE(SubsEditBox::OnSize) EVT_SIZE(SubsEditBox::OnSize)
END_EVENT_TABLE() END_EVENT_TABLE()
@ -819,12 +823,24 @@ void SubsEditBox::DoKeyPress(wxKeyEvent &event) {
if (key == WXK_RETURN || key == WXK_NUMPAD_ENTER) { if (key == WXK_RETURN || key == WXK_NUMPAD_ENTER) {
if (enabled) { if (enabled) {
Commit(event.m_controlDown);
return;
}
}
event.Skip();
}
//////////
// Commit
void SubsEditBox::Commit(bool stay) {
// Update line // Update line
CommitText(); CommitText();
// Next line if control is not held down // Next line if control is not held down
bool updated = false; bool updated = false;
if (!event.m_controlDown) { if (!stay) {
AssDialogue *cur = grid->GetDialogue(linen); AssDialogue *cur = grid->GetDialogue(linen);
int nrows = grid->GetRows(); int nrows = grid->GetRows();
int next = linen+1; int next = linen+1;
@ -848,11 +864,6 @@ void SubsEditBox::DoKeyPress(wxKeyEvent &event) {
grid->ass->FlagAsModified(_("editing")); grid->ass->FlagAsModified(_("editing"));
grid->CommitChanges(); grid->CommitChanges();
} }
return;
}
}
event.Skip();
} }
@ -1276,3 +1287,9 @@ void SubsEditBox::OnButtonStrikeout(wxCommandEvent &event) {
} }
//////////
// Commit
void SubsEditBox::OnButtonCommit(wxCommandEvent &event) {
Commit(wxGetMouseState().ControlDown());
}

View file

@ -95,6 +95,7 @@ private:
wxButton *Color2; wxButton *Color2;
wxButton *Color3; wxButton *Color3;
wxButton *Color4; wxButton *Color4;
wxButton *CommitButton;
wxSizer *TopSizer; wxSizer *TopSizer;
wxSizer *MiddleBotSizer; wxSizer *MiddleBotSizer;
@ -122,6 +123,7 @@ private:
void OnButtonItalics(wxCommandEvent &event); void OnButtonItalics(wxCommandEvent &event);
void OnButtonUnderline(wxCommandEvent &event); void OnButtonUnderline(wxCommandEvent &event);
void OnButtonStrikeout(wxCommandEvent &event); void OnButtonStrikeout(wxCommandEvent &event);
void OnButtonCommit(wxCommandEvent &event);
void OnSyntaxBox(wxCommandEvent &event); void OnSyntaxBox(wxCommandEvent &event);
void OnFrameRadio(wxCommandEvent &event); void OnFrameRadio(wxCommandEvent &event);
@ -157,6 +159,7 @@ public:
void SetToLine(int n,bool weak=false); void SetToLine(int n,bool weak=false);
void UpdateFrameTiming(); void UpdateFrameTiming();
void DoKeyPress(wxKeyEvent &event); void DoKeyPress(wxKeyEvent &event);
void Commit(bool stay);
DECLARE_EVENT_TABLE() DECLARE_EVENT_TABLE()
}; };
@ -202,5 +205,6 @@ enum {
BUTTON_COLOR1, BUTTON_COLOR1,
BUTTON_COLOR2, BUTTON_COLOR2,
BUTTON_COLOR3, BUTTON_COLOR3,
BUTTON_COLOR4 BUTTON_COLOR4,
BUTTON_COMMIT
}; };