php打印指定区域图片,php截取视频指定帧为图片

搜索热词

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

getFrame(1);

$gd_image = $ff_frame->toGDImage();

$img="./test.jpg";

imagejpeg($gd_image,$img);

imagedestroy($gd_image);

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

然后PHP ffmpeg扩展并无法获知rotation信息(PHP ffmpeg扩展文档),但可以通过ffmpeg命令行获取:

PHP简单封装下如下:

/dev/null";

$result = shell_exec($cmd);

$orientation = 0;

if(strpos($result,'TAG:rotate') !== FALSE) {

$result = explode("\n",$result);

foreach($result as $line) {

if(strpos($line,'TAG:rotate') !== FALSE) {

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

$orientation = $stream_info[1];

}

}

}

return $orientation;

}

使用imagerotate()函数就可以旋转截图:

getFrame(1);

$gd = $frame->toGDImage();

if ($orientation = $this->get_video_orientation($video_filePath)) {

$gd = imagerotate($gd,360-$orientation,0);

}

$img="./test.jpg";

imagejpeg($gd,$img);

imagedestroy($gd_image);

最后还有一个麻烦事,不是所有的播放器和浏览器都可对video识别orientation并自动rotate,如果你想对视频进行旋转,可通过ffmpeg命令解决:

/usr/local/ffmpeg/bin/ffmpeg -i input.mp4 -vf 'transpose=3' -Metadata:s:v:0 rotate=0

内容,希望对大家学习PHP程序设计有所帮助。

总结

以上是编程之家为你收集整理的php截取视频指定帧为图片全部内容,希望文章能够帮你解决php截取视频指定帧为图片所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用Python截取Excel指定区域并生成图片,首先需要安装openpyxl和PIL库,openpyxl用于处理Excel文件,PIL用于生成图片。 首先,我们需要打开Excel文件,然后选择指定区域。可以通过openpyxl库中的load_workbook函数进行打开,并使用active属性或者获取sheet之后使用cell函数来定位需要截取区域。 接下来,可以使用PIL库中的Image模块来创建一个新的图片对象。然后,通过遍历Excel指定区域的内容,并将其添加到图片对象中相应的位置。 最后,可以使用PIL库的save函数将图片保存到本地磁盘。 整个过程的代码可以分为以下几个步骤: 1. 导入openpyxl和PIL库 2. 打开Excel文件 3. 选择指定区域 4. 创建一个新的图片对象 5. 将Excel指定区域的内容添加到图片对象中 6. 保存图片到本地磁盘 一个简单的示例代码如下: ```python import openpyxl from PIL import Image, ImageDraw # 打开Excel文件 wb = openpyxl.load_workbook('example.xlsx') sheet = wb.active # 选择指定区域 cell_range = sheet['A1:C3'] # 创建一个新的图片对象 img = Image.new('RGB', (300, 300), color = (255, 255, 255)) draw = ImageDraw.Draw(img) # 将Excel指定区域的内容添加到图片对象中 for row in cell_range: for cell in row: draw.text((cell.column * 100, cell.row * 100), cell.value, fill=(0, 0, 0)) # 保存图片到本地磁盘 img.save('output.png') ``` 这样就可以使用Python截取Excel指定区域并生成图片了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值