Malunan个人博客|IT技术博客 Malunan个人博客|IT技术博客
首页
  • 前端文章

    • JavaScript
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • 《Git》
    • TypeScript
    • JS设计模式总结
    • HTML
    • CSS
  • 技术文档
  • GitHub技巧
  • Nodejs
  • 博客搭建
  • 脚本
  • 剪辑
关于
  • 网站
  • 常用的前端轮子
  • 工具网站
  • 软件工具
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

Lunan Ma

升职加薪搞钱~
首页
  • 前端文章

    • JavaScript
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • 《Git》
    • TypeScript
    • JS设计模式总结
    • HTML
    • CSS
  • 技术文档
  • GitHub技巧
  • Nodejs
  • 博客搭建
  • 脚本
  • 剪辑
关于
  • 网站
  • 常用的前端轮子
  • 工具网站
  • 软件工具
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • 技术文档

    • Git使用手册
    • Markdown使用教程
    • npm常用命令
    • 移动端兼容问题
    • 常用cmd命令
    • npm packageJson属性详解
    • yaml语言教程
    • Git修改分支名
    • javaScript-时间相加,超过24小时继续累加
    • 获取视频文件第一帧
      • 需求
      • 解决
    • 前端获取文件下载进度
    • 前端获取上传的视频图片详细信息
    • 解决拖拽时,如果元素内有input,无法选中文本的问题
    • css点击穿透
    • vue插槽传参
    • 谷歌浏览器的kiosk模式
    • 前台下载后台返的二进制文件流
    • css实现无缝切换跑马灯样式
    • 前端优化规范
    • 懒加载+无感删除list思路
  • GitHub技巧

  • Nodejs

  • 博客搭建

  • 脚本

  • 技术
  • 技术文档
MaLunan
2024-02-29
目录

获取视频文件第一帧

# 需求

在前端上传视频时,同时截取第一帧作为封面

# 解决

// oneImgUtil.js
// 封装utils
// 获取视频文件第一帧
export function oneImgUtil(file) {
  return new Promise((resolve, reject) => {
    // 创建一个 <video> 元素
    const video = document.createElement('video')
    video.setAttribute('crossOrigin', 'anonymous')
    video.currentTime = 1 //currentTime 属性设置或返回视频播放的当前位置(以秒计)   重要!不设置会导致第一帧图片不显示
    // 监听视频加载完成事件
    video.addEventListener('loadeddata', function () {
      // 将视频的第一帧绘制到 canvas 上
    // 定时器兼容edag,解决edag截取的第一帧白屏问题
      setTimeout(()=>{
        // 创建一个 <canvas> 元素
        const canvas = document.createElement('canvas')
        const context = canvas.getContext('2d')

        // 设置 canvas 的宽高与视频的宽高相同
        canvas.width = video.videoWidth
        canvas.height = video.videoHeight

        //   setTimeout(()=>{
        context.drawImage(video, 0, 0, canvas.width, canvas.height)

        // 将 canvas 转换为图片并显示
        const dataURL = canvas.toDataURL() // 默认格式为 PNG
        let files = setFile(dataURL)
        resolve(files)
      },1000)
    })

    // 选择用户上传的视频文件
    function changeImg(file) {
      // 读取视频文件并将其赋值给 <video> 元素的 src 属性
      const reader = new FileReader()
      reader.onload = function (e) {
        video.src = e.target.result
      }
      reader.readAsDataURL(file)
    }
    changeImg(file)
  })
}

// base64转换file
function setFile(base64) {
  const arr = base64.split(',')
  const type = arr[0].match(/:(.*?);/)[1]
  const size = window.atob(arr[1])
  let n = size.length
  const u8arr = new Uint8Array(n)
  while (n--) {
    u8arr[n] = size.charCodeAt(n)
  }
  return new File([u8arr], Date.now(), { type })
}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58

引入使用

import { oneImgUtil } from '@/utils/oneImgUtil.js'
oneImgUtil(file).then(res=>{
  console.log(res)//第一帧图片的file
})
1
2
3
4
编辑 (opens new window)
上次更新: 2024/02/29, 15:10:43
javaScript-时间相加,超过24小时继续累加
前端获取文件下载进度

← javaScript-时间相加,超过24小时继续累加 前端获取文件下载进度→

最近更新
01
懒加载+无感删除list思路
11-12
02
移动端兼容问题
11-12
03
前端优化规范
03-25
更多文章>
Theme by Vdoing | Copyright © 2019-2024 LuNan Ma | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式