diff options
| author | Carl Hetherington <cth@carlh.net> | 2013-02-02 14:27:54 +0000 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2013-02-02 14:27:54 +0000 |
| commit | 98bbaf1e907e927dbd26131cbdef243a82fdc2d1 (patch) | |
| tree | b5863c26d3368c44269755f7af9f5e4b7b117ea7 /src/lib | |
| parent | 8b4aa224882d2451f81c0a3ad07ec2d4ea098d5a (diff) | |
Only offer filters and postproc that exist.
Diffstat (limited to 'src/lib')
| -rw-r--r-- | src/lib/filter.cc | 68 | ||||
| -rw-r--r-- | src/lib/filter.h | 1 | ||||
| -rw-r--r-- | src/lib/filter_graph.cc | 2 | ||||
| -rw-r--r-- | src/lib/util.cc | 2 |
4 files changed, 47 insertions, 26 deletions
diff --git a/src/lib/filter.cc b/src/lib/filter.cc index 446cc111d..c23882726 100644 --- a/src/lib/filter.cc +++ b/src/lib/filter.cc @@ -22,6 +22,10 @@ */ #include "filter.h" +extern "C" { +#include <libavfilter/avfilter.h> +#include <libpostproc/postprocess.h> +} using namespace std; @@ -57,30 +61,46 @@ Filter::setup_filters () { /* Note: "none" is a magic id name, so don't use it here */ - _filters.push_back (new Filter ("pphb", "Horizontal deblocking filter", "", "hb")); - _filters.push_back (new Filter ("ppvb", "Vertical deblocking filter", "", "vb")); - _filters.push_back (new Filter ("ppha", "Horizontal deblocking filter A", "", "ha")); - _filters.push_back (new Filter ("ppva", "Vertical deblocking filter A", "", "va")); - _filters.push_back (new Filter ("pph1", "Experimental horizontal deblocking filter 1", "", "h1")); - _filters.push_back (new Filter ("pphv", "Experimental vertical deblocking filter 1", "", "v1")); - _filters.push_back (new Filter ("ppdr", "Deringing filter", "", "dr")); - _filters.push_back (new Filter ("pplb", "Linear blend deinterlacer", "", "lb")); - _filters.push_back (new Filter ("ppli", "Linear interpolating deinterlacer", "", "li")); - _filters.push_back (new Filter ("ppci", "Cubic interpolating deinterlacer", "", "ci")); - _filters.push_back (new Filter ("ppmd", "Median deinterlacer", "", "md")); - _filters.push_back (new Filter ("ppfd", "FFMPEG deinterlacer", "", "fd")); - _filters.push_back (new Filter ("ppl5", "FIR low-pass deinterlacer", "", "l5")); - _filters.push_back (new Filter ("mcdeint", "Motion compensating deinterlacer", "mcdeint", "")); - _filters.push_back (new Filter ("kerndeint", "Kernel deinterlacer", "kerndeint", "")); - _filters.push_back (new Filter ("yadif", "Yet Another Deinterlacing Filter", "yadif", "")); - _filters.push_back (new Filter ("pptn", "Temporal noise reducer", "", "tn")); - _filters.push_back (new Filter ("ppfq", "Force quantizer", "", "fq")); - _filters.push_back (new Filter ("gradfun", "Gradient debander", "gradfun", "")); - _filters.push_back (new Filter ("unsharp", "Unsharp mask and Gaussian blur", "unsharp", "")); - _filters.push_back (new Filter ("denoise3d", "3D denoiser", "denoise3d", "")); - _filters.push_back (new Filter ("hqdn3d", "High quality 3D denoiser", "hqdn3d", "")); - _filters.push_back (new Filter ("telecine", "Telecine filter", "telecine", "")); - _filters.push_back (new Filter ("ow", "Overcomplete wavelet denoiser", "mp=ow", "")); + maybe_add ("pphb", "Horizontal deblocking filter", "", "hb"); + maybe_add ("ppvb", "Vertical deblocking filter", "", "vb"); + maybe_add ("ppha", "Horizontal deblocking filter A", "", "ha"); + maybe_add ("ppva", "Vertical deblocking filter A", "", "va"); + maybe_add ("pph1", "Experimental horizontal deblocking filter 1", "", "h1"); + maybe_add ("pphv", "Experimental vertical deblocking filter 1", "", "v1"); + maybe_add ("ppdr", "Deringing filter", "", "dr"); + maybe_add ("pplb", "Linear blend deinterlacer", "", "lb"); + maybe_add ("ppli", "Linear interpolating deinterlacer", "", "li"); + maybe_add ("ppci", "Cubic interpolating deinterlacer", "", "ci"); + maybe_add ("ppmd", "Median deinterlacer", "", "md"); + maybe_add ("ppfd", "FFMPEG deinterlacer", "", "fd"); + maybe_add ("ppl5", "FIR low-pass deinterlacer", "", "l5"); + maybe_add ("mcdeint", "Motion compensating deinterlacer", "mcdeint", ""); + maybe_add ("kerndeint", "Kernel deinterlacer", "kerndeint", ""); + maybe_add ("yadif", "Yet Another Deinterlacing Filter", "yadif", ""); + maybe_add ("pptn", "Temporal noise reducer", "", "tn"); + maybe_add ("ppfq", "Force quantizer", "", "fq"); + maybe_add ("gradfun", "Gradient debander", "gradfun", ""); + maybe_add ("unsharp", "Unsharp mask and Gaussian blur", "unsharp", ""); + maybe_add ("denoise3d", "3D denoiser", "denoise3d", ""); + maybe_add ("hqdn3d", "High quality 3D denoiser", "hqdn3d", ""); + maybe_add ("telecine", "Telecine filter", "telecine", ""); + maybe_add ("ow", "Overcomplete wavelet denoiser", "mp=ow", ""); +} + +void +Filter::maybe_add (string i, string n, string v, string p) +{ + if (!v.empty ()) { + if (avfilter_get_by_name (i.c_str())) { + _filters.push_back (new Filter (i, n, v, p)); + } + } else if (!p.empty ()) { + pp_mode* m = pp_get_mode_by_name_and_quality (p.c_str(), PP_QUALITY_MAX); + if (m) { + _filters.push_back (new Filter (i, n, v, p)); + pp_free_mode (m); + } + } } /** @param filters Set of filters. diff --git a/src/lib/filter.h b/src/lib/filter.h index 20c55049c..e7e8b389f 100644 --- a/src/lib/filter.h +++ b/src/lib/filter.h @@ -73,6 +73,7 @@ private: /** all available filters */ static std::vector<Filter const *> _filters; + static void maybe_add (std::string, std::string, std::string, std::string); }; #endif diff --git a/src/lib/filter_graph.cc b/src/lib/filter_graph.cc index 3a13d93d0..b0991a2da 100644 --- a/src/lib/filter_graph.cc +++ b/src/lib/filter_graph.cc @@ -68,8 +68,6 @@ FilterGraph::FilterGraph (shared_ptr<Film> film, FFmpegDecoder* decoder, libdcp: filters += crop_string (Position (film->crop().left, film->crop().top), film->cropped_size (decoder->native_size())); - avfilter_register_all (); - AVFilterGraph* graph = avfilter_graph_alloc(); if (graph == 0) { throw DecodeError ("Could not create filter graph."); diff --git a/src/lib/util.cc b/src/lib/util.cc index 872985024..ce89d5355 100644 --- a/src/lib/util.cc +++ b/src/lib/util.cc @@ -233,6 +233,8 @@ seconds (struct timeval t) void dvdomatic_setup () { + avfilter_register_all (); + Format::setup_formats (); DCPContentType::setup_dcp_content_types (); Scaler::setup_scalers (); |
