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

主頁 > 知識庫 > canvas離屏技術與放大鏡實現代碼示例

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

熱門標簽:欣鼎電銷機器人 效果 惡搞電話機器人 智能電銷機器人被禁用了么 如何查看地圖標注 電話機器人技術 地圖標注軟件打印出來 ok電銷機器人 高德地圖標注商戶怎么標 黃石ai電銷機器人呼叫中心

利用 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>

實現效果如下圖所示:

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

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離屏技術與放大鏡實現代碼示例》,本文關鍵詞  canvas,離屏,技術,與,放大鏡,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《canvas離屏技術與放大鏡實現代碼示例》相關的同類信息!
  • 本頁收集關于canvas離屏技術與放大鏡實現代碼示例的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 亚洲一区精品在线| 色香色香欲天天天影视综合网 | 亚洲色图清纯唯美| 91久久香蕉国产日韩欧美9色| 一区二区三区四区在线播放| 欧美午夜精品一区| 免费在线观看成人| 久久久精品黄色| 91蜜桃免费观看视频| 亚洲成av人在线观看| 日韩欧美在线一区二区三区| 国产精品一区免费视频| 国产精品国产三级国产普通话99| 色妹子一区二区| 久久av中文字幕片| 国产精品视频九色porn| 欧美三级午夜理伦三级中视频| 免费观看一级欧美片| 国产日韩欧美亚洲| 欧洲人成人精品| 狠狠色狠狠色综合日日91app| 国产精品久线观看视频| 欧美三区免费完整视频在线观看| 毛片av一区二区| 亚洲色欲色欲www| 3atv在线一区二区三区| 成人黄色在线网站| 五月婷婷综合网| 国产精品无人区| 日韩一区二区影院| 色综合久久久久综合| 久久国内精品视频| 一区二区三区免费观看| 久久日韩精品一区二区五区| 色综合一个色综合亚洲| 精品综合久久久久久8888| 一区二区在线免费观看| 精品国产乱子伦一区| 欧美视频一区二区三区四区 | 久久免费的精品国产v∧| 在线观看国产一区二区| 成人精品高清在线| 蜜臀av一区二区在线观看| 亚洲精品欧美激情| 中文字幕乱码一区二区免费| 欧美一卡二卡三卡| 在线观看亚洲精品| av不卡一区二区三区| 国内精品视频一区二区三区八戒 | 麻豆国产精品视频| 亚洲成av人片在线| 一区二区三区在线看| 国产精品免费网站在线观看| 日韩欧美国产高清| 5858s免费视频成人| 91激情在线视频| 97超碰欧美中文字幕| 丰满放荡岳乱妇91ww| 国产伦理精品不卡| 美女视频黄 久久| 五月婷婷激情综合| 日日噜噜夜夜狠狠视频欧美人 | 一区二区理论电影在线观看| 国产精品护士白丝一区av| 337p粉嫩大胆色噜噜噜噜亚洲| 日韩精品一区二区三区视频在线观看| 欧美色区777第一页| 欧美吻胸吃奶大尺度电影 | 性做久久久久久久久| 亚洲精品ww久久久久久p站| 亚洲色图欧美偷拍| 亚洲欧美日韩国产手机在线| 国产精品卡一卡二| 亚洲免费观看高清完整版在线| 亚洲视频在线一区二区| 亚洲色图视频网站| 亚洲一区二区四区蜜桃| 亚洲午夜激情网站| 婷婷开心久久网| 日本aⅴ免费视频一区二区三区| 日本aⅴ精品一区二区三区 | 国产91在线观看丝袜| 成人高清视频在线观看| 99视频精品全部免费在线| 91偷拍与自偷拍精品| 91九色02白丝porn| 91精品国产91热久久久做人人| 91精品国产综合久久精品麻豆| 日韩午夜中文字幕| 26uuu另类欧美亚洲曰本| 欧美国产精品专区| 最近日韩中文字幕| 亚洲成人福利片| 激情成人综合网| 99re热视频精品| 欧美群妇大交群中文字幕| 欧美mv和日韩mv国产网站| 国产日韩欧美精品一区| 一区二区三区在线免费视频| 日本欧美在线看| 成人免费看片app下载| 在线精品视频小说1| 日韩免费视频一区| 欧美激情中文不卡| 天天综合天天做天天综合| 国产一区二区三区免费播放| 波多野结衣在线一区| 5566中文字幕一区二区电影| 国产欧美日韩三区| 亚洲国产日韩在线一区模特 | 蜜臀av性久久久久蜜臀aⅴ四虎| 精品一区二区久久| 欧美中文字幕亚洲一区二区va在线| 日韩午夜在线观看| 亚洲人成电影网站色mp4| 久久精品999| 欧美体内she精高潮| 国产欧美一区二区精品性| 日精品一区二区三区| 99视频超级精品| 91精品国产欧美一区二区18 | 三级久久三级久久久| 成人性视频免费网站| 3d成人动漫网站| 樱花草国产18久久久久| 国产精品亚洲成人| 91精品国产色综合久久| 亚洲精品视频在线观看免费| 国产精品亚洲第一区在线暖暖韩国| 欧美在线观看一二区| 国产精品国产三级国产aⅴ无密码| 免费在线观看一区二区三区| 欧美午夜精品理论片a级按摩| 欧美极品少妇xxxxⅹ高跟鞋| 久久国产精品99精品国产| 在线观看91精品国产入口| 国产精品视频线看| 黑人巨大精品欧美一区| 欧美日韩一区二区在线观看视频| 亚洲欧美一区二区在线观看| 国产精品一区一区三区| 精品日本一线二线三线不卡| 日韩国产欧美视频| 欧日韩精品视频| 亚洲欧美另类图片小说| 丁香一区二区三区| 国产欧美日本一区视频| 黑人精品欧美一区二区蜜桃| 欧美成人乱码一区二区三区| 美美哒免费高清在线观看视频一区二区| 欧美丝袜自拍制服另类| 亚洲精品美国一| 在线精品观看国产| 一区二区三区四区视频精品免费 | 欧美国产日韩在线观看| 国产黄色精品视频| 日本一区二区视频在线| 国产精品夜夜嗨| 中文字幕av在线一区二区三区| 国产一区二区久久| 国产色91在线| 成人污视频在线观看| 日韩一区在线看| 色94色欧美sute亚洲线路一ni| 亚洲另类色综合网站| 欧洲一区二区三区在线| 性做久久久久久久久| 日韩欧美的一区| 国产一区二区h| 国产精品欧美久久久久无广告| 成人a免费在线看| 亚洲在线免费播放| 欧美日韩极品在线观看一区| 免费观看一级欧美片| 精品国产乱码久久| 国产成人免费视| 综合色中文字幕| 欧美伦理视频网站| 久久99这里只有精品| 日本一区二区三区国色天香| 成人aaaa免费全部观看| 亚洲一区二区在线免费看| 69堂精品视频| 成人免费高清视频| 亚洲国产裸拍裸体视频在线观看乱了| 欧美日韩你懂得| 韩国午夜理伦三级不卡影院| 国产精品妹子av| 欧美亚一区二区| 国产一区二区三区黄视频| 自拍偷拍亚洲欧美日韩| 4438成人网| 99久久免费国产| 日本午夜一区二区| 中文欧美字幕免费| 69堂成人精品免费视频| 成人激情校园春色| 日产精品久久久久久久性色| 亚洲国产激情av|