canvas rotate方法

canvas rotate方法接上一篇图片上传功能中的ios下横屏拍的图片,最终上传却变成了竖向的解决方法。理解canvas的rotate,得先了解几个概念varc=document.getElementById("myCanvas");varctx=c.getContext("2d");ctx.fillRect(0,0,50,100);1、rotate的圆心是canvas的00位置2、将canvas…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

接上一篇图片上传功能中的ios下横屏拍的图片,最终上传却变成了竖向的解决方法。

理解canvas的rotate,得先了解几个概念

var c=document.getElementById(“myCanvas”);
var ctx=c.getContext(“2d”);
ctx.fillRect(0,0,50,100);

1、rotate的圆心是canvas的0 0位置

2、将canvas本身理解为可视区域

3、ctx rotate以后x轴和y轴都会发生变化

 

回到最初的问题,横向拍摄的图片绘制进canvas变成了竖向,首先想到的是rotate 90 或270 度来解决。

以rotate90度来做实例,我们先生成一个竖向的方块

<canvas id="myCanvas" style="background:#eee;"></canvas>
<script>
var c=document.getElementById("myCanvas");
var ctx=c.getContext("2d");
ctx.fillRect(0,0,50,100);
</script>

Jetbrains全家桶1年46,售后保障稳定

canvas rotate方法

我们需求是一个横向的,这个时候加入rotate

<canvas id="myCanvas" style="background:#eee;"></canvas>
<script>
var c=document.getElementById("myCanvas");
var ctx=c.getContext("2d");
ctx.rotate(Math.PI/2);
ctx.fillRect(0,0,50,100);
</script>

 

canvas rotate方法

发现黑方块不见了,主要是旋转90度以后,出了可视区域,在可视区域的右边,而且ctx本身的x,y轴也旋转了,这个时候需要改变绘制起点,才能让他重新出现在可视区域内,并实现了需要的效果

<canvas id="myCanvas" style="background:#eee;"></canvas>
<script>
var c=document.getElementById("myCanvas");
var ctx=c.getContext("2d");
ctx.rotate(Math.PI/2);
ctx.fillRect(0,-100,50,100);
</script>

canvas rotate方法

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/219088.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 创建文件映射函数CreateFileMapping中第一个参数设置成0xFFFFFFFF

    创建文件映射函数CreateFileMapping中第一个参数设置成0xFFFFFFFF创建文件内存映射:HANDLEhMySharedMapFile=CreateFileMapping((HANDLE)0xFFFFFFFF),NULL,PAGE_READWRITE,0,0x1000,"MySharedMem");其中第一个参数文件句柄设置成0XFFFFFFFF代表什么意思呢?0XFFFFFFFF在内存中又是什么意思呢?为什么要把文件句柄设置成0XFF…

    2022年5月16日
    37
  • python hashlib_python加密之hashlib[通俗易懂]

    python hashlib_python加密之hashlib[通俗易懂]1、强大的hashlib,提供了用于加密相关的操作,代替了md5模块和sha模块,主要提供SHA1,SHA224,SHA256,SHA384,SHA512,MD5算法2、hmac模块实现了hmac算法,需要一个key来进行加密,提供更为强大的加密,不过需要提供key,也就是通常说的盐3、使用hashlib.algorithms_available,可以查看hashlib提供的加密算法…

    2022年4月29日
    42
  • pycharm常用快捷键详解,让你编程 事半功倍。[通俗易懂]

    pycharm常用快捷键详解,让你编程 事半功倍。[通俗易懂]pycharm常用快捷键1、编辑(Editing)Ctrl+Space:基本的代码完成(类、方法、属性)Ctrl+Alt+Space快速导入任意类Ctrl+Shift+Enter:语句完成Ctrl+P参数信息(在方法中调用参数)Ctrl+Q快速查看文档F1外部文档Shift+F1:外部文档,进…

    2022年8月25日
    12
  • 使用Django 测试客户端一起测试视图,模板和URL

    使用Django 测试客户端一起测试视图,模板和URL

    2022年4月2日
    37
  • IP地址分类及对应范围[通俗易懂]

    IP地址分类及对应范围[通俗易懂]IP地址分类(A类B类C类D类E类)此文为转载博文原文作者:开着奥迪卖小猪https://blog.csdn.net/kzadmxz/article/details/73658168 一、简介    IP地址由四段组成,…

    2022年5月23日
    65
  • 微信公众平台域名设置「建议收藏」

    微信公众平台域名设置「建议收藏」微信公众平台域名设置微信公众平台的开发目前可在三个地方配置域名,域名所起到的作用不尽相同,本篇文章将讲解微信公众平台如何配置、以及配置后的域名各有什么样的作用(注:文章中的图片来源于个人的微信订阅号、接口测试号)。基本配置登录微信公众平台后,在“开发”菜单下有个“基本配置”菜单;图1基本配置点开后可看到“公众号开发信息”、“服务器配置(未启用)”、“已绑定的微信开放平…

    2022年6月18日
    427

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号