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

首頁 > 編程 > HTML > 正文

canvas離屏技術與放大鏡實現代碼示例

2024-08-26 00:20:58
字體:
來源:轉載
供稿:網友

利用 canvas 除了可以實現濾鏡,還可以利用 離屏技術 放大鏡功能。

為了方便講解,本文分為 2 個應用部分:

  • 實現水印和中心縮放
  • 實現放大鏡

 1. 什么是離屏技術?

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

2. 實現水印和中心縮放

在代碼中,有兩個 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"      /* 加載圖片后執行操作 */      img.onload = function () {        canvas.width = img.width;        canvas.height = img.height;        drawImageByScale(canvas, ctx, img, scale, watermarkCanvas);        // 監聽input標簽的mousemove事件        // 注意:mousemove實時監聽值的變化,內存消耗較大        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>

實現效果如下圖所示:

canvas,離屏技術,放大鏡,代碼

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

canvas,離屏技術,放大鏡,代碼

3. 實現放大鏡

在上述中心縮放的基礎上,實現放大鏡主需要注意以下 2 個部分:

  • 細化處理canvas的鼠標響應事件:滑入、滑出、點擊和松開
  • 重新計算離屏坐標(詳細公式計算思路請見代碼注釋)
  • 重新計算鼠標相對于 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        // 初識狀態下, 兩個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的正方形區域        // 放大到        // canvas上的(dx,dy)開始的長寬均為 2 * mr 的正方形可視區域        // 由此實現放大效果        ctx.drawImage(offCanvas, sx, sy, mr, mr, dx, dy, 2 * mr, 2 * mr)      }      /*********************/    }  </script></body></html>

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

canvas,離屏技術,放大鏡,代碼

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


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
一区二区三区日韩在线| 久久精品视频亚洲| 欧美视频免费在线观看| 亚洲欧美另类国产| 亚洲亚裔videos黑人hd| 欧美香蕉大胸在线视频观看| 九色成人免费视频| 欧美一级高清免费播放| 欧美乱大交做爰xxxⅹ性3| 欧美激情手机在线视频| 日韩经典中文字幕| 国产精品你懂得| 亚洲视频第一页| 九九热这里只有精品免费看| 久久精品亚洲热| 亚洲色图日韩av| 午夜精品久久久久久99热软件| 日韩中文字幕欧美| 国外视频精品毛片| 亚洲激情 国产| 精品一区二区三区四区在线| 亚洲人a成www在线影院| 欧美中文在线观看| 欧美激情精品久久久久久| 国产成人精品综合| 美女精品久久久| 国产精品一区二区久久| 欧美怡春院一区二区三区| 亚洲天堂av高清| 国产精品成人aaaaa网站| 国产精自产拍久久久久久| 欧美日韩爱爱视频| 久久国产精品久久久久久| 欧美在线观看网站| 国产精品三级网站| 亚洲香蕉成视频在线观看| 久久人人爽人人爽爽久久| 精品久久久久久久久国产字幕| 欧美专区在线播放| 亚洲成色www8888| 国产综合色香蕉精品| 国产精品自产拍高潮在线观看| 国产精品久在线观看| 日韩成人在线网站| 亚洲丝袜av一区| 66m—66摸成人免费视频| 欧美激情2020午夜免费观看| 亚洲成人激情在线观看| 91tv亚洲精品香蕉国产一区7ujn| 久久91精品国产| 欧美成人国产va精品日本一级| 日韩精品极品在线观看| 久久高清视频免费| 亚洲国产欧美一区二区三区同亚洲| 欧美激情综合亚洲一二区| 欧美性猛交xxx| 色偷偷噜噜噜亚洲男人的天堂| 日韩在线观看免费av| 日本精品一区二区三区在线| 久久久精品网站| 国产精品亚洲美女av网站| 亚洲美女在线观看| 亚洲成色999久久网站| 国产+人+亚洲| 日韩av在线电影网| 久久久国产在线视频| 亚洲精品第一国产综合精品| 久久噜噜噜精品国产亚洲综合| 91免费精品国偷自产在线| 亚洲欧美日韩天堂| 日韩精品免费观看| 日本免费一区二区三区视频观看| 九九综合九九综合| 91视频国产精品| 亚洲精品久久久久中文字幕欢迎你| 国产日韩精品在线播放| 91在线观看免费网站| 亚洲精品欧美一区二区三区| 久久躁狠狠躁夜夜爽| 日本一区二区在线免费播放| 国产伦精品一区二区三区精品视频| 亚洲国产成人精品久久久国产成人一区| 黄色一区二区在线观看| 日韩精品视频免费在线观看| 久久久亚洲福利精品午夜| 97超级碰碰碰| 57pao成人永久免费视频| 亚洲а∨天堂久久精品喷水| 日韩精品视频在线观看免费| 亚洲福利在线观看| 97在线免费视频| 日韩女优在线播放| 色悠久久久久综合先锋影音下载| 欧美精品videossex88| 992tv成人免费影院| 欧美wwwxxxx| 777国产偷窥盗摄精品视频| 亚洲高清免费观看高清完整版| 久久久久久噜噜噜久久久精品| 欧美激情免费在线| 亚洲成人999| 欧美大尺度在线观看| 欧美成人高清视频| 亚洲欧美日韩高清| 亚洲乱码国产乱码精品精天堂| 亚洲bt天天射| 欧美激情视频网址| 视频在线观看一区二区| 日韩av有码在线| 日韩av一区二区在线观看| 日韩高清免费观看| 欧美成人精品一区二区| 日韩中文字幕在线看| 亚洲专区在线视频| 操91在线视频| 亚洲欧美综合精品久久成人| 亚洲日本中文字幕| 国产91精品黑色丝袜高跟鞋| 欧美大片在线影院| 57pao成人国产永久免费| 国产欧美精品xxxx另类| 国产精品色视频| 国产精品女主播视频| 国产精品福利网| 亚洲性生活视频在线观看| 久久久久久久久久久免费| 亚洲精品xxxx| 在线精品播放av| 91国偷自产一区二区三区的观看方式| 亚洲人在线视频| 国产精品96久久久久久又黄又硬| 黄色一区二区在线| 久久久最新网址| 国产精品久久一区主播| 亚洲国产精彩中文乱码av在线播放| 国产精品日韩欧美综合| 国产性猛交xxxx免费看久久| 91精品国产综合久久香蕉最新版| 91亚洲精品一区| 国产精品一香蕉国产线看观看| 91久久久在线| 日本精品一区二区三区在线播放视频| 91色琪琪电影亚洲精品久久| 在线播放日韩专区| 日本一区二区在线播放| 国产免费观看久久黄| 精品久久久久久久久久久久久久| 色婷婷久久一区二区| 国产精品久久久久免费a∨大胸| 51久久精品夜色国产麻豆| www国产精品com| 亚洲欧美日韩高清| 日韩在线视频线视频免费网站| 成人黄色av播放免费| 欧美日韩午夜剧场| 久久久久久成人| 日韩精品免费视频| 国产有码一区二区| 国产mv久久久| 亚洲一区二区三区乱码aⅴ蜜桃女| 91精品国产自产在线观看永久| 久久国产精品免费视频| 久久大大胆人体| 中文字幕精品国产|