zoukankan      html  css  js  c++  java
  • Canvas旋转图片--保持相同大小的算法

    

    function drawImg(angle)
    {

        canvas.width = canvas.width;

        var distance = size / 2 * Math.sqrt(2) * Math.sin(angle * Math.PI / 180 / 2) * 2;
        var degree = 180 - 45 - (180 - angle) / 2;
        var x = distance * Math.sin(degree * Math.PI / 180);
        var y = distance * Math.cos(degree * Math.PI / 180);

        ctx.translate(x, -y);
        var angleInRadians = angle * Math.PI / 180;
        ctx.rotate(angleInRadians);

        ctx.drawImage(img, 0, 0, 32, 32);
        ctx.restore();
    }

    第一步是清空画板,重点是找到旋转后图片相原方的中心,其计算公式是我自己写的。计算distnace那个。

    版权声明:本文博客原创文章,博客,未经同意,不得转载。

  • 相关阅读:
    数据产品—数据仓库
    数据产品-开篇
    os.walk()
    pytest入门
    XML 文件处理
    字符编码
    消息队列
    Pycharm
    AWS入门
    Python配置模块:configparser参数含义
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/4748777.html
Copyright © 2011-2022 走看看