js视频音频预加载/视频获取截图(返回canvas截图)
来源:互联网 发布:软件开发工作室名称 编辑:程序博客网 时间:2024/05/20 09:21
#load-media.js
/** * Create by Capricorncd 2017 */// 同域资源实现视频截图,可上传的图片数据格式// 非同域资源实现canvas截图预览// 提示码const CODES = { 0: 'success', 1: 'The url is not valid', 2: 'onerror'}/** * constructor * @param opts.url 音频|视频URL * @param opts.type 'audio|video' * @param opts.callback 回调函数 */function loadMedia(opts) { this.callback = opts.callback || function (res) { console.log(res); } // 初始化 this.init(opts);}// prototypeloadMedia.prototype = { /** * 初始化media * @param url */ init: function (opts) { let self = this; if (!opts.url || typeof opts.url !== 'string') { this.callback({code: 1, msg: CODES[1]}); return; } // 创建media let mediaType = opts.type === 'audio' ? 'audio' : 'video'; this.media = document.createElement(mediaType); console.log('this.media', this.media); // loaded this.listener('canplaythrough', function (e) { // 截图 if (mediaType === 'video') { self.screenshot(); } else { self.callback({ code: 0, msg: CODES[0], thumb: null, media: this.media, canvas: null }); } }); // error this.listener('error', function (e) { self.callback({code: 2, msg: CODES[2], data: e}); }) this.media.setAttribute('src', opts.url); }, screenshot: function () { // create canvas let canvas = document.createElement('canvas'); canvas.width = this.media.videoWidth; canvas.height = this.media.videoHeight; let ctx = canvas.getContext('2d'); // 截取 ctx.drawImage(this.media, 0, 0); let thumb = null; // 非跨域资源 // !!非同域资源无法获取数据 try { let type = 'image/png'; let data = canvas.toDataURL(type); thumb = this.toBlobData(data, type); } catch (e) {} this.callback({ code: 0, msg: CODES[0], thumb: thumb, media: this.media, canvas: canvas }) }, // 数据转换 toBlobData: function (data, type) { // 获取base64数据 // base64数据格式: // "data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEASABIAAD/2wBDAAkGB+wgHBgkIBwgKCgkLDRYPDQw//9k=" data = window.atob(data.split(',')[1]); let ia = new Uint8Array(data.length); for (let i = 0; i < data.length; i++) { ia[i] = data.charCodeAt(i); }; // canvas.toDataURL 返回的默认格式是 image/png return new Blob([ia], {type: type}); }, /** * addEventListener 事件监听 * @param en EventName * @param callback */ listener: function (en, callback) { this.media.addEventListener(en, function (e) { if (callback) { callback(e); } else { console.warn(this); } }, false); } /** * 资源是否跨域 * @param url 资源地址 * @returns {boolean} */ // isCrossDomain: function (url) { // let loc, host, protocol; // loc = window.location; // host = loc.host; // protocol = loc.protocol; // // 是否为http链接 // if (/(http|https):\/\//.test(url)) { // if (url.indexOf(protocol + '//' + host) >= 0) { // return false; // } else { // return true; // } // } // // './xxx.mp4' '/xxx.mp4' 'xxx.mp4' // return false; // }}export default loadMedia;// 参考资料// HTML5的Video标签的属性,方法和事件汇总// http://www.cnblogs.com/TF12138/p/4448108.html
# 使用
import loadMedia from '@/common/js/load-media'let loadVideo = new loadMedia({ type: 'video', url: 'http://xmqvip1-1253933147.file.myqcloud.com/chat/video/60/2017/09/29/qgj1c8K7oaYn-SCVideo-Merged.mp4', callback: handleCallback})function handleCallback (res) { console.log(res) // canplaythrough if (res.code === 0) { } // error if (res.code === 2) { } }
阅读全文
0 0
- js视频音频预加载/视频获取截图(返回canvas截图)
- 视频截图(转)
- 视频截图
- 视频 截图
- 视频截图
- 视频截图
- 视频截图
- 用canvas做视频截图遇到的坑(已填坑)
- canvas+video实现跨域视频截图
- canvas与html5实现视频截图功能
- Iphone5S 体验(视频+截图)
- iOS获取视频图片(视屏截图)
- iOS获取某一时间点视频桢截图
- js+HTML5实现视频截图的方法
- node.js 实现html5视频播放截图
- ios开发之Swift获取视频截图(本地视频、网络视频的缩略图)(转)
- Swift - 获取视频截图(本地视频、网络视频的缩略图)
- ios开发之Swift获取视频截图(本地视频、网络视频的缩略图)
- 良心教程:用户交互的黑科技ARKitQQQ1
- zTree:实现单选/取消父子关联等
- Git和gitHub
- log4j加载配置方式和配置详解
- 自定义view 生成随机数
- js视频音频预加载/视频获取截图(返回canvas截图)
- Android 自定义控件实现圆形进度条
- Linux 创建用户的同时设置密码
- 舒适的Linux中文环境——Manjaro Deepin工作环境配置
- linux 下创建 用户 groupadd useradd 命令使用
- 量化投资(一):十行代码实现一个量化交易入门程序
- Android自定义View--初出茅庐
- Java提高篇(36)--线程的生命周期
- Mac上的应用,例如Xcode需要输入原始下载账号才能更新问题