成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁(yè) > 知識(shí)庫(kù) > canvas離屏技術(shù)與放大鏡實(shí)現(xiàn)代碼示例

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

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

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

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

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

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

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

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

在代碼中,有兩個(gè) canvas 標(biāo)簽。分別是可見(jiàn)與不可見(jiàn)。 不可見(jiàn)的 canvas 對(duì)象上的 Context 對(duì)象,就是我們放置圖像水印的地方。

更多詳解,請(qǐng)看代碼注釋:

<!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")

      /* 給第二個(gè)canvas獲取的Context對(duì)象添加水印 */
      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)聽(tīng)input標(biāo)簽的mousemove事件
        // 注意:mousemove實(shí)時(shí)監(jiān)聽(tīng)值的變化,內(nèi)存消耗較大
        slider.onmousemove = function () {
          scale = slider.value
          drawImageByScale(canvas, ctx, img, scale, watermarkCanvas);
        }
      }
      /******************/
    }
    /**
    *
    * @param {Object} canvas 畫布對(duì)象
    * @param {Object} ctx
    * @param {Object} img
    * @param {Number} scale 縮放比例
    * @param {Object} watermark 水印對(duì)象
    */
    function drawImageByScale(canvas, ctx, img, scale, watermark) {
      // 圖像按照比例進(jìn)行縮放
      var width = img.width * scale,
        height = img.height * scale
      // (dx, dy): 畫布上繪制img的起始坐標(biāo)
      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>

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

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

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

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

  • 細(xì)化處理canvas的鼠標(biāo)響應(yīng)事件:滑入、滑出、點(diǎn)擊和松開(kāi)
  • 重新計(jì)算離屏坐標(biāo)(詳細(xì)公式計(jì)算思路請(qǐng)見(jiàn)代碼注釋)
  • 重新計(jì)算鼠標(biāo)相對(duì)于 canvas 標(biāo)簽的坐標(biāo)(詳細(xì)公式計(jì)算思路請(qǐng)見(jiàn)代碼注釋)

代碼如下:

 

<!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對(duì)象
    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

        // 計(jì)算縮放比例
        scale = offCanvas.width / canvas.width

        // 初識(shí)狀態(tài)下, 兩個(gè)canvas均繪制Image
        ctx.drawImage(img, 0, 0, canvas.width, canvas.height)
        offCtx.drawImage(img, 0, 0, canvas.width, canvas.height)

      }

      // 鼠標(biāo)按下
      canvas.onmousedown = function (event) {
        event.preventDefault() // 禁用默認(rèn)事件
        var point = windowToCanvas(event.clientX, event.clientY) // 獲取鼠標(biāo)相對(duì)于 canvas 標(biāo)簽的坐標(biāo)
        isMouseDown = true
        drawCanvasWithMagnifier(true, point) // 繪制在離屏canvas上繪制放大后的圖像
      }

      // 鼠標(biāo)移動(dòng)
      canvas.onmousemove = function (event) {
        event.preventDefault() // 禁用默認(rèn)事件
        if (isMouseDown === true) {
          var point = windowToCanvas(event.clientX, event.clientY)
          drawCanvasWithMagnifier(true, point)
        }
      }

      // 鼠標(biāo)松開(kāi)
      canvas.onmouseup = function (event) {
        event.preventDefault() // 禁用默認(rèn)事件
        isMouseDown = false
        drawCanvasWithMagnifier(false) // 不繪制離屏放大鏡
      }

      // 鼠標(biāo)移出canvas標(biāo)簽
      canvas.onmouseout = function (event) {
        event.preventDefault() // 禁用默認(rèn)事件
        isMouseDown = false
        drawCanvasWithMagnifier(false) // 不繪制離屏放大鏡
      }
    }

    /**
    * 返回鼠標(biāo)相對(duì)于canvas左上角的坐標(biāo)
    * @param {Number} x 鼠標(biāo)的屏幕坐標(biāo)x
    * @param {Number} y 鼠標(biāo)的屏幕坐標(biāo)y
    */
    function windowToCanvas(x, y) {
      var bbox = canvas.getBoundingClientRect() // bbox中存儲(chǔ)的是canvas相對(duì)于屏幕的坐標(biāo)
      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 // 正方形放大鏡邊長(zhǎng)

        // (sx, sy): 待放大圖像的開(kāi)始坐標(biāo)
        var sx = x - mr / 2,
          sy = y - mr / 2

        // (dx, dy): 已放大圖像的開(kāi)始坐標(biāo)
        var dx = x - mr,
          dy = y - mr

        // 將offCanvas上的(sx,sy)開(kāi)始的長(zhǎng)寬均為mr的正方形區(qū)域
        // 放大到
        // canvas上的(dx,dy)開(kāi)始的長(zhǎng)寬均為 2 * mr 的正方形可視區(qū)域
        // 由此實(shí)現(xiàn)放大效果
        ctx.drawImage(offCanvas, sx, sy, mr, mr, dx, dy, 2 * mr, 2 * mr)
      }
      /*********************/
    }
  </script>
</body>
</html>

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:阿壩 綏化 萍鄉(xiāng) 盤錦 聊城 金昌 赤峰 中山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《canvas離屏技術(shù)與放大鏡實(shí)現(xiàn)代碼示例》,本文關(guān)鍵詞  canvas,離屏,技術(shù),與,放大鏡,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《canvas離屏技術(shù)與放大鏡實(shí)現(xiàn)代碼示例》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于canvas離屏技術(shù)與放大鏡實(shí)現(xiàn)代碼示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    国产.精品.日韩.另类.中文.在线.播放| 黄瓜视频网站| 成人国产亚洲欧美成人综合网| 久久精品一区二区三区不卡| 麻豆精品在线播放| 亚洲中文字幕无码中文字| 欧美日韩大片在线观看| 九九热视频这里只有精品| 日本福利专区在线观看| 成人黄色av播放免费| 亚洲高清在线不卡| 日韩精品在线免费视频| 久久久国产精品无码| 午夜精品一区二区三区国产| 在线一区视频| 日韩精品视频在线免费观看| 国产亚洲福利| 91午夜理伦私人影院| 婷婷综合一区| 97影视在线观看| 波多野结衣在线影院| 禁果av一区二区三区| 超碰在线网址| 午夜精品久久久久久久男人的天堂| 成人精品在线视频观看| 黑人巨大精品欧美| 国产视频不卡在线| 久久久久免费av| 麻豆国产精品va在线观看不卡| 精品丰满人妻无套内射| av激情亚洲男人天堂| 性欧美成人播放77777| 在线精品视频小说1| 欧美视频13p| 日本动漫理论片在线观看网站| 午夜成人免费电影| 成人福利电影精品一区二区在线观看| 四虎海外影库www4hu| avlululu| 国产精品亚洲片夜色在线| 亚洲精品久久久久久| 久久久久久久影视| 国产精品大陆在线观看| 亚洲欧美精品久久| 日韩第一页在线| av亚洲一区| 九一久久久久久| 日韩一二三在线视频播| 日韩精品亚洲一区二区三区免费| 日韩欧美成人免费视频| 久久99国产精品久久99果冻传媒| 亚洲激情欧美| 天堂www在线а√天堂| 免费黄色大片| 欧美猛交ⅹxxx乱大交视频| 欧美不卡1区2区3区| 欧美图片第一页| 欧美精品www在线观看| 777片理伦片在线观看| 亚洲成国产人片在线观看| 99久久久久免费精品国产| 亚洲欧美日韩一区二区三区四区| 午夜老司机精品| 亚洲精品福利免费在线观看| 99国产精品视频免费观看| 不卡一区二区在线| 精品盗摄女厕tp美女嘘嘘| 中文字幕五月欧美| 国产日韩欧美一区二区| 日韩美女精品| 色先锋av资源| 亚洲成av人电影| 精品国产福利| 97视频在线观看网站| 欧美一级大片在线视频| 精品欧美国产一区二区三区| 久久视频国产| 竹内纱里奈兽皇系列在线观看| 精品欧美国产一区二区三区| 久久亚洲私人国产精品va媚药| 亚洲美女啪啪| 成人一级生活片| 亚洲成人精品女人久久久| 久久精品国产精品亚洲精品色| 国产午夜精品免费一区二区三区| 成人精品视频在线播放| 怡红院男人的天堂| 特种兵之深入敌后| 奇米影音第四色| 国产日韩精品一区二区三区在线| 精品亚洲国产成人av制服丝袜| 黄色小说在线播放| 你懂的好爽在线观看| 午夜亚洲精品| 女人被狂躁c到高潮| www视频在线看| 亚洲成人电视网| 欧美13一16娇小xxxx| 亚洲视频一区二区在线| 杨钰莹一级淫片aaaaaa播放| wwww在线观看| 国产suv精品一区二区6| 久久久www成人免费精品| 婷婷中文字幕在线观看| wwwww在线观看免费视频| 性日韩欧美在线视频| 亚洲欧美中日韩| 免费操人视频| 美女脱光内衣内裤视频久久影院| 日韩亚洲一区在线| 一区二区三区四区五区精品| 4438x亚洲最大成人网| 精品美女一区二区三区| 一本到不卡精品视频在线观看| 国产精品一区二区视频| 亚洲精品日韩久久| 国产精品日产欧美久久久久| 91精品久久| 亚洲天天做日日做天天谢日日欢| 你懂的在线播放| 日韩一区二区电影网| 久久久久久久精| aaa国产精品视频| 日韩专区视频网站| www.日韩.com| 欧美日韩国产高清一区二区| 国产精品免费久久久久影院| 国产mv免费观看入口亚洲| av电影免费在线观看| 国产又粗又硬视频| 精品影片在线观看的网站| 韩国在线视频一区| 深夜视频一区二区| 日本aa大片在线播放免费看| 一区二区三区中文在线观看| 久久国产亚洲精品无码| 免费人成精品欧美精品| 麻豆精品蜜桃| 欧美猛男超大videosgay| 亚洲第一av在线| 国产黄色在线看| 在线观看免费p片视频网站地址| 无码av中文一区二区三区桃花岛| 美丽的姑娘在线观看免费动漫| 国产白浆在线免费观看| 麻豆久久久久久| 清纯粉嫩极品夜夜嗨av| 麻豆成人91精品二区三区| 91免费国产在线观看| 男人的天堂免费在线视频| 羞羞影院体验区| 久久综合九色综合97婷婷女人| 亚洲精品欧美日韩专区| 国产深夜男女无套内射| 动漫美女无遮挡免费| 亚洲av无日韩毛片久久| 强制高潮抽搐sm调教高h| 中文字幕第五页| 成人www视频在线观看| 日韩av影视| 日韩av一级片| 精品国产91洋老外米糕| 91极品女神私人尤物在线播放| 成人在线国产视频| 激情视频一区二区| 日本一级黄视频| 国产综合色香蕉精品| 性欧美视频videos6一9| 婷婷在线视频| 国产精品久久久免费观看| 91麻豆精品国产91久久久更新资源速度超快| 国产精品视频色| 又黄又爽无遮挡| 成人做爰69片免网站| 青青艹在线视频| 中文字幕一区久久| 国产伦子伦对白视频| 免费极品av一视觉盛宴| 国产无遮挡又黄又爽在线观看| 高清在线不卡av| 免费一区二区视频| 国产xxx在线| 三级黄色小视频| 嘿嘿视频在线观看| 日韩欧美一区在线观看| 成人午夜一级| 亚洲专区一区二区三区| 欧美国产激情18| 国产第一精品| 三级毛片电影网站| 91在线精品入口| 免费在线超碰| 国产女人免费看a级丨片| 亚洲免费在线看| 精品欧美一区二区三区精品久久| 狠狠色成人综合网图片区| 三级福利视频| 久热成人在线视频| 中国美女乱淫免费看视频| 中文字幕第10页| 男人亚洲天堂网| 91色在线播放| 在线观看视频一区二区三区| 国产熟妇久久777777| 美女91在线| 亚洲高清资源综合久久精品| 亚洲激情专区| 欧美一区二区三区系列电影| 欧美激情一区不卡| 伊人av在线播放| 性一交一乱一伦一色一情| 国产精品视频黄色| 久久久一本精品| 成年人免费网站| 精品在线观看入口| 欧美激情一区二区三区免费观看| 日本一级淫片免费放| 久久资源免费视频| 合欧美一区二区三区| 色综合天天综合狠狠| 高清视频一区| 国产精品日本一区二区三区在线| 欧美福利电影在线观看| jizzjizzjizz亚洲女| 国产成年人视频网站| 亚洲伦理一区| 偷拍自拍亚洲| 国产探花在线观看视频| 91在线视频成人| 精品在线你懂的| 日本乱人伦一区| 欧美不卡一区二区三区四区| 99久久国产综合精品五月天喷水| av黄色免费在线观看| 国产精品成人一区二区网站软件| 欧美午夜精品久久久久久超碰| 日本欧美加勒比视频| 久久精品国产av一区二区三区| 手机在线成人av| 国产在线精品一区二区三区》| 密臀av在线| 久久精品道一区二区三区| 日本青青草视频| 国产精品一区二区久久精品爱涩| 短视频在线观看| 国产精品一品二品| 成人免费a级片| 欧美成人激情视频免费观看| 黄色片免费大全| 欧美日韩免费一区二区| 亚洲国产精品一区二区第一页| 高h视频在线观看| 91精品免费视频| 国产91av在线播放| 免费网站在线观看黄| 在线观看国产福利| 国产乱视频在线观看播放| 日韩精品伦理第一区| 中文字幕在线一二| 国产精品无人区| 日韩av激情| 国产极品久久久久久久久波多结野| 国内精品久久久久久久久久久| 极品美女一区| 国产福利图片| 欧美aaaaaaaa| 黄在线免费观看| 国产一级大片免费看| 久久99精品久久久久久| 欧美日韩国产成人高清视频| 日本三级电影网站| а√在线天堂官网| 日韩精品一线二线三线| 就去色蜜桃综合| 精品人妻一区二区色欲产成人| 亚洲 欧美 综合 另类 中字| 亚洲欧美另类综合| 欧美日韩不卡在线| 三级欧美韩日大片在线看| 久久久久久亚洲精品美女| 国产中文字幕一区二区| 天堂电影在线| 精品无码av一区二区三区不卡| 无人码人妻一区二区三区免费| 麻豆网站在线看| 国产精品suv一区二区| 欧美重口另类videos人妖| 日韩在线视频第一页| 亚洲国产成人久久| 亚洲国产不卡| 亚洲精品电影网| 久久人人妻人人人人妻性色av| 日本亚洲不卡| 成人久久久精品国产乱码一区二区| 国产aⅴ夜夜欢一区二区三区| 亚洲大黄网站| 国产女主播在线一区二区| 亚洲精品国产精品乱码不卡| 欧美娇小性xxxx| 欧美日韩在线免费观看视频| 深爱激情久久| 亚洲av片在线观看| 免费在线观看h片| 欧美一卡二卡在线| 欧美中文字幕在线观看视频| 免费国产黄线在线观看视频| 国产亚洲人成a在线v网站| 日本少妇做爰全过程毛片| 亚洲国产视频一区二区| 在线免费看h| 91久久偷偷做嫩草影院| 内射无码专区久久亚洲| 久久久久久久波多野高潮日日| 久久久久成人网| 亚洲电影天堂av| 黄色网在线免费观看| 久久精品国产亚洲夜色av网站| 麻豆成人91精品二区三区| 国产精品一区二区x88av| 精品日本一区二区三区在线观看| 色94色欧美sute亚洲线路二| 欧美精品aⅴ在线视频| 一级毛片aaaaaa免费看| 国产一区二区中文字幕免费看| 午夜影院免费视频| 国产伦精品一区二区三区视频金莲| 蜜桃视频在线观看成人| 一区二区三区毛片免费|