校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 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種方式的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 郸城县| 深水埗区| 秦安县| 黔南| 渑池县| 福鼎市| 南澳县| 石景山区| 邵东县| 沿河| 新余市| 滁州市| 宜州市| 和田市| 安平县| 元阳县| 株洲县| 阿瓦提县| 巩留县| 遂昌县| 斗六市| 阳高县| 平塘县| 晴隆县| 和平区| 彩票| 连平县| 墨脱县| 长葛市| 丰城市| 汶上县| 绥宁县| 讷河市| 永平县| 新津县| 清流县| 察隅县| 宜州市| 社旗县| 二连浩特市| 巩义市|