亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

canvas離屏技術(shù)與放大鏡實現(xiàn)代碼示例

2024-08-26 00:20:58
字體:
供稿:網(wǎng)友

利用 canvas 除了可以實現(xiàn)濾鏡,還可以利用 離屏技術(shù) 放大鏡功能。

為了方便講解,本文分為 2 個應(yīng)用部分:

  • 實現(xiàn)水印和中心縮放
  • 實現(xiàn)放大鏡

 1. 什么是離屏技術(shù)?

canvas 學習和濾鏡實現(xiàn) 介紹過 drawImage 接口。除了繪制圖像,這個接口還可以: 將一個 canvas 對象繪制到另一個 canvas 對象上 。這就是離屏技術(shù)。

2. 實現(xiàn)水印和中心縮放

在代碼中,有兩個 canvas 標簽。分別是可見與不可見。 不可見的 canvas 對象上的 Context 對象,就是我們放置圖像水印的地方。

更多詳解,請看代碼注釋:

<!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8">  <title>Learn Canvas</title>  <style>    canvas {      display: block;      margin: 0 auto;      border: 1px solid #222;    }    input {      display: block;      margin: 20px auto;      width: 800px    }  </style></head><body>  <div id="app">    <canvas id="my-canvas"></canvas>    <input type="range" value="1.0" min="0.5" max="3.0" step="0.1">    <canvas id="watermark-canvas" style="display: none;"></canvas>  </div>  <script type="text/javascript">    window.onload = function () {      var canvas = document.querySelector("#my-canvas")      var watermarkCanvas = document.querySelector("#watermark-canvas")      var slider = document.querySelector("input")      var scale = slider.value      var ctx = canvas.getContext('2d')      var watermarkCtx = watermarkCanvas.getContext("2d")      /* 給第二個canvas獲取的Context對象添加水印 */      watermarkCanvas.width = 300      watermarkCanvas.height = 100      watermarkCtx.font = "bold 20px Arial"      watermarkCtx.lineWidth = "1"      watermarkCtx.fillStyle = "rgba(255 , 255 , 255, 0.5)"      watermarkCtx.fillText("=== yuanxin.me ===", 50, 50)      /****************************************/      var img = new Image()      img.src = "./img/photo.jpg"      /* 加載圖片后執(zhí)行操作 */      img.onload = function () {        canvas.width = img.width;        canvas.height = img.height;        drawImageByScale(canvas, ctx, img, scale, watermarkCanvas);        // 監(jiān)聽input標簽的mousemove事件        // 注意:mousemove實時監(jiān)聽值的變化,內(nèi)存消耗較大        slider.onmousemove = function () {          scale = slider.value          drawImageByScale(canvas, ctx, img, scale, watermarkCanvas);        }      }      /******************/    }    /**    *    * @param {Object} canvas 畫布對象    * @param {Object} ctx    * @param {Object} img    * @param {Number} scale 縮放比例    * @param {Object} watermark 水印對象    */    function drawImageByScale(canvas, ctx, img, scale, watermark) {      // 圖像按照比例進行縮放      var width = img.width * scale,        height = img.height * scale      // (dx, dy): 畫布上繪制img的起始坐標      var dx = canvas.width / 2 - width / 2,        dy = canvas.height / 2 - height / 2      ctx.clearRect(0, 0, canvas.width, canvas.height) // No1 清空畫布      ctx.drawImage(img, dx, dy, width, height) // No2 重新繪制圖像      if (watermark) {        // No3 判斷是否有水印: 有, 繪制水印        ctx.drawImage(watermark, canvas.width - watermark.width, canvas.height - watermark.height)      }    }  </script></body></html>

實現(xiàn)效果如下圖所示:

canvas,離屏技術(shù),放大鏡,代碼

拖動滑竿,即可放大和縮小圖像。然后右鍵保存圖像。保存后的圖像,就有已經(jīng)有了水印,如下圖所示:

canvas,離屏技術(shù),放大鏡,代碼

3. 實現(xiàn)放大鏡

在上述中心縮放的基礎(chǔ)上,實現(xiàn)放大鏡主需要注意以下 2 個部分:

  • 細化處理canvas的鼠標響應(yīng)事件:滑入、滑出、點擊和松開
  • 重新計算離屏坐標(詳細公式計算思路請見代碼注釋)
  • 重新計算鼠標相對于 canvas 標簽的坐標(詳細公式計算思路請見代碼注釋)

代碼如下:

 

<!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8">  <title>Document</title>  <style>    canvas {      display: block;      margin: 0 auto;      border: 1px solid #222;    }  </style></head><body>  <canvas id="my-canvas"></canvas>  <canvas id="off-canvas" style="display: none;"></canvas>  <script>    var isMouseDown = false,      scale = 1.0    var canvas = document.querySelector("#my-canvas")    var offCanvas = document.querySelector("#off-canvas") // 離屏 canvas    var ctx = canvas.getContext("2d")    var offCtx = offCanvas.getContext("2d") // 離屏 canvas 的 Context對象    var img = new Image()    window.onload = function () {      img.src = "./img/photo.jpg"      img.onload = function () {        canvas.width = img.width        canvas.height = img.height        offCanvas.width = img.width        offCanvas.height = img.height        // 計算縮放比例        scale = offCanvas.width / canvas.width        // 初識狀態(tài)下, 兩個canvas均繪制Image        ctx.drawImage(img, 0, 0, canvas.width, canvas.height)        offCtx.drawImage(img, 0, 0, canvas.width, canvas.height)      }      // 鼠標按下      canvas.onmousedown = function (event) {        event.preventDefault() // 禁用默認事件        var point = windowToCanvas(event.clientX, event.clientY) // 獲取鼠標相對于 canvas 標簽的坐標        isMouseDown = true        drawCanvasWithMagnifier(true, point) // 繪制在離屏canvas上繪制放大后的圖像      }      // 鼠標移動      canvas.onmousemove = function (event) {        event.preventDefault() // 禁用默認事件        if (isMouseDown === true) {          var point = windowToCanvas(event.clientX, event.clientY)          drawCanvasWithMagnifier(true, point)        }      }      // 鼠標松開      canvas.onmouseup = function (event) {        event.preventDefault() // 禁用默認事件        isMouseDown = false        drawCanvasWithMagnifier(false) // 不繪制離屏放大鏡      }      // 鼠標移出canvas標簽      canvas.onmouseout = function (event) {        event.preventDefault() // 禁用默認事件        isMouseDown = false        drawCanvasWithMagnifier(false) // 不繪制離屏放大鏡      }    }    /**    * 返回鼠標相對于canvas左上角的坐標    * @param {Number} x 鼠標的屏幕坐標x    * @param {Number} y 鼠標的屏幕坐標y    */    function windowToCanvas(x, y) {      var bbox = canvas.getBoundingClientRect() // bbox中存儲的是canvas相對于屏幕的坐標      return {        x: x - bbox.x,        y: y - bbox.y      }    }    function drawCanvasWithMagnifier(isShow, point) {      ctx.clearRect(0, 0, canvas.width, canvas.height) // 清空畫布      ctx.drawImage(img, 0, 0, canvas.width, canvas.height) // 在畫布上繪制圖像      /* 利用離屏,繪制放大鏡 */      if (isShow) {        var { x, y } = point        var mr = 50 // 正方形放大鏡邊長        // (sx, sy): 待放大圖像的開始坐標        var sx = x - mr / 2,          sy = y - mr / 2        // (dx, dy): 已放大圖像的開始坐標        var dx = x - mr,          dy = y - mr        // 將offCanvas上的(sx,sy)開始的長寬均為mr的正方形區(qū)域        // 放大到        // canvas上的(dx,dy)開始的長寬均為 2 * mr 的正方形可視區(qū)域        // 由此實現(xiàn)放大效果        ctx.drawImage(offCanvas, sx, sy, mr, mr, dx, dy, 2 * mr, 2 * mr)      }      /*********************/    }  </script></body></html>

放大鏡效果如下圖所示(被紅筆標出的區(qū)域就是我們的正方形放大鏡):

canvas,離屏技術(shù),放大鏡,代碼

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網(wǎng)。


注:相關(guān)教程知識閱讀請移步到HTML教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
精品国产第一福利网站| 97超碰人人模人人爽人人看| av在线播放不卡| 性欧美极品xxxx欧美一区二区| www.国产三级| 伊人久久大香线蕉| 国产成人精品男人的天堂538| 永久免费毛片在线播放不卡| 伊人久久亚洲| 亚洲精品一区二区三区网址| 国产麻豆精品一区| 三级网站在线看| 久久欧美中文字幕| 国产探花在线视频| 日韩av手机版| 国产激情91久久精品导航| 国产色片在线观看| 宅男在线精品国产免费观看| 日韩一级成人av| 亚洲欧美综合乱码精品成人网| 懂色av粉嫩av蜜臀av一区二区三区| 7878成人国产在线观看| 欧美日本国产精品| 好男人官网在线观看| 国产成年妇视频| 欧美又粗又硬又大久久久| 高清免费电影在线观看| 日本在线视频1区| 国产美女主播在线播放| 91网址在线播放| 粉嫩绯色av一区二区在线观看| 一区二区视频免费完整版观看| 成人动漫免费在线观看| 一区二区在线播放视频| 国产精品久久久久久久久鸭| 亚洲午夜在线视频| 国产主播欧美精品| 在线观看一区二区视频| xvideos成人免费中文版| 真不卡电影网| 欧美精品久久久久久久久25p| 黄色18在线观看| 天堂在线一二区| 色综合网站在线| 国产区在线视频| 手机在线成人免费视频| www婷婷av久久久影片| 最新黄色av网址| 91成人在线视频观看| 成人黄色激情网| 色域天天综合网| 影音成人av| 国产乱码精品一区二区三区中文| 成年人黄色在线观看| 免费在线观看一区二区三区| 国产精品露出视频| 7m精品福利视频导航| 国产精品美女呻吟| 成人观看网站a| 亚洲精品在线观看www| 制服丝袜在线一区| 亚洲字幕久久| 青青国产视频| 久久精品国产91精品亚洲| 久久久在线免费观看| 免费看黄色三级| 亚洲一区二区三区涩| 色综合网站在线| 91精品国产高清一区二区三区蜜臀| 91福利资源站| 欧美男同视频网| 天海翼在线观看视频| 亚洲精品日韩综合观看成人91| 国产一区在线观看麻豆| 91精品国产91久久久久久吃药| 北条麻妃在线观看| 久久综合88| 久久婷婷色综合| 亚洲精品成人无限看| 国内精品久久影院| 欧美一区二区黄| 欧美成人一级视频| 午夜亚洲视频| 成人免费在线视频| 麻豆传媒mv| 欧美猛男gaygay网站| 亚洲人成毛片在线播放女女| 成人在线观看a| 懂色av一区二区| 6699久久国产精品免费| 影音先锋中文在线观看| 国产91在线视频观看| 91久久高清国语自产拍| 久久九九99视频| 99国产精品一区二区| 老司机凹凸av亚洲导航| 精品一区二区三区免费毛片| 青青草原播放器| av在线免费网站| 全国精品久久少妇| 亚洲精品欧洲精品| 成人97人人超碰人人99| 亚洲精品一区二区三区不| 亚洲国产成人一区二区三区| 精品伦精品一区二区三区视频密桃| 稀缺小u女呦精品呦| 久久免费视频观看| 一本色道久久综合亚洲二区三区| 国产精品香蕉在线观看| 国产亚洲精品美女久久久久久久久久| 暗呦丨小u女国产精品| 欧美在线二区| 视频一区二区在线观看| 欧美乱强性伦xxxxx| 亚洲欧美在线观看| 制服丝袜专区在线| 精品国产免费一区二区三区| 69看片网站| 五丁香在线视频| а天堂中文最新一区二区三区| 女同性互吃奶乳免费视频| 台湾佬中文娱乐久久久| 91免费高清视频| 国产精品一卡二卡| 国产精品日韩在线观看| 一级在线视频| 久久综合九色综合网站| 1024欧美极品| 日韩精品亚洲一区二区三区免费| 亚洲精品v亚洲精品v日韩精品| 久久精品福利视频| 国产特级毛片| 欧美日韩高清一区二区不卡| 国产精品狠色婷| 亚洲精品免费网站| 日本成人手机在线| 国产亚洲人成a在线v网站| 五月婷婷激情在线| 欧美日韩免费观看一区=区三区| 精品国产乱码久久久久久浪潮| 亚洲精品综合精品自拍| 四虎精品成人a在线观看| 天天综合天天| 亚洲一区三区视频在线观看| 欧美性生活大片免费观看网址| 国内一区二区在线| 国产视频综合在线| 奇米888四色在线精品| 日本中文字幕观看| 无码人妻丰满熟妇啪啪网站| 国产欧美精品日韩精品| 国产蜜臀av在线播放| 亚洲人成网站在线播放2019| 91在线免费看| 久久久久国产精品麻豆| 日日干日日操| 无码人妻丰满熟妇啪啪网站| 久久精品成人一区二区三区蜜臀| 午夜精品成人av| 777久久久精品一区二区三区| 91福利视频在线观看| 精品国产一区二区三区久久久蜜月| 久久精品人人做人人爽电影蜜月| 国产一级片视频| www亚洲精品| 日本一区二区三区在线免费观看| 亚洲一区二区免费视频| 日本a级片视频| 亚洲手机成人高清视频| 免费成人在线看| 日本五十路在线| 欧美不卡在线视频| 亚洲av综合一区| 久久人体做爰大胆| 欧美国产综合视频| 亚洲精品午夜在线观看| 亚洲精品a级片| 成人蜜臀av电影| 老司机精品福利在线观看| 2021天堂中文幕一二区在线观| 欧美另类videoxo高潮| 91黄色精品| 中文字幕日韩精品一区| 99免费在线观看视频| 麻豆三级在线观看| 91精品福利视频| 欧美一级在线观看| 成人免费午夜电影| 一个人看的免费网站www视频| 国产一级二级毛片| 国产九一精品| 无码国产精品一区二区免费式直播| 亚洲少妇一区二区三区| 久9久9色综合| 欧美丰满美乳xxⅹ高潮www| 91牛牛免费视频| 麻豆一区产品精品蜜桃的特点| 日本午夜精品理论片a级appf发布| 国产私人影院| 中文字幕日韩高清在线| 久久久久亚洲av无码专区首jn| 久久精品成人欧美大片| 亚洲网站在线| 免费在线不卡视频| 自由日本语热亚洲人| 国产日韩欧美一区二区三区乱码| 天天操天天干天天插| 污视频在线观看网站| 99在线精品视频在线观看| 两性午夜免费视频| 欧美大黑bbbbbbbbb在线| 国产精品一区无码| 国产精品国内免费一区二区三区| 日本韩国欧美中文字幕| 国产精品一品二品| 精品国产露脸精彩对白| 国产精品美女一区二区三区四区| 国产成人99久久亚洲综合精品| 鲁丝一区二区三区免费| 青青青伊人色综合久久| 久久久免费av| 在线观看日韩欧美| 国产99久久精品一区二区| 精品久久福利| 欧美日韩麻豆| 黄网站免费在线| 国内成人自拍| 高清毛片在线观看| 中文字幕一区二区三区波野结| 成人黄视频在线观看| 先锋影音男人资源| 精品人妻一区二区乱码| 日韩三级一区二区| 国产成人一级电影| 99精品桃花视频在线观看| 亚洲天堂网一区| 美女一区二区久久| 日韩成人av电影| 欧美一区二区三区公司| 欧美亚洲精品天堂| 亚洲欧美日本视频在线观看| 高清乱码毛片入口| 国产免费一区二区三区四区五区| 欧美日韩国产一区二区三区地区| 可以免费看污视频的网站在线| 你懂的视频网| 碰草在线视频| 欧美日韩国产在线观看| 欧美精品国产精品| 国产成人精品一区二区色戒| 婷婷亚洲久悠悠色悠在线播放| 精品黑人一区二区三区国语馆| 亚洲人成毛片在线播放| 偷拍盗摄高潮叫床对白清晰| 99re6在线视频精品免费| 日本欧美久久久久免费播放网| 91社影院在线观看| 李宗瑞系列合集久久| 国产成+人+综合+亚洲欧美丁香花| 欧美日韩第一区日日骚| 另类国产精品一区二区| 7777精品伊人久久久大香线蕉经典版下载| 国产精品三级av在线播放| 精品国产乱码久久久久久夜甘婷婷| 国产草草浮力影院| 全部毛片永久免费看| 欧美大胆的人体xxxx| 欧美激情办公室videoshd| 色综合久久综合中文综合网| 日韩电影免费一区| 日韩一级视频在线观看| 久久精品国产精品亚洲红杏| 亚洲欧美在线视频| 国产亚洲精品久久久久久打不开| 99久久久久久中文字幕一区| 日韩欧美a级片| 黑人与娇小精品av专区| 亚洲深夜视频| 艳妇乳肉亭妇荡乳av| 欧美黄色免费观看| 欧美黑人性猛交xxx| 国产精品性做久久久久久| 国内精品久久久久国产| 永久看看免费大片| 亚洲成人一区二区在线观看| 51午夜精品视频| 色呦呦国产精品| 91亚洲精品久久久蜜桃| 99re91这里只有精品| 日韩欧美国产综合| 亚洲精品aⅴ| 亚洲免费网址| 99re热视频精品| 日韩精品极品在线观看播放免费视频| 无码人妻精品一区二区三区不卡| 毛片毛片毛片毛片毛片毛片| 精品午夜视频| 尤物yw午夜国产精品视频明星| 成人黄色一区二区| 亚洲一本大道在线| 青青青免费在线视频| 在线高清欧美| 99精品国自产在线| 国产成人av一区二区| 狠狠v欧美v日韩v亚洲ⅴ| 三上悠亚在线免费观看| 四虎成人影院网址| 九九热免费在线视频| 国产在线观看网站| 最新国产黄色网址| 黄污视频在线看| 日韩免费一二三区| www成人免费观看| 精品国内片67194| 黑人巨大40厘米重口ysn| 性感美女一级片| 免费精品视频一区二区三区| 97国产精品videossex| 综合精品久久久| 91香蕉在线| 日韩在线视频导航| 国产日本欧美在线| 91超碰国产在线| 少妇被躁爽到高潮无码文| 天天色天天草天天射| 午夜欧美巨大性欧美巨大| 色哟哟日韩精品| 日本天堂网在线观看|