X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-core%2Ftrunk%2Fsrc%2Fmodules%2Fmod_ffmpeg%2Fmptr_ffmpeg.cpp;h=0ab514fc4fd647a10c4917716c25326f1dcf289c;hb=3ddc1c12f966668a0835427890c97645b77935fb;hp=951bfbd43d6c4903c2b4c74a503e5437480773f8;hpb=7e841a0c53e559c8721b24aadef23082e3e5677e;p=synfig.git diff --git a/synfig-core/trunk/src/modules/mod_ffmpeg/mptr_ffmpeg.cpp b/synfig-core/trunk/src/modules/mod_ffmpeg/mptr_ffmpeg.cpp index 951bfbd..0ab514f 100644 --- a/synfig-core/trunk/src/modules/mod_ffmpeg/mptr_ffmpeg.cpp +++ b/synfig-core/trunk/src/modules/mod_ffmpeg/mptr_ffmpeg.cpp @@ -102,7 +102,7 @@ ffmpeg_mptr::seek_to(int frame) string command; - command=strprintf("ffmpeg -i \"%s\" -an -f image2pipe -vcodec ppm -\n",filename.c_str()); + command=strprintf("ffmpeg -ss 00:00:00.%d -i \"%s\" -an -f image2pipe -vcodec ppm -\n",frame,filename.c_str()); file=popen(command.c_str(),POPEN_BINARY_READ_TYPE); @@ -133,7 +133,8 @@ ffmpeg_mptr::seek_to(int frame) } // Close the unneeded pipein close(p[1]); - execlp("ffmpeg", "ffmpeg", "-i", filename.c_str(), "-an", "-f", "image2pipe", "-vcodec", "ppm", "-", (const char *)NULL); + string time = strprintf("00:00:00.%d",frame); + execlp("ffmpeg", "ffmpeg", "-ss", time.c_str(), "-i", filename.c_str(), "-an", "-f", "image2pipe", "-vcodec", "ppm", "-", (const char *)NULL); // We should never reach here unless the exec failed cerr<<"Unable to open pipe to ffmpeg"<