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)
上一篇 2025年7月10日 上午9:15
下一篇 2025年7月10日 上午9:43


相关推荐

  • 翻译:VESA Adaptive-Sync / AMD FreeSync / VRR 白皮书[通俗易懂]

    翻译:VESA Adaptive-Sync / AMD FreeSync / VRR 白皮书[通俗易懂]译者注以下为正文。介绍多年来,显示行业一直普遍认为显示器是以固定的刷新率(refreshrate)运行的,如60Hz。这与以下事实形成鲜明对比:送给显示器的图像内容多种多样,每种图像都有自己独特的、变化的帧率(framerate)。当显示的刷新率与图像内容自身的帧率不同步时,用户可能会察觉到撕裂(tearing)和卡顿(stutter)之类的异常效果。在移动应用程序中(如平板、笔记本电脑),对于静态图像和视频播放来说,较高的显示刷新率不仅显得多余,还增加了系统功耗,降低了续航能力。这些因素使得我

    2022年6月10日
    138
  • 操作系统虚拟存储管理实验报告_虚拟存储器技术

    操作系统虚拟存储管理实验报告_虚拟存储器技术操作系统虚拟存储管理实验开辟一块内存空间,作为模拟内存(malloc)空间大小为2^14字节假设系统的页面大小为256字节,每个页表项占4个字节(系统的物理页面数为2^6,每个页表正好占一个页面)用位图刻画内存页面的分配状态,可以用一个辅助的变量来对空闲内存页面计数每个进程的虚拟地址空间也是2^14字节每个进程分配9个页面(连页表一共10个页面)创建12个作业,并模拟作业的运行…

    2026年4月14日
    9
  • 中文大模型幻觉测评:豆包大模型准确率全球第一,超越DeepSeek

    中文大模型幻觉测评:豆包大模型准确率全球第一,超越DeepSeek

    2026年3月12日
    2
  • 【最新版】2025年最新ChatGPT Plus充值教程:如何在国内充值 ChatGPT Plus、升级 GPT5

    【最新版】2025年最新ChatGPT Plus充值教程:如何在国内充值 ChatGPT Plus、升级 GPT5

    2026年3月16日
    3
  • Matlab GUI上位机界面实现串口通信

    Matlab GUI上位机界面实现串口通信MatlabGUI因项目需求,不得不学的又杂又浅,趁着还没彻底忘记,写下来一些关键注意点。命令行窗口输入guide→BlankGUI→确定根据自己的需求,拖动选择对应的工具,如下图所示双击每一个对象,就可以弹出其检查器,修改其属性,字体大小、粗细、位置等,其中最关键的是两个,一是String,二是Tag,String是用来修改对象中的文字,Tag是所调用的代码名,这个要好的…

    2022年5月15日
    52
  • 加载模型出错

    加载模型出错错误:google.protobuf.message.DecodeError:Errorparsingmessage解决:查看模型是否不完整,很多情况由于这个导致

    2022年7月14日
    21

发表回复

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

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