diff options
| author | Aurélio A. Heckert <aurelio@colivre.coop.br> | 2015-06-09 22:08:16 -0300 | 
|---|---|---|
| committer | Aurélio A. Heckert <aurelio@colivre.coop.br> | 2015-06-09 22:08:16 -0300 | 
| commit | d84f1d14b526c4a5359117a58f25691a3da4c97e (patch) | |
| tree | 29b71297494ac80da38a4f0a047a9cebbfafa1df /youtube_dl/postprocessor/ffmpeg.py | |
| parent | 70219b0f4371fe54cc72d025ce06fc4691ba12fa (diff) | |
Adds support for XviD output with extra parametrization
As the "LG Time Machine" (a (not so) smart TV) has a limitation for video dimensions (as for codecs), I take to implement an extra parameter `--pp-params` where we can send extra parameterization for the video converter (post-processor).
Example:
```
$ youtube-dl --recode-video=xvid --pp-params='-s 720x480' -c https://www.youtube.com/watch?v=BE7Qoe2ZiXE
```
That works fine on a 4yo LG Time Machine.
Closes #5733
Diffstat (limited to 'youtube_dl/postprocessor/ffmpeg.py')
| -rw-r--r-- | youtube_dl/postprocessor/ffmpeg.py | 14 | 
1 files changed, 10 insertions, 4 deletions
| diff --git a/youtube_dl/postprocessor/ffmpeg.py b/youtube_dl/postprocessor/ffmpeg.py index cc65b34e7..a696b12b4 100644 --- a/youtube_dl/postprocessor/ffmpeg.py +++ b/youtube_dl/postprocessor/ffmpeg.py @@ -287,22 +287,28 @@ class FFmpegExtractAudioPP(FFmpegPostProcessor):  class FFmpegVideoConvertorPP(FFmpegPostProcessor): -    def __init__(self, downloader=None, preferedformat=None): +    def __init__(self, downloader=None, preferedformat=None, extra_params=[]):          super(FFmpegVideoConvertorPP, self).__init__(downloader)          self._preferedformat = preferedformat +        self._extra_params = extra_params      def run(self, information):          path = information['filepath']          prefix, sep, ext = path.rpartition('.') -        outpath = prefix + sep + self._preferedformat +        ext = self._preferedformat +        options = self._extra_params +        if self._preferedformat == 'xvid': +            ext = 'avi' +            options.extend(['-c:v', 'libxvid', '-vtag', 'XVID']) +        outpath = prefix + sep + ext          if information['ext'] == self._preferedformat:              self._downloader.to_screen('[ffmpeg] Not converting video file %s - already is in target format %s' % (path, self._preferedformat))              return [], information          self._downloader.to_screen('[' + 'ffmpeg' + '] Converting video from %s to %s, Destination: ' % (information['ext'], self._preferedformat) + outpath) -        self.run_ffmpeg(path, outpath, []) +        self.run_ffmpeg(path, outpath, options)          information['filepath'] = outpath          information['format'] = self._preferedformat -        information['ext'] = self._preferedformat +        information['ext'] = ext          return [path], information | 
