java截取视频最后一帧照片作为封面

引言

我们在日常工作中经常会遇到上传视频,而产品还会要求截取视频某一帧作为封面展示,对于这种情况新手还是比较头疼的,那我们直接世界上最简单的实现方案。

How to do

1.提前引入包

java 复制代码
        <!--视频多媒体工具包 包含 FFmpeg、OpenCV-->
        <dependency>
            <groupId>org.bytedeco</groupId>
            <artifactId>javacv-platform</artifactId>
            <version>1.5.3</version>
        </dependency>
        <!--hutool万能工具包-->
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.4.4</version>
        </dependency>

2.逻辑代码实现

java 复制代码
    public static void main(String[] args) throws IOException, InterruptedException {
        Image image = cutScreenshot("");
        String jpg = ImgUtil.toBase64(image, "jpg");
        System.out.println(jpg);
    }



  
     /**
     * 截屏视频最后一帧(有效图片)
     *
     * @param localPath 本地视频地址
     * @return
     */
    public static Image cutScreenshot(String localPath) throws FrameGrabber.Exception {
        FFmpegFrameGrabber grabber = FFmpegFrameGrabber.createDefault(localPath);

        grabber.start();
//            设置帧数
        grabber.setFrameNumber(grabber.getLengthInFrames() - 1);
//            获取当前有效图片(如果没有图片返回的是null,后期在做优化)
        Frame frame = grabber.grabImage();
        //视频旋转度
        String rotate = grabber.getVideoMetadata("rotate");
        Java2DFrameConverter converter = new Java2DFrameConverter();
        //绘制图片
        BufferedImage bufferedImage = converter.getBufferedImage(frame);
        if (rotate != null) {
            // 旋转图片
            bufferedImage = rotate(bufferedImage, Integer.parseInt(rotate));
        }
        log.info("视频的宽:{}", bufferedImage.getWidth());
        log.info("视频的高:{}", bufferedImage.getHeight());
        log.info("视频的旋转度:{}", rotate);
        log.info("视频的格式:{}", grabber.getFormat());
        log.info("此视频时长(s/秒):{}", grabber.getLengthInTime() / (1000 * 1000));
        return bufferedImage;
    }
相关推荐
小蜜蜂嗡嗡2 小时前
【flutter对屏幕底部有手势区域(如:一条横杠)导致出现重叠遮挡】
前端·javascript·flutter
伍哥的传说3 小时前
Vue 3 useModel vs defineModel:选择正确的双向绑定方案
前端·javascript·vue.js·definemodel对比·usemodel教程·vue3.4新特性·vue双向绑定
胡gh8 小时前
页面卡成PPT?重排重绘惹的祸!依旧性能优化
前端·javascript·面试
胡gh9 小时前
简单又复杂,难道只能说一个有箭头一个没箭头?这种问题该怎么回答?
javascript·后端·面试
言兴9 小时前
# 深度解析 ECharts:从零到一构建企业级数据可视化看板
前端·javascript·面试
山有木兮木有枝_9 小时前
TailWind CSS
前端·css·postcss
烛阴10 小时前
TypeScript 的“读心术”:让类型在代码中“流动”起来
前端·javascript·typescript
杨荧10 小时前
基于Python的农作物病虫害防治网站 Python+Django+Vue.js
大数据·前端·vue.js·爬虫·python
Moment11 小时前
毕业一年了,分享一下我的四个开源项目!😊😊😊
前端·后端·开源
程序视点11 小时前
Escrcpy 3.0投屏控制软件使用教程:无线/有线连接+虚拟显示功能详解
前端·后端