• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    canvas实现图片镜像翻转的2种方式

    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图片镜像翻转内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家! 

    上一篇:html5关于外链嵌入页面通信问题(postMessage解决跨域通信)
    下一篇:HTML5 video进入全屏和退出全屏的实现方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    canvas实现图片镜像翻转的2种方式 canvas,实现,图片,镜像,翻转,