jquery教程

推荐列表 站点导航

当前位置:首页 > jquery > jquery教程 >

ffmpeg截取视频指定帧为图片,获取rotation信息并旋转

来源:网络整理  作者:  发布时间:2020-12-21 11:30
jquery中文网为您提供ffmpeg截取视频指定帧为图片,获取rotation信息并旋转等资源,欢迎您收藏本站,我们将为您提供最...

对ffmpeg命令和参数不熟悉的可参考如下文档:

    }
        foreach($result as $line) {
然后php ffmpeg扩展并无法获知rotation信息(php ffmpeg扩展文档),但可以通过ffmpeg命令行获取:

用php简单封装下如下:
/usr/local/ffmpeg/bin/ffprobe test.mp4 -show_streams  | grep rotate

                $stream_info = explode("=", $line);
imagedestroy($gd_image);

ffmpeg对于php开发者来讲肯定都多少会听过吧,我信下面来看ffmpeg截取视频的功能,这个是直接使用php来实现的,具体的例子如下所示.

然而问题来了,智能手机拍摄的视频,由于拍摄方向不同,视频会被旋转,并带上meta信息rotate,当你相对视频截取frame图片的时候,如果有rotate信息的视频,frame也是旋转的,因此你需要将截取的图片相应的旋转。

使用imagerotate()函数就可以旋转截图:
$movie = new ffmpeg_movie($video_filePath);
    $orientation = 0;
            if(strpos($line, 'TAG:rotate') !== FALSE) {
    if(strpos($result, 'TAG:rotate') !== FALSE) {
    $cmd =  "/usr/local/ffmpeg/bin/ffprobe " . $video_path . " -show_streams 2>/dev/null";
    $result = shell_exec($cmd);
        $result = explode("\n", $result);
$gd = $frame->toGDImage();
 
$frame = $movie->getFrame(1);
    return $orientation;
}

截取视频指定帧为图片,php ffmpeg扩展已经完美实现:

/usr/local/ffmpeg/bin/ffmpeg -i input.mp4 -vf 'transpose=3' -metadata:s:v:0 rotate=0 -codec:v libx264 -strict -2 -y output.mp4

$gd_image = $ff_frame->toGDImage();

$movie = new ffmpeg_movie($video_filePath);
            }
$img="./test.jpg";
    $gd = imagerotate($gd, 360-$orientation, 0);
if ($orientation = $this->get_video_orientation($video_filePath)) {
imagejpeg($gd, $img);

最后还有一个麻烦事,不是所有的播放器和浏览器都可对video识别orientation并自动rotate,如果你想对视频进行旋转,可通过ffmpeg命令解决:
imagejpeg($gd_image, $img);
$ff_frame = $movie->getFrame(1);
$img="./test.jpg";
                $orientation = $stream_info[1];
imagedestroy($gd_image);

function get_video_orientation($video_path) {
        }
}

相关热词:

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!

本文地址: https://v30.fanwenzhu.com/jq/jc/6612.shtml

相关文章
最新文章
PHP识别相片是否是颠倒的 PHP识别相片是否是颠倒的

时间:2020-12-28

python编程有哪些ide python编程有哪些ide

时间:2020-12-28

python开发工程师是做什么 python开发工程师是做什么

时间:2020-12-28

php构造函数的作用 php构造函数的作用

时间:2020-12-28

php怎么跟数据库连接 php怎么跟数据库连接

时间:2020-12-28

php实现顺序线性表 php实现顺序线性表

时间:2020-12-28

Python多重继承中的菱形继 Python多重继承中的菱形继

时间:2020-12-28

php中break的作用 php中break的作用

时间:2020-12-28

Copyright © www.juheyunku.com      关于 | 合作 | 声明 | 联系 | 更新 | 地图 | Tags

ffmpeg截取视频指定帧为图片,获取rotation信息并旋转

2020-12-21 编辑:

对ffmpeg命令和参数不熟悉的可参考如下文档:

    }
        foreach($result as $line) {
然后php ffmpeg扩展并无法获知rotation信息(php ffmpeg扩展文档),但可以通过ffmpeg命令行获取:

用php简单封装下如下:
/usr/local/ffmpeg/bin/ffprobe test.mp4 -show_streams  | grep rotate

                $stream_info = explode("=", $line);
imagedestroy($gd_image);

ffmpeg对于php开发者来讲肯定都多少会听过吧,我信下面来看ffmpeg截取视频的功能,这个是直接使用php来实现的,具体的例子如下所示.

然而问题来了,智能手机拍摄的视频,由于拍摄方向不同,视频会被旋转,并带上meta信息rotate,当你相对视频截取frame图片的时候,如果有rotate信息的视频,frame也是旋转的,因此你需要将截取的图片相应的旋转。

使用imagerotate()函数就可以旋转截图:
$movie = new ffmpeg_movie($video_filePath);
    $orientation = 0;
            if(strpos($line, 'TAG:rotate') !== FALSE) {
    if(strpos($result, 'TAG:rotate') !== FALSE) {
    $cmd =  "/usr/local/ffmpeg/bin/ffprobe " . $video_path . " -show_streams 2>/dev/null";
    $result = shell_exec($cmd);
        $result = explode("\n", $result);
$gd = $frame->toGDImage();
 
$frame = $movie->getFrame(1);
    return $orientation;
}

截取视频指定帧为图片,php ffmpeg扩展已经完美实现:

/usr/local/ffmpeg/bin/ffmpeg -i input.mp4 -vf 'transpose=3' -metadata:s:v:0 rotate=0 -codec:v libx264 -strict -2 -y output.mp4

$gd_image = $ff_frame->toGDImage();

$movie = new ffmpeg_movie($video_filePath);
            }
$img="./test.jpg";
    $gd = imagerotate($gd, 360-$orientation, 0);
if ($orientation = $this->get_video_orientation($video_filePath)) {
imagejpeg($gd, $img);

最后还有一个麻烦事,不是所有的播放器和浏览器都可对video识别orientation并自动rotate,如果你想对视频进行旋转,可通过ffmpeg命令解决:
imagejpeg($gd_image, $img);
$ff_frame = $movie->getFrame(1);
$img="./test.jpg";
                $orientation = $stream_info[1];
imagedestroy($gd_image);

function get_video_orientation($video_path) {
        }
}

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供学习参考!
本文地址为 https://v30.fanwenzhu.com/jq/jc/6612.shtml

相关文章

风云图片

推荐阅读

返回jquery教程频道首页