Vue+Video.js实现视频抽帧返回抽帧图片Base64

1.vue

   // 抽帧 (url视频地址 time00:00:00:00时分秒帧 FPS视频帧率) 返回抽帧图片Base64
    getImgBase64(url,time,FPS) {
          var base64URL = ''
          let video = document.createElement('video')
          video.setAttribute('crossOrigin', 'anonymous') //处理跨域
          video.setAttribute('src', url)
          video.currentTime = this.timeToSeconds(time,FPS);
          video.addEventListener('loadeddata', function() {
          let canvas = document.createElement('canvas')
          //使用视频的宽高作为canvas、预览图的宽高
          let width = video.videoWidth 
          let height = video.videoHeight
          canvas.width = width
          canvas.height = height
          canvas.getContext('2d').drawImage(video, 0, 0, width, height) //绘制canvas
          base64URL = canvas.toDataURL('image/jpeg') //转换为base64,图片格式默认为png,这里修改为jpeg
          // console.log(base64URL.split(",")[1]);
          return base64URL.split(",")[1];
          })
    },
        //时分秒帧 转为秒
        timeToSeconds(time,FPS) {
            // 按小时、分钟、秒进行切割
            const [hours, minutes, seconds,frame] = time.split(':');
            // 计算总共的秒数
            var second = parseInt(hours) * 3600 + parseInt(minutes) * 60 + parseInt(seconds)+ (1/FPS) * parseInt(frame);
            //若秒数为0 防止黑帧 赋值0.1
            if(second == 0){
                second = 0.1;
            }
            return second;
        },

2.Java接口测试生成文件

    /**
     * 抽帧
     * @param jsonObject
     * @return
     */
    @PostMapping("/getFetchFrame")
    public AjaxResult getFetchFrame(@RequestBody JSONObject jsonObject) {
        String imgStr = jsonObject.getString("imgStr");
        OutputStream out = null;
        BASE64Decoder decoder = new BASE64Decoder();
        try {
            byte[] b = decoder.decodeBuffer(imgStr);
            //文件存储位置
            String uploadUrl = "C:\\Users\\cdv\\Desktop";
            File testFile = new File(uploadUrl);
            if (!testFile.exists()) {
                testFile.mkdirs();
            }
            String fileName = "frame" + System.currentTimeMillis() + ".jpg";
            String imgFilePath = uploadUrl + "/" + fileName;
            out = new FileOutputStream(imgFilePath);
            out.write(b);
            out.flush();
            return AjaxResult.success();
        } catch (Exception e) {
            logger.error("抽帧失败! error : " + e.getMessage());
            return AjaxResult.error("抽帧失败");
        } finally {
            try {
                if (out != null) {
                    out.close();
                }
            } catch (Exception e2) {
                logger.error("关闭输出流失败! error : " + e2.getMessage());
                return AjaxResult.error("关闭输出流失败");
            }
        }
    }

实现Spring Boot与Vue.js集成,并使用MinIO存储和读取图片视频,可以按照以下步骤操作: 1. 后端实现 首先,你需要在Spring Boot中集成MinIO客户端,以便从MinIO中读取文件。你可以使用MinIO Java SDK来实现这一点。然后,你需要在Spring Boot中实现一个REST API,该API可以接收前端发送的请求,并从MinIO中读取文件,然后将文件返回给前端。 例如,你可以实现一个REST API,其URL为`/api/file/{filename}`,其中`{filename}`是要从MinIO中读取的文件名。在该API中,你可以使用MinIO Java SDK从MinIO中读取文件,然后将文件内容返回给前端。以下是一个可能的实现: ```java @RestController @RequestMapping("/api") public class FileController { private final MinioClient minioClient; public FileController(MinioClient minioClient) { this.minioClient = minioClient; } @GetMapping("/file/{filename}") public ResponseEntity<byte[]> getFile(@PathVariable String filename) throws Exception { InputStream inputStream = minioClient.getObject("bucket-name", filename); byte[] bytes = IOUtils.toByteArray(inputStream); HttpHeaders headers = new HttpHeaders(); headers.setContentType(MediaType.IMAGE_JPEG); // 设置Content-Type为图片类型 return new ResponseEntity<>(bytes, headers, HttpStatus.OK); } } ``` 2. 前端实现Vue.js中,你可以使用`axios`库来发送请求获取后端API返回的文件内容,并将其显示在页面上。以下是一个可能的实现: ```vue <template> <div> <img :src="imageSrc" /> <video :src="videoSrc" controls></video> </div> </template> <script> import axios from 'axios'; export default { data() { return { imageSrc: '', videoSrc: '', }; }, mounted() { axios.get('/api/file/image.jpg', { responseType: 'blob' }).then((response) => { const reader = new FileReader(); reader.readAsDataURL(response.data); reader.onload = () => { this.imageSrc = reader.result; }; }); axios.get('/api/file/video.mp4', { responseType: 'blob' }).then((response) => { const reader = new FileReader(); reader.readAsDataURL(response.data); reader.onload = () => { this.videoSrc = reader.result; }; }); }, }; </script> ``` 在上面的代码中,我们使用`axios`库发送GET请求获取图片视频文件的内容,并将其转换为Base64编码的字符串,然后将其分别赋值给`imageSrc`和`videoSrc`变量,从而在页面上显示图片视频。注意,我们需要将`responseType`设置为`blob`,以便获取文件的原始二进制数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值