婷婷综合国产,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種方式的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 揭阳市| 巩义市| 桂阳县| 化隆| 古蔺县| 瑞金市| 通许县| 长宁区| 阿合奇县| 金堂县| 弋阳县| 陇川县| 镶黄旗| 乐山市| 区。| 商都县| 嘉禾县| 洪江市| 都江堰市| 临安市| 吉安县| 石狮市| 宝清县| 榆中县| 禹州市| 海兴县| 鱼台县| 饶阳县| 佛坪县| 隆子县| 霸州市| 卢龙县| 怀宁县| 舞钢市| 巴南区| 延庆县| 东丽区| 长治县| 定边县| 桦南县| 虞城县|