截取视频第一帧当做封面

看了好多处理视频的框架 比如ffmpeg,很多都需要依赖安装第三方插件,比较麻烦,找到一个内嵌进去不需要额外安装的:jcodec

一 首先代码中添加依赖

java 复制代码
    <!--视频生成预览图用-->
        <dependency>
            <groupId>org.jcodec</groupId>
            <artifactId>jcodec</artifactId>
            <version>0.2.3</version>
        </dependency>
        <dependency>
            <groupId>org.jcodec</groupId>
            <artifactId>jcodec-javase</artifactId>
            <version>0.2.3</version>
        </dependency>

二 截取业务逻辑代码编写

生成的预览图你可以输出到一个地址,这里我是转换成了base64,然后存储到了数据库中,前台拿到也可以直接用。

java 复制代码
    /**
     * 截取图片第一帧作为预览图
     *
     * @param path
     * @param suffix
     * @return
     */
    private String generatorPreviewImg(String path,String suffix){
        ByteArrayInputStream byteArrayInputStream;
        try {
            File videoFile = new File(path);
            // 获取视频的第一帧作为预览图
            Picture frame = FrameGrab.getFrameFromFile(videoFile, 1);
            // 将视频帧转换为BufferedImage
            BufferedImage image = AWTUtil.toBufferedImage(frame);
            // 生成的预览图
            ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
            ImageIO.write(image, "jpg", outputStream);
            byteArrayInputStream = new ByteArrayInputStream(outputStream.toByteArray());
        }catch (IOException | JCodecException e){
            throw new RuntimeException(e);
        }
        return getBase64(byteArrayInputStream,suffix);
    }
java 复制代码
    /**
     * 将图片转为base64
     *
     * @param in
     * @param suffix
     * @return
     */
    private String getBase64(InputStream in,String suffix){
        // 将图片文件转化为字节数组字符串,并对其进行Base64编码处理
        byte[] buffer = null;
        // 读取图片字节数组
        try (InputStream inputStream =  in) {
            buffer = new byte[inputStream.available()];
            inputStream.read(buffer);
        } catch (IOException e) {
            e.printStackTrace();
        }
        String base64 = Base64.encodeBase64String(buffer);
        // 拼接前面的格式 
        return "data:image/" + suffix + ";base64," + base64;
    }
相关推荐
sweetone4 分钟前
LINN莲CLASSIK桌面音响微修
经验分享·音视频
晚霞的不甘4 小时前
CANN 编译器深度解析:UB、L1 与 Global Memory 的协同调度机制
java·后端·spring·架构·音视频
美狐美颜SDK开放平台5 小时前
多终端适配下的人脸美型方案:美颜SDK工程开发实践分享
人工智能·音视频·美颜sdk·直播美颜sdk·视频美颜sdk
饭饭大王6668 小时前
CANN 生态深度整合:使用 `pipeline-runner` 构建高吞吐视频分析流水线
人工智能·音视频
晚霞的不甘10 小时前
CANN 编译器深度解析:TBE 自定义算子开发实战
人工智能·架构·开源·音视频
愚公搬代码10 小时前
【愚公系列】《AI短视频创作一本通》016-AI短视频的生成(AI短视频运镜方法)
人工智能·音视频
那个村的李富贵11 小时前
CANN赋能AIGC“数字人”革命:实时视频换脸与表情驱动实战
aigc·音视频
晚霞的不甘11 小时前
CANN 支持强化学习:从 Isaac Gym 仿真到机械臂真机控制
人工智能·神经网络·架构·开源·音视频
晚霞的不甘15 小时前
CANN 支持多模态大模型:Qwen-VL 与 LLaVA 的端侧部署实战
人工智能·神经网络·架构·开源·音视频
拾荒的小海螺1 天前
开源项目:LTX2 高效可控的开源视频生成模型
开源·音视频