Better lavc/avisynth selection code (will automatically use what's available, or by option if both are)

Originally committed to SVN as r147.
This commit is contained in:
Rodrigo Braz Monteiro 2006-02-24 08:30:08 +00:00
parent 9481d8424b
commit 9b395f283d
7 changed files with 123 additions and 12 deletions

View file

@ -153,6 +153,8 @@ void OptionsManager::LoadDefaults() {
SetBool(_T("Threaded Video"),false); SetBool(_T("Threaded Video"),false);
SetInt(_T("Avisynth MemoryMax"),64); SetInt(_T("Avisynth MemoryMax"),64);
SetBool(_T("Allow Ancient Avisynth"),false); SetBool(_T("Allow Ancient Avisynth"),false);
SetBool(_T("Use ffmpeg"),false);
SetText(_T("Video resizer"),_T("BilinearResize")); SetText(_T("Video resizer"),_T("BilinearResize"));
SetInt(_T("Video Check Script Res"), 0); SetInt(_T("Video Check Script Res"), 0);
SetInt(_T("Video Default Zoom"), 7); SetInt(_T("Video Default Zoom"), 7);

View file

@ -37,8 +37,7 @@
//////////// ////////////
// Includes // Includes
#include "video_display.h" #include "video_display.h"
#include "video_provider_avs.h" #include "video_provider.h"
#include "video_provider_lavc.h"
#include "vfr.h" #include "vfr.h"
#include "ass_file.h" #include "ass_file.h"
#include "ass_time.h" #include "ass_time.h"
@ -140,6 +139,7 @@ void VideoDisplay::UpdateSize() {
/////////////////////// ///////////////////////
// Sets video filename // Sets video filename
void VideoDisplay::SetVideo(const wxString &filename) { void VideoDisplay::SetVideo(const wxString &filename) {
// Unload video
if (filename.IsEmpty()) { if (filename.IsEmpty()) {
delete provider; delete provider;
provider = NULL; provider = NULL;
@ -151,20 +151,19 @@ void VideoDisplay::SetVideo(const wxString &filename) {
frame_n = 0; frame_n = 0;
Reset(); Reset();
} else { }
// Load video
else {
SetVideo(_T("")); SetVideo(_T(""));
try { try {
grid->CommitChanges(true); grid->CommitChanges(true);
// Choose a provider
bool usedDirectshow = false; bool usedDirectshow = false;
provider = VideoProvider::GetProvider(filename,GetTempWorkFile());
#ifndef USE_LAVC
provider = new AvisynthVideoProvider(filename,GetTempWorkFile(),zoomValue,usedDirectshow);
#else
provider = new LAVCVideoProvider(filename,GetTempWorkFile(),zoomValue);
#endif
// Set keyframes // Set keyframes
wxString ext = filename.Right(4).Lower(); wxString ext = filename.Right(4).Lower();
if (ext == _T(".avi")) KeyFrames = VFWWrapper::GetKeyFrames(filename); if (ext == _T(".avi")) KeyFrames = VFWWrapper::GetKeyFrames(filename);

87
core/video_provider.cpp Normal file
View file

@ -0,0 +1,87 @@
// Copyright (c) 2006, Rodrigo Braz Monteiro
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
// * Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
// * Neither the name of the Aegisub Group nor the names of its contributors
// may be used to endorse or promote products derived from this software
// without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.
//
// -----------------------------------------------------------------------------
//
// AEGISUB
//
// Website: http://aegisub.cellosoft.com
// Contact: mailto:zeratul@cellosoft.com
//
///////////
// Headers
#include "video_provider_avs.h"
#include "video_provider_lavc.h"
#include "options.h"
////////////////
// Get provider
VideoProvider *VideoProvider::GetProvider(wxString video,wxString subtitles) {
// Check if avisynth is available
bool avisynthAvailable = false;
#ifdef __WINDOWS__
try {
// If avisynth.dll cannot be loaded, an exception will be thrown and avisynthAvailable will never be set to true
AviSynthWrapper avs;
avisynthAvailable = true;
}
catch (...) {}
#endif
// Initialize to null
VideoProvider *provider = NULL;
// See if it's OK to use LAVC
#ifdef USE_LAVC
if (Options.AsBool(_T("Use ffmpeg"))) {
try {
provider = new LAVCVideoProvider(video,subtitles,1.0);
}
catch (...) {
if (avisynthAvailable) {
wxMessageBox(_T("Failed loading FFmpeg decoder for video, falling back to Avisynth."),_T("FFmpeg error."));
provider = NULL;
}
// Out of options, rethrow
else throw;
}
}
#endif
// Use avisynth provider
#ifdef __WINDOWS__
bool usedDirectshow = false;
if (!provider) provider = new AvisynthVideoProvider(video,subtitles,1.0,usedDirectshow);
#endif
// Return provider
return provider;
}

View file

@ -60,4 +60,6 @@ public:
virtual int GetSourceWidth()=0; // Returns the original source width in pixels virtual int GetSourceWidth()=0; // Returns the original source width in pixels
virtual int GetSourceHeight()=0; // Returns the original source height in pixels virtual int GetSourceHeight()=0; // Returns the original source height in pixels
static VideoProvider *GetProvider(wxString video,wxString subtitles);
}; };

View file

@ -40,6 +40,9 @@
#include "main.h" #include "main.h"
#ifdef __WINDOWS__
AvisynthVideoProvider::AvisynthVideoProvider(wxString _filename, wxString _subfilename, double _zoom, bool &usedDirectshow) { AvisynthVideoProvider::AvisynthVideoProvider(wxString _filename, wxString _subfilename, double _zoom, bool &usedDirectshow) {
bool mpeg2dec3_priority = true; bool mpeg2dec3_priority = true;
RGB32Video = NULL; RGB32Video = NULL;
@ -281,3 +284,6 @@ void AvisynthVideoProvider::LoadVSFilter() {
throw _T("Couldn't locate VSFilter"); throw _T("Couldn't locate VSFilter");
} }
} }
#endif

View file

@ -33,9 +33,15 @@
// Contact: mailto:zeratul@cellosoft.com // Contact: mailto:zeratul@cellosoft.com
// //
#ifndef VIDEO_PROVIDER_AVS_H
#define VIDEO_PROVIDER_AVS_H
#pragma once
///////////
// Headers
#include <wx/wxprec.h>
#ifdef __WINDOWS__
#include "avisynth_wrap.h" #include "avisynth_wrap.h"
#include "video_provider.h" #include "video_provider.h"

View file

@ -36,6 +36,15 @@
#pragma once #pragma once
///////////////////////////////////
// Auto-enable LAVC on non-windows
#ifndef __WINDOWS__
#ifndef USE_LAVC
#define USE_LAVC
#endif
#endif
/////////// ///////////
// Headers // Headers
#ifdef USE_LAVC #ifdef USE_LAVC