婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > video結合canvas實現視頻在線截圖功能

video結合canvas實現視頻在線截圖功能

熱門標簽:濟南辦理400電話 ai電銷機器人連接網關 鄭州電銷外呼系統違法嗎 農村住宅地圖標注 威海營銷外呼系統招商 漳州人工外呼系統排名 中紳電銷智能機器人 跟電銷機器人做同事 鶴壁手機自動外呼系統怎么安裝

給大家講解下我前幾天看到的一個有趣小demo:視頻在線截圖。以下是我修改和添加了新功能后的效果圖:

 

是不是很酷,其實挺簡單的,下面就給大家講講怎么弄哈。

這里主要分為三大塊功能,首先是第一個:

利用URL對象獲取視頻鏈接并展示:

js的URL對象有個 createObjectURL 方法,它可以獲取一個文件(File對象)的url,然后插入到 video 元素的 src 特性中,這樣就可以實現視屏的展示了。當然如何獲取File對象呢,方法有種,比如使用input元素,或者使用拖動的方式。一個完整的代碼段:

<input type="file"/>
document.querySelector('input[type="file"]').addEventListener('change',function () {
    document.querySelector('video').src = window.URL.createObjectURL(this.files[0])
})

當然源碼中我并不是這樣寫的,僅僅是為了給大家一個演示而已。關于URL更加具體的使用,大家可以看看這篇文章或者MDN。

利用canvas實現視頻截圖:

接下來就是關鍵步驟了,但也很簡單,那就是使用 canvas 的 drawImage 方法,大家如果翻到高程三的第15.2.6節,就會發現 drawImage 的方法的使用描述得非常詳細,但漏講了一個,那就是 video 元素也可傳入 drawImage 方法中,并且繪制圖形。具體代碼段:

var canvas = document.createElement("canvas");
var canvasCtx = canvas.getContext("2d");
var video=document.querySelector('video');
//坐原圖像的x,y軸坐標,大小,目標圖像的x,y軸標,大小。
canvasCtx.drawImage(video, 0, 0, videoWidth, videoHeight, 0, 0, imgWidth, imgHeight);
//把圖標base64編碼后變成一段url字符串
var dataUrl = canvas.toDataURL("image/png");
//插入圖片得src特性中
document.createElement('img').src=dataUrl;

繪制完成圖像后,再調用 canvas 的 toDataURl 方法把圖像變成 base64 編碼的url,就可插入到 img 元素中展示,一個縮略的圖的制作便完成了。關于圖片和base64的關系,具體的同學們可以看下這篇文章。

實現動畫效果:

該動畫實現的主要原理是:先在視頻原處創建一張大小和視頻一致的大圖片,設置為絕對布局( position:absolut ),在實際放置縮略圖處創建一張小圖片,設置為不可見( visibility:hidden ),然后大圖片通過 left 和 top 實現位移, width 和 height 實現縮小,至實際放置縮略圖處,并形成動畫效果。最后大圖片刪除,小圖片顯示即可。具體代碼段:

function getOffset(elem) {
    var pos = {x: elem.offsetLeft, y: elem.offsetTop};
    var offsetParent = elem.offsetParent;
    while (offsetParent) {
        pos.x += offsetParent.offsetLeft;
        pos.y += offsetParent.offsetTop;
        offsetParent = offsetParent.offsetParent;
    }
    return pos;
}

該函數是獲取小圖片距viewport(視口)的距離,并提供給大圖片作為位移參數的,高程三的12.2.3節有段幾乎一模一樣的代碼,并附有詳細說明,以及替代方案 getBoundingClientRect 函數也有提到,具體的大家翻書看看哈。

下面的代碼便是創建大圖片和小圖片并實現動畫效果了。為了方便易懂,我這兒使用了JQuery

var $imgBig = $("<img/>");
//設置大圖片的初始位置,就是原視頻處。
$imgBig.css({
    position: "absolute",
    left: video.offsetLeft,
    top: video.offsetTop,
    width: video.offsetWidth+ "px",
    height: video.offsetHeight+ "px"
}).attr("src", dataUrl);
var $img = $("<img/>");
$img.hide();
//獲取小圖片的距離參數,實現大圖片的動畫效果。
var offset = getOffset($img[0]);
//添加動畫效果
$imgBig.animate({
    left: offset.x + "px",
    top: offset.y + "px",
    width: $img.width() + "px",
    height: $img.height() + "px"
}, 500, function () {
    $img.show();
    $imgBig.remove();
});

 

恩恩,主要的代碼部分到這就講完啦,當然具體的實現還有很多細節上的問題以及其他的功能可能沒有展示,我就不一一說明了,具體的大家看完源碼后可以再提問。

下面是我的源碼地址,大家可以試試哈:

在github上的demo

總結

以上所述是小編給大家介紹的video結合canvas實現視頻在線截圖功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

標簽:咸陽 營口 甘南 紅河 惠州 蘇州 萍鄉 文山

巨人網絡通訊聲明:本文標題《video結合canvas實現視頻在線截圖功能》,本文關鍵詞  video,結合,canvas,實現,視頻,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《video結合canvas實現視頻在線截圖功能》相關的同類信息!
  • 本頁收集關于video結合canvas實現視頻在線截圖功能的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产制服丝袜一区| 91电影在线观看| 奇米精品一区二区三区在线观看| 中文字幕一区二区不卡| 欧美在线|欧美| av中文字幕在线不卡| 91精品福利视频| 欧美色网站导航| 欧美三级电影在线看| 欧美午夜片在线看| 欧美群妇大交群中文字幕| 在线观看亚洲专区| 欧美精品xxxxbbbb| 欧美一区二区三区四区高清| 欧美一区二区三区免费在线看 | 国产精品资源在线观看| 久久99精品国产.久久久久久| 精品一区二区三区蜜桃| 国产成人免费高清| 91麻豆自制传媒国产之光| 久久久亚洲国产美女国产盗摄| 91亚洲国产成人精品一区二区三| 日韩限制级电影在线观看| 91精品国产91热久久久做人人| 91精品国产综合久久香蕉麻豆| 欧美电影免费观看高清完整版在| 国产农村妇女毛片精品久久麻豆| 亚洲男人电影天堂| 奇米777欧美一区二区| 成人午夜电影网站| 69堂精品视频| 中文字幕不卡一区| 日韩影院精彩在线| av亚洲精华国产精华精| 制服丝袜中文字幕一区| 欧美国产精品劲爆| 欧美aaa在线| 91成人免费网站| 久久久国产综合精品女国产盗摄| 中文幕一区二区三区久久蜜桃| 亚洲高清不卡在线| 国产·精品毛片| 欧美一级视频精品观看| 亚洲人成网站色在线观看| 狠狠色狠狠色综合系列| 欧美三级蜜桃2在线观看| 欧美国产综合色视频| 麻豆精品视频在线观看免费| 91成人国产精品| 国产精品成人免费| 国产精品一区免费视频| 欧美一级一区二区| 婷婷中文字幕一区三区| 91网站最新地址| 国产精品久久久久久久裸模| 精品一区二区影视| 欧美日韩精品是欧美日韩精品| 日本一区二区三区久久久久久久久不 | 一区二区三区在线影院| 国产99精品视频| 欧美精品一区二区三区视频| 五月激情综合网| 欧美日韩三级一区| 亚洲美女视频在线| 91玉足脚交白嫩脚丫在线播放| 欧美国产亚洲另类动漫| 国产精品18久久久久| 亚洲精品一区二区三区在线观看 | 综合在线观看色| 成人免费视频caoporn| 国产视频一区在线播放| 国产成人av影院| 久久久不卡网国产精品二区| 久久国产日韩欧美精品| 精品少妇一区二区三区在线视频| 日韩国产欧美一区二区三区| 337p亚洲精品色噜噜| 另类小说图片综合网| 精品国产网站在线观看| 国产精品亚洲成人| 国产精品福利一区二区| 一本久久a久久免费精品不卡| 亚洲女爱视频在线| 欧洲视频一区二区| 亚洲地区一二三色| 日韩女优电影在线观看| 国产乱子伦视频一区二区三区| 久久久精品一品道一区| 99精品视频在线免费观看| 一区二区成人在线| 日韩美女主播在线视频一区二区三区| 久久精品国产精品亚洲红杏| 国产无人区一区二区三区| 成人高清免费在线播放| 亚洲第一综合色| 久久久综合激的五月天| 91色视频在线| 免费观看在线色综合| 亚洲国产精品成人综合 | 亚洲情趣在线观看| 日韩亚洲欧美成人一区| 成人开心网精品视频| 婷婷国产v国产偷v亚洲高清| 精品国产亚洲在线| 欧美色视频一区| 国产99久久久精品| 性做久久久久久久免费看| 精品成人在线观看| 欧美性视频一区二区三区| 久久成人免费网| 玉米视频成人免费看| 欧美大片在线观看一区| 日本久久电影网| 精品无人码麻豆乱码1区2区 | 国产精品每日更新| 欧美一区二区性放荡片| 99久久精品一区| 日本不卡高清视频| 亚洲色图在线视频| 久久久综合视频| 日韩一区二区三区电影在线观看 | 老司机精品视频一区二区三区| 中文字幕视频一区| 国产午夜精品美女毛片视频| 欧美丰满美乳xxx高潮www| 91亚洲午夜精品久久久久久| 国产精品一区2区| 青娱乐精品视频在线| 亚洲动漫第一页| 亚洲欧美偷拍卡通变态| 国产女人18毛片水真多成人如厕 | 久久久综合激的五月天| 日韩一区二区视频在线观看| 色爱区综合激月婷婷| 成人av在线播放网址| 国产乱子轮精品视频| 日韩av高清在线观看| 亚洲图片你懂的| 亚洲理论在线观看| 精品国产一区久久| 国产凹凸在线观看一区二区| 亚洲色图视频免费播放| 精品亚洲aⅴ乱码一区二区三区| 一区二区三区欧美日| 成人欧美一区二区三区| 国产亚洲欧美日韩俺去了| 精品国产三级电影在线观看| 日韩欧美一级二级三级久久久| 欧美亚洲综合久久| 欧美视频精品在线观看| 欧美日韩国产高清一区| 欧美日韩精品电影| 欧美日韩小视频| 欧美欧美欧美欧美| 678五月天丁香亚洲综合网| 538在线一区二区精品国产| 欧美精品少妇一区二区三区| 欧美三级日韩三级| 宅男在线国产精品| 午夜精品免费在线| 成人精品视频一区二区三区| 中文字幕在线不卡视频| 国产亚洲美州欧州综合国| 国产午夜精品一区二区三区嫩草| 中文字幕欧美三区| 国产精品的网站| 国产精品久久三| 一区二区三区中文在线观看| 亚洲综合精品自拍| 美国毛片一区二区三区| 成人综合婷婷国产精品久久| 日本道色综合久久| 91麻豆精品国产91久久久久久| 精品噜噜噜噜久久久久久久久试看| 久久亚洲一区二区三区四区| 国产精品国产自产拍高清av王其| 亚洲精品福利视频网站| 美女一区二区在线观看| 99久久国产综合色|国产精品| 欧美日本一道本在线视频| 国产午夜精品久久久久久久 | 亚洲欧美日韩在线不卡| 亚洲电影一级片| 国产美女精品人人做人人爽 | 国产精品一区在线观看你懂的| 91视频一区二区| 精品久久久久99| 亚洲三级在线免费| 国产麻豆精品久久一二三| 欧美网站一区二区| 国产日韩精品一区二区三区| 亚洲综合在线视频| 成人免费视频一区二区| 欧美绝品在线观看成人午夜影视| 国产清纯美女被跳蛋高潮一区二区久久w| 一区二区在线观看av| 高清国产午夜精品久久久久久| 欧美日高清视频| 亚洲日本免费电影| 成人激情图片网|