图形编辑器:图形和辅助线绘制的坐标问题

图形编辑器:图形和辅助线绘制的坐标问题,大家好,我是前端西瓜哥。今天看看绘制图形和辅助线时,坐标转换的一些注意点。,图片,视口转场景:,场景转视口:,场景很大,但能画的范围其实就视口大小。所以,我们需要将使用了场景坐标的图形的位置,转换为视口坐标,再绘制。,对于图形我们的做法是在绘制图形前,先做矩阵变换,让之后绘制的所有像素都自动做一个转换,不用自己一个个手动转换。,有的朋友看着前面的 sceneCoordsToViewportCoords 方法,有:,于是认为 ctx 的变换对应的写法是这样的:,这个写法思路是对的,但细节有错误。因为 ctx.scale 的缩放中心因为前面的ctx.tranlate 从 (0, 0) 变成了 (-viewport.x, -viewport.y) 。,正确的写法其实是缩放时调整一下缩放中心,缩放后再移回去,即:,然后你会发现,第一行和第二行抵消了,于是化简得到:,上面的效果,是无差别给之后绘制的所有图形做缩放。也就是说,zoom 变大时,线宽(ctx.lineWidth)也会跟着变大。,图形编辑器要绘制的除了图形外,还有非常重要的一样东西:辅助线。,(辅助线的坐标我们也是用场景坐标系的),对于辅助线,我们希望 zoom 改变时,还能让线宽保持原来的 1px,还有让控制点的尺寸不变,如下图效果:,图片,缩放功能演示,解决方案是,我们自己算辅助线上的点在视口坐标的位置,不借助 ctx.scale 和 ctx.translate。,首先用 ctx.setTransform 将变换矩阵重置,将之前 ctx.scale 等造成的影响消除掉。,然后就是用前面写好的 sceneCoordsToViewportCoords 方法转换一下,得到视口坐标系下的位置,然后进行绘制即可。,其实就是局部做坐标系转换,比如坐标会转换、线宽不转换。其实也有另一种思路,就是让线宽除以 zoom,或尺寸除以 zoom,都可以。,场景坐标和视口坐标转换,贯穿于整个编辑器项目,还是很重要的,要好好消化。

文章版权声明

 1 原创文章作者:cmcc,如若转载,请注明出处: https://www.52hwl.com/19669.html

 2 温馨提示:软件侵权请联系469472785#qq.com(三天内删除相关链接)资源失效请留言反馈

 3 下载提示:如遇蓝奏云无法访问,请修改lanzous(把s修改成x)

 免责声明:本站为个人博客,所有软件信息均来自网络 修改版软件,加群广告提示为修改者自留,非本站信息,注意鉴别

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023年3月5日 上午12:00
下一篇 2023年3月7日 下午10:34