3

Я пытаюсь заставить ffmpeg использовать плагин frei0r и, хотя мне удалось показать frei0r в списке фильтров, я получаю сообщение об ошибке:

 [frei0r @ 0x10331c1c0] Could not find module 'glow'
 Error initializing filter 'frei0r' with args 'glow:0.5'

Я использую доморощенный. Я получил ffmpeg для сборки с --enable-frei0r --enable-filter = frei0r инструкция из этого Git:

https://github.com/mxcl/homebrew/commit/f63399c3d0241e7534e73b9fe9d4413b151414b9

Но не могу на самом деле использовать frei0r.

РЕДАКТИРОВАТЬ: Вот полный вывод:

$ ffmpeg -i 1.mp4 -vf -vf frei0r=glow:0.5 output.mpg
 ffmpeg version 0.10 Copyright (c) 2000-2012 the FFmpeg developers  built on Mar  4 2012       11:47:02 with clang 3.0 (tags/Apple/clang-211.10.1)
  configuration: --prefix=/usr/local/Cellar/ffmpeg/0.10 --enable-shared --enable-gpl --enable-version3 --enable-nonfree --enable-hardcoded-tables --enable-libfreetype --cc=/usr/bin/clang --enable-libx264 --enable-libfaac --enable-libmp3lame --enable-librtmp --enable-libtheora --enable-libvorbis --enable-libvpx --enable-libxvid --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libass --disable-ffplay --enable-frei0r --enable-filter=frei0r --enable-filter=frei0r_src --enable-libopencv
  libavutil      51. 34.101 / 51. 34.101
  libavcodec     53. 60.100 / 53. 60.100
  libavformat    53. 31.100 / 53. 31.100
  libavdevice    53.  4.100 / 53.  4.100
  libavfilter     2. 60.100 /  2. 60.100
  libswscale      2.  1.100 /  2.  1.100
  libswresample   0.  6.100 /  0.  6.100
  libpostproc    52.  0.100 / 52.  0.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from '1.mp4':
  Metadata:
    major_brand     : isom
    minor_version   : 512
    compatible_brands: isomiso2avc1mp41
    creation_time   : 2011-12-15 10:24:56
    encoder         : Lavf53.24.0
  Duration: 00:00:15.44, start: 0.000000, bitrate: 2736 kb/s
    Stream #0:0(und): Video: h264 (High) (avc1 / 0x31637661), yuv420p, 1920x1080, 2604 kb/s, 23.98 fps, 23.98 tbr, 48k tbn, 47.95 tbc
    Metadata:
      creation_time   : 2011-12-15 10:24:56
      handler_name    : VideoHandler
    Stream #0:1(und): Audio: aac (mp4a / 0x6134706D), 44100 Hz, stereo, s16, 128 kb/s
    Metadata:
      creation_time   : 2011-12-15 10:24:56
      handler_name    : 
[NULL @ 0x7fcb9184a400] Unable to find a suitable output format for 'frei0r=glow:0.5'
frei0r=glow:0.5: Invalid argument

2 ответа2

6

попробуйте следующее:

ffmpeg -v debug -i 1.mp4 -vf frei0r=glow:0.5 output.mpg

и вы, вероятно, увидите что-то вроде этого:

[Parsed_frei0r_0 @ 0x7fe7834196a0] Поиск эффекта frei0r в '/Users/user/.frei0r-1/lib/glow.dylib' [Parsed_frei0r_0 @ 0x7fe7834196a0] Поиск эффекта frei0r в '/usr/local/lib/1/.dylib '[Parsed_frei0r_0 @ 0x7fe7834196a0] Поиск эффекта frei0r в'/usr/lib/frei0r-1/glow.dylib '

и ffmpeg, вероятно, прав. Если вы увидите ls -l /usr/local/lib/frei0r-1/ вы увидите, что плагин установлен с расширением .so .

На моей машине (OSX 10.7.3, ffmpeg 1.0 и frei0r-1.3) я просто сделал что-то вроде:

for file in /usr/local/lib/frei0r-1/*.so ; do cp $file "${file%.*}.dylib" ; done

что решило проблему, потому что библиотека .so имела 2 архитектуры: i386 и x86_64.

Я уверен, что это не общее решение, но оно сделало всю работу за меня.

3

У меня также была эта проблема, и я обнаружил эту переменную среды в источнике ffmpeg vf_frei0r.c в строке 229:

if ((path = av_strdup(getenv("FREI0R_PATH")))) {
...

Следовательно, установка этого с помощью

export FREI0R_PATH=/path/to/.so-files

работал на меня. Замените этот путь тем, где хранятся ваши .so файлы для libfrei0r.

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .