mirror of https://github.com/odrling/Aegisub
Destination of screenshots can now be set in the options dialog, and some tweaks to options dialog.
Originally committed to SVN as r726.
This commit is contained in:
parent
cd4b6c0f93
commit
8ec4322174
|
@ -76,6 +76,7 @@ Please visit http://aegisub.net to download latest version
|
|||
o Holding down ctrl lets you retime the original line while in Karaoke mode.
|
||||
- Fixed loading of SRT and TXT files, which were causing an empty line to appear at the start of the file. (AMZ)
|
||||
- Added options to toggle the display of the audio timeline and of the time over the mouse cursor. (AMZ)
|
||||
- Destination of screenshots can now be set in the options dialog. (AMZ)
|
||||
|
||||
|
||||
= 1.10 beta - 2006.08.07 ===========================
|
||||
|
|
|
@ -216,7 +216,7 @@ DialogOptions::DialogOptions(wxWindow *parent)
|
|||
control = new ColourButton(editPage,-1,wxSize(40,10));
|
||||
Bind(control,option);
|
||||
editSizer4->Add(new wxStaticText(editPage,-1,caption),0,wxALIGN_CENTER_VERTICAL|wxRIGHT,5);
|
||||
editSizer4->Add(control,1,wxALIGN_CENTER,0);
|
||||
editSizer4->Add(control,1,wxALIGN_RIGHT,0);
|
||||
}
|
||||
editSizer4->AddGrowableCol(1,1);
|
||||
|
||||
|
@ -311,7 +311,7 @@ DialogOptions::DialogOptions(wxWindow *parent)
|
|||
wxSizer *videoMainSizer = new wxBoxSizer(wxVERTICAL);
|
||||
wxSizer *videoSizer1 = new wxStaticBoxSizer(wxVERTICAL,videoPage,_("Options"));
|
||||
wxSizer *videoSizer2 = new wxStaticBoxSizer(wxVERTICAL,videoPage,_("Advanced - EXPERT USERS ONLY"));
|
||||
wxFlexGridSizer *videoSizer3 = new wxFlexGridSizer(4,2,5,5);
|
||||
wxFlexGridSizer *videoSizer3 = new wxFlexGridSizer(5,2,5,5);
|
||||
wxFlexGridSizer *videoSizer4 = new wxFlexGridSizer(4,2,5,5);
|
||||
wxControl *control;
|
||||
|
||||
|
@ -336,6 +336,12 @@ DialogOptions::DialogOptions(wxWindow *parent)
|
|||
control = new wxTextCtrl(videoPage,-1,_T(""),wxDefaultPosition,wxDefaultSize,0,NumValidator());
|
||||
Bind(control,_T("Video fast jump step"));
|
||||
videoSizer3->Add(control,1,wxEXPAND);
|
||||
videoSizer3->Add(new wxStaticText(videoPage,-1,_("Screenshot save path: ")),0,wxALIGN_CENTER_VERTICAL | wxRIGHT,10);
|
||||
wxString choices3[3] = { _T("?video"), _T("?script"), _T(".") };
|
||||
//control = new wxTextCtrl(videoPage,-1);
|
||||
control = new wxComboBox(videoPage,-1,_T(""),wxDefaultPosition,wxDefaultSize,3,choices3,wxCB_DROPDOWN);
|
||||
Bind(control,_T("Video screenshot path"));
|
||||
videoSizer3->Add(control,1,wxEXPAND);
|
||||
control = new wxCheckBox(videoPage,-1,_("Show keyframes in slider"));
|
||||
Bind(control,_T("Show keyframes on video slider"));
|
||||
videoSizer3->Add(control,0,wxEXPAND);
|
||||
|
@ -343,11 +349,22 @@ DialogOptions::DialogOptions(wxWindow *parent)
|
|||
|
||||
// Second sizer
|
||||
videoSizer4->Add(new wxStaticText(videoPage,-1,_("Video Provider: ")),0,wxALIGN_CENTER_VERTICAL | wxRIGHT,10);
|
||||
control = new wxTextCtrl(videoPage,-1);
|
||||
Bind(control,_T("Video provider"));
|
||||
wxArrayString choices4;
|
||||
#ifdef __WINDOWS__
|
||||
choices4.Add(_T("Avisynth"));
|
||||
#endif
|
||||
#if USE_LAVC == 1
|
||||
choices4.Add(_T("ffmpeg"));
|
||||
#endif
|
||||
#if USE_DIRECTSHOW == 1
|
||||
choices4.Add(_T("dshow"));
|
||||
#endif
|
||||
control = new wxComboBox(videoPage,-1,_T(""),wxDefaultPosition,wxDefaultSize,choices4,wxCB_DROPDOWN | wxCB_READONLY);
|
||||
Bind(control,_T("Video provider"),1);
|
||||
videoSizer4->Add(control,1,wxEXPAND);
|
||||
videoSizer4->Add(new wxStaticText(videoPage,-1,_("Avisynth Video Resizer: ")),0,wxALIGN_CENTER_VERTICAL | wxRIGHT,10);
|
||||
control = new wxTextCtrl(videoPage,-1);
|
||||
wxString choices5[3] = { _T("BilinearResize"), _T("BicubicResize"), _T("LanczosResize") };
|
||||
control = new wxComboBox(videoPage,-1,_T(""),wxDefaultPosition,wxDefaultSize,3,choices5,wxCB_DROPDOWN);
|
||||
Bind(control,_T("Video resizer"));
|
||||
videoSizer4->Add(control,1,wxEXPAND);
|
||||
videoSizer4->Add(new wxStaticText(videoPage,-1,_("Avisynth Memory Limit: ")),0,wxALIGN_CENTER_VERTICAL | wxRIGHT,10);
|
||||
|
@ -425,7 +442,8 @@ DialogOptions::DialogOptions(wxWindow *parent)
|
|||
Bind(control,_T("Audio Cache"));
|
||||
audioSizer5->Add(new wxStaticText(audioPage,-1,_("Cache type: ")),0,wxRIGHT | wxALIGN_CENTER_VERTICAL,5);
|
||||
audioSizer5->Add(control,1,wxEXPAND,0);
|
||||
control = new wxTextCtrl(audioPage,-1);
|
||||
wxString choices3[3] = { _T("ConvertToMono"), _T("GetLeftChannel"), _T("GetRightChannel") };
|
||||
control = new wxComboBox(audioPage,-1,_T(""),wxDefaultPosition,wxDefaultSize,3,choices3,wxCB_DROPDOWN);
|
||||
Bind(control,_T("Audio Downmixer"));
|
||||
audioSizer5->Add(new wxStaticText(audioPage,-1,_("Avisynth down-mixer: ")),0,wxRIGHT | wxALIGN_CENTER_VERTICAL,5);
|
||||
audioSizer5->Add(control,1,wxEXPAND,0);
|
||||
|
@ -583,10 +601,11 @@ DialogOptions::~DialogOptions() {
|
|||
|
||||
//////////////////////////
|
||||
// Bind control to option
|
||||
void DialogOptions::Bind(wxControl *ctrl, wxString option) {
|
||||
void DialogOptions::Bind(wxControl *ctrl, wxString option,int param) {
|
||||
OptionsBind bind;
|
||||
bind.ctrl = ctrl;
|
||||
bind.option = option;
|
||||
bind.param = param;
|
||||
binds.push_back(bind);
|
||||
}
|
||||
|
||||
|
@ -690,9 +709,22 @@ void DialogOptions::WriteToOptions(bool justApply) {
|
|||
// Combo box
|
||||
if (binds[i].ctrl->IsKindOf(CLASSINFO(wxComboBox))) {
|
||||
wxComboBox *combo = (wxComboBox*) binds[i].ctrl;
|
||||
if (combo->GetSelection() != Options.AsInt(binds[i].option)) {
|
||||
Options.SetInt(binds[i].option,combo->GetSelection());
|
||||
modified = true;
|
||||
int style = combo->GetWindowStyleFlag();
|
||||
|
||||
// Read-only, use as value
|
||||
if (style & wxCB_READONLY && binds[i].param == 0) {
|
||||
if (combo->GetSelection() != Options.AsInt(binds[i].option)) {
|
||||
Options.SetInt(binds[i].option,combo->GetSelection());
|
||||
modified = true;
|
||||
}
|
||||
}
|
||||
|
||||
// Editable, use as text
|
||||
else {
|
||||
if (!combo->GetValue().IsEmpty() && combo->GetValue() != Options.AsText(binds[i].option)) {
|
||||
Options.SetText(binds[i].option,combo->GetValue());
|
||||
modified = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -787,7 +819,19 @@ void DialogOptions::ReadFromOptions() {
|
|||
// Combo box
|
||||
if (binds[i].ctrl->IsKindOf(CLASSINFO(wxComboBox))) {
|
||||
wxComboBox *combo = (wxComboBox*) binds[i].ctrl;
|
||||
combo->SetSelection(Options.AsInt(binds[i].option));
|
||||
int style = combo->GetWindowStyleFlag();
|
||||
|
||||
// Read-only, use as value
|
||||
if (style & wxCB_READONLY && binds[i].param == 0) {
|
||||
combo->SetSelection(Options.AsInt(binds[i].option));
|
||||
}
|
||||
|
||||
// Editable, set text
|
||||
else {
|
||||
wxString value = Options.AsText(binds[i].option);
|
||||
if (!(style & wxCB_READONLY) && combo->FindString(value) == wxNOT_FOUND) combo->Append(value);
|
||||
combo->SetValue(value);
|
||||
}
|
||||
}
|
||||
|
||||
// Colour button
|
||||
|
|
|
@ -60,6 +60,7 @@ class OptionsBind {
|
|||
public:
|
||||
wxControl *ctrl;
|
||||
wxString option;
|
||||
int param;
|
||||
};
|
||||
|
||||
|
||||
|
@ -72,7 +73,7 @@ private:
|
|||
wxTreebook *book;
|
||||
std::vector<OptionsBind> binds;
|
||||
|
||||
void Bind(wxControl *ctrl,wxString option);
|
||||
void Bind(wxControl *ctrl,wxString option,int param=0);
|
||||
void WriteToOptions(bool justApply=false);
|
||||
void ReadFromOptions();
|
||||
|
||||
|
|
|
@ -37,6 +37,12 @@
|
|||
////////////
|
||||
// Includes
|
||||
#include "setup.h"
|
||||
#include <wx/image.h>
|
||||
#include <string.h>
|
||||
#include <wx/clipbrd.h>
|
||||
#include <wx/filename.h>
|
||||
#include <wx/config.h>
|
||||
#include "utils.h"
|
||||
#include "video_display.h"
|
||||
#include "video_provider.h"
|
||||
#include "vfr.h"
|
||||
|
@ -51,11 +57,6 @@
|
|||
#include "audio_display.h"
|
||||
#include "main.h"
|
||||
#include "video_slider.h"
|
||||
#include <wx/image.h>
|
||||
#include <string.h>
|
||||
#include <wx/clipbrd.h>
|
||||
#include <wx/filename.h>
|
||||
#include <wx/config.h>
|
||||
#if USE_FEXTRACKER == 1
|
||||
#include "../FexTrackerSource/FexTracker.h"
|
||||
#include "../FexTrackerSource/FexTrackingFeature.h"
|
||||
|
@ -648,10 +649,25 @@ void VideoDisplay::OnSaveSnapshot(wxCommandEvent &event) {
|
|||
}
|
||||
|
||||
void VideoDisplay::SaveSnapshot() {
|
||||
static int session_shot_count = 1;
|
||||
// Get path
|
||||
wxFileName file = videoName;
|
||||
wxString basepath = file.GetPath() + _T("/") + file.GetName();
|
||||
// Get folder
|
||||
wxString option = Options.AsText(_("Video Screenshot Path"));
|
||||
wxFileName videoFile(videoName);
|
||||
wxString basepath;
|
||||
if (option == _T("?video")) {
|
||||
basepath = videoFile.GetPath();
|
||||
}
|
||||
else if (option == _T("?script")) {
|
||||
if (grid->ass->filename.IsEmpty()) basepath = videoFile.GetPath();
|
||||
else {
|
||||
wxFileName file2(grid->ass->filename);
|
||||
basepath = file2.GetPath();
|
||||
}
|
||||
}
|
||||
else basepath = DecodeRelativePath(option,((AegisubApp*)wxTheApp)->folderName);
|
||||
basepath += _T("/") + videoFile.GetName();
|
||||
|
||||
// Get full path
|
||||
int session_shot_count = 1;
|
||||
wxString path;
|
||||
while (1) {
|
||||
path = basepath + wxString::Format(_T("_%03i_%i.png"),session_shot_count,frame_n);
|
||||
|
|
Loading…
Reference in New Issue