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

主頁 > 知識庫 > canvas實現圖片鏡像翻轉的2種方式

canvas實現圖片鏡像翻轉的2種方式

熱門標簽:機器人外呼系統存在哪些能力 電話機器人電銷系統掙話費 如何獲取地圖標注客戶 平涼地圖標注位置怎么弄 只辦理400電話 拓展地圖標注 高德地圖標注地點糾錯 電話機器人黑斑馬免費 南昌仁和怎么申請開通400電話

1. 通過canvas自帶的畫布方法進行翻轉

  var img = new Image(); //這個就是 img標簽的dom對象
  img.src = './sy.png';
  img.onload = function () {
    //圖片加載完成后,執行此方法
    ctx.drawImage(img, posx, posy, 210, 80);
  };
play.addEventListener('click', function () {
     ctx.clearRect(0, 0, canvas.width, canvas.height);//清除畫布
     //位移來做鏡像翻轉
     ctx.translate(210+ posx * 2, 0);
     ctx.scale(-1, 1); //左右鏡像翻轉
     
     //ctx.translate(0, 160 + posy * 2);
     //ctx.scale(1, -1); //上下鏡像翻轉
     ctx.drawImage(img, 0, 0, 210, 80);
  });

2.像素點的鏡像翻轉方法

//豎向像素反轉
    function imageDataVRevert(sourceData, newData) {
      for (var i = 0, h = sourceData.height; i < h; i++) {
        for (var j = 0, w = sourceData.width; j < w; j++) {
          newData.data[i * w * 4 + j * 4 + 0] =
            sourceData.data[(h - i) * w * 4 + j * 4 + 0];
          newData.data[i * w * 4 + j * 4 + 1] =
            sourceData.data[(h - i) * w * 4 + j * 4 + 1];
          newData.data[i * w * 4 + j * 4 + 2] =
            sourceData.data[(h - i) * w * 4 + j * 4 + 2];
          newData.data[i * w * 4 + j * 4 + 3] =
            sourceData.data[(h - i) * w * 4 + j * 4 + 3];
        }
      }
      return newData;
    }

    //橫向像素反轉
    function imageDataHRevert(sourceData, newData) {
      for (var i = 0, h = sourceData.height; i < h; i++) {
        for (j = 0, w = sourceData.width; j < w; j++) {
          newData.data[i * w * 4 + j * 4 + 0] =
            sourceData.data[i * w * 4 + (w - j) * 4 + 0];
          newData.data[i * w * 4 + j * 4 + 1] =
            sourceData.data[i * w * 4 + (w - j) * 4 + 1];
          newData.data[i * w * 4 + j * 4 + 2] =
            sourceData.data[i * w * 4 + (w - j) * 4 + 2];
          newData.data[i * w * 4 + j * 4 + 3] =
            sourceData.data[i * w * 4 + (w - j) * 4 + 3];
        }
      }
      return newData;
    }
``

var img = new Image(); //這個就是 img標簽的dom對象
  img.src = './sy.png';
  img.onload = function () {
    //圖片加載完成后,執行此方法
    ctx.drawImage(img, 0, 0, 210, 80);
  };
  
    //像素點操作
    var imgData = ctx.getImageData(0, 0, 210, 80);
    var newImgData = ctx.getImageData(0, 0, 210, 80);

    // var newImgData = ctx.getImageData(0, 0, w, h);
    ctx.putImageData(imageDataVRevert(newImgData, imgData), 0, 0);  //上下翻轉
    // ctx.putImageData(imageDataHRevert(newImgData, imgData), 0, 0);//左右翻轉~~~~

到此這篇關于canvas實現圖片鏡像翻轉的2種方式的文章就介紹到這了,更多相關canvas圖片鏡像翻轉內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章,希望大家以后多多支持腳本之家! 

標簽:池州 西藏 棗莊 漯河 遼源 永州 新疆 青島

巨人網絡通訊聲明:本文標題《canvas實現圖片鏡像翻轉的2種方式》,本文關鍵詞  canvas,實現,圖片,鏡像,翻轉,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《canvas實現圖片鏡像翻轉的2種方式》相關的同類信息!
  • 本頁收集關于canvas實現圖片鏡像翻轉的2種方式的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 松原市| 宽城| 藁城市| 宣汉县| 五家渠市| 萨嘎县| 武川县| 通州市| 奉贤区| 庄河市| 库伦旗| 邢台县| 遵义市| 芷江| 广灵县| 高邮市| 大同市| 吉木萨尔县| 体育| 曲阳县| 玛纳斯县| 三明市| 临桂县| 鹰潭市| 鹤壁市| 双峰县| 炉霍县| 安化县| 洪雅县| 上饶市| 上栗县| 阿勒泰市| 马边| 东平县| 沙田区| 阳原县| 微山县| 城市| 广昌县| 渑池县| 阳信县|