欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

JavaScript怎么實(shí)現(xiàn)截屏功能

今天小編給大家分享一下JavaScript怎么實(shí)現(xiàn)截屏功能的相關(guān)知識點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

成都創(chuàng)新互聯(lián)是一家專注于成都網(wǎng)站設(shè)計、成都網(wǎng)站制作與策劃設(shè)計,新羅網(wǎng)站建設(shè)哪家好?成都創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)10年,網(wǎng)設(shè)計領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:新羅等地區(qū)。新羅做網(wǎng)站價格咨詢:18980820575

1.Blob的媒體類型必須是"image/svg+xml"

2.需要一個 svg 元素

3.在 svg 元素里面插入一個 foreignObject 元素

4.在 foreignObject 元素里面放入符合規(guī)范的 html

把dom轉(zhuǎn)成canvas就這么簡單,就上面幾個步驟。下面是文檔給出的一上簡單的demo:

<!doctype html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Document</title>
</head>
<body>
<canvas id="canvas"  width="200" height="200">
</canvas>
<script>
 var canvas = document.getElementById('canvas');
 var ctx = canvas.getContext('2d');
 var data = '<svg xmlns="http://www.w3.org/2000/svg" width="200" height="200">' +
  '<foreignObject width="100%" height="100%">' +
  '<div xmlns="http://www.w3.org/1999/xhtml" >' +
  '<em>I</em> like ' +
  '<span >' +
  'cheese</span>' +
  '</div>' +
  '</foreignObject>' +
  '</svg>';
 var DOMURL = window.URL || window.webkitURL || window;
 var img = new Image();
 var svg = new Blob([data], {type: 'image/svg+xml'});
 var url = DOMURL.createObjectURL(svg);
 img.onload = function() {
  ctx.drawImage(img, 0, 0);
  DOMURL.revokeObjectURL(url);
 }
 img.src = url;
</script>
</body>
</html>

復(fù)制代碼,運(yùn)行一下,哇,帥呆了,瀏覽器上出現(xiàn)了超酷的兩行藝術(shù)字呢!

嗯,原來dom轉(zhuǎn)成canvas這么簡單?。磕俏彝ㄟ^ document.body.innerHTML 把body里面的所有dom取出來,然后放到 foreignObject 元素里面,不就OK了、把整個頁面都截取下來了嗎?

demo僅僅是個Hello World,但是實(shí)際項目中的Dom結(jié)構(gòu)比這個復(fù)雜多了,比如,引入了外部樣式表、圖片、而且還可能某些標(biāo)簽不符合xml規(guī)范(如缺少閉合標(biāo)簽等)。下面的舉個簡單的例子,.container不是使用行內(nèi)樣式的,而是在style標(biāo)簽里面定義,字體紅色,轉(zhuǎn)成圖片后,樣式不生效。

<!doctype html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Document</title>
 <style>
  .container {
   color: red;
  }
 </style>
</head>
<body>
<div class="container" >
 Hello World!
</div>
<canvas id="canvas"  width=200" height="200">
</canvas>
<script>
 var canvas = document.getElementById('canvas');
 var ctx = canvas.getContext('2d');
 var data = '<svg xmlns="http://www.w3.org/2000/svg" width="200" height="200">' +
  '<foreignObject width="100%" height="100%">' +
  '<div xmlns="http://www.w3.org/1999/xhtml" >' +
  document.querySelector('.container').innerHTML +
  '</div>' +
  '</foreignObject>' +
  '</svg>';
 var DOMURL = window.URL || window.webkitURL || window;
 var img = new Image();
 var svg = new Blob([data], {type: 'image/svg+xml'});
 var url = DOMURL.createObjectURL(svg);
 img.onload = function() {
  ctx.drawImage(img, 0, 0);
  DOMURL.revokeObjectURL(url);
 }
 img.src = url;
</script>
</body>
</html>

既然外部樣式不生效,那我們可以通過JS遍歷所有的dom元素,把全部的樣式通過element.style對象添加到行內(nèi)樣式啊。這個思路聽起來不錯,但是,實(shí)現(xiàn)這個把外部樣式轉(zhuǎn)成行內(nèi)樣式的函數(shù)我還真寫不出來啊。需求比較緊,也沒有那 多時間去瞎折騰了,所以,就想找找有沒有現(xiàn)成的庫。于是又去google一下。很幸運(yùn), 一下子就搜到了一個叫做html2canvas的庫,非常棒的一個庫,很強(qiáng)大、但用法非常簡單.就這么簡單的方法,就可以把我的整個頁面截圖下來了:

function convertHtml2Canvas() {
  html2canvas(document.body, {
   allowTaint: false,
   taintTest: true
  }).then(function(canvas) {
   document.body.appendChild(canvas);
  }).catch(function(e) {
   console.error('error', e);
  });
 }

目前還有一個問題,就是這種方法默認(rèn)是把整個頁面截取下來的(就是說,會以你的innerHeight和innerWidth為邊界,會存在大量的空白),可是,我的卡組只是占了頁面的一小部分,我只想要卡組的部分啊。其實(shí)已經(jīng)有了canvas就好辦了,我們可以對它進(jìn)行處理啊。大概思路是:1.把上面得到的canvas對象轉(zhuǎn)成Blob并放到一個img元素。然后再把img.src繪制到canvas里面。這時候調(diào)用canvas.drawImage方法就可以截取我們想要的內(nèi)容了。下面的兩個函數(shù)分別是把canvas轉(zhuǎn)成image以及反過來把image轉(zhuǎn)成canvas。

// Converts canvas to an image
 function convertCanvasToImage(canvas) {
  var image = new Image();
  image.src = canvas.toDataURL("image/png", 0.1);
  return image;
 }
 // Converts image to canvas; returns new canvas element
 function convertImageToCanvas(image, startX, startY, width, height) {
  var canvas = document.createElement("canvas");
  canvas.width = width;
  canvas.height = height;
  canvas.getContext("2d").drawImage(image, startX, startY, width, height, 0, 0, width, height);
  return canvas;
 }

然后,再把我們上面的寫的 convertHtml2Canvas 改成下面的:

function convertHtml2Canvas() {
  html2canvas(document.body, {
   allowTaint: false,
   taintTest: true
  }).then(function(canvas) {
   var img = convertCanvasToImage(canvas);
   document.body.appendChild(img);
   img.onload = function() {
    img.onload = null;
    canvas = convertImageToCanvas(img, 0, 0, 384, 696);
    img.src = convertCanvasToImage(canvas).src;
    $(img).css({
     display: 'block',
     position: 'absolute',
     top: 0,
     left: 400 + 'px'
    });
   }
  }).catch(function(e) {
   console.error('error', e);
  });
 }

這時候就可以把它的頁面的某部分內(nèi)容進(jìn)行截取下來了。效果如卡組分享測試頁面。頁面左邊部分是DOM結(jié)構(gòu)的,右邊部分是則是使用html2canvas轉(zhuǎn)換出來的圖片。

以上就是“JavaScript怎么實(shí)現(xiàn)截屏功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學(xué)習(xí)更多的知識,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

當(dāng)前名稱:JavaScript怎么實(shí)現(xiàn)截屏功能
轉(zhuǎn)載來于:http://aaarwkj.com/article48/pjdiep.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作、用戶體驗(yàn)、域名注冊網(wǎng)站導(dǎo)航、云服務(wù)器、全網(wǎng)營銷推廣

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都app開發(fā)公司
日本理论午夜三级在线观看| 国产av网站精品成人| 国产亚洲av麻豆精品推荐| 男人天堂手机视频在线| 日本欧美亚洲一区二区三区| 99精品久久久中文字幕日本| 人妻熟女在线一区二区| 亚洲午夜天堂精品福利天堂| 青青草成年人免费视频 | 亚洲熟妇av一区二区| av基地蜜桃蜜桃蜜桃| 男人天堂av东京热伊人| 五月开心婷婷开心五月活动推荐| 五月天亚洲综合小说网| 亚洲精品你懂的av在线| 成人黄色小视频下载| 精品久久精品久久人妻九色| 亚洲欧美一区二区三区日本| 国产精品毛片一区二区三区| 欧美日韩国产天堂一区| 欧美日韩在线一区二区精品| 亚洲av乱码专区国产乱码| 激情亚洲欧美日韩精品| 精品人妻一区二区三区不卡| 麻豆av久久一区二区| 日韩暴露一区二区三区| 精品毛片久久久久久久久| 亚洲精品偷拍在线观看| 中文字幕乱码亚洲美女精品| 欧美亚洲另类国产精品| 国产精品美女黄色av| 亚洲欧美精品专区极品| 国产日韩在线不卡网站| 久久99精品人妻一区二区三区| 狼人综合狼人综合网站| 久久综合伊人欧美精品| 久久国产精品av在线观看| 国产欧美日韩亚洲精品区| 亚洲男人天堂最新地址| 久久精品一偷一偷国产| 亚洲国产中文日韩欧美在线|