Drawing a 1px thick line in canvas creates a 2px thick line(在画布中绘制 1px 粗线会创建 2px 粗线)
问题描述
在这个 jsfiddle 中有一条 lineWidth 为 1 的线.
In this jsfiddle there's a line with a lineWidth of 1.
http://jsfiddle.net/mailrox/9bMPD/350/
例如:
ctx.lineWidth = 1;
但是在画布上绘制的线条是 2px 粗的,你如何创建一个 1px 粗的线条.
However the line is 2px thick when it's drawn on the canvas, how do you create a 1px thick line.
我可以绘制一个矩形(高度为 1 像素),但我希望这条线也适用于对角线.那么如何让这条线达到 1px 高呢?
I could draw a rectangle (with 1px height) however I want the line to also work on diagonals. So how do you get this line to be 1px high?
谢谢!
推荐答案
Canvas 从半个像素开始计算
Canvas calculates from the half of a pixel
ctx.moveTo(50,150.5);
ctx.lineTo(150,150.5);
所以从一半开始会解决它
So starting at a half will fix it
固定版本:http://jsfiddle.net/9bMPD/357/
这个答案解释了为什么它会这样工作.
This answer explains why it works that way.
这篇关于在画布中绘制 1px 粗线会创建 2px 粗线的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在画布中绘制 1px 粗线会创建 2px 粗线
基础教程推荐
- 直接将值设置为滑块 2022-01-01
- Chart.js 在线性图表上拖动点 2022-01-01
- Electron 将 Node.js 和 Chromium 上下文结合起来意味着 2022-01-01
- 如何使用JIT在顺风css中使用布局变体? 2022-01-01
- 我可以在浏览器中与Babel一起使用ES模块,而不捆绑我的代码吗? 2022-01-01
- html表格如何通过更改悬停边框来突出显示列? 2022-01-01
- 自定义 XMLHttpRequest.prototype.open 2022-01-01
- 用于 Twitter 小部件宽度的 HTML/CSS 2022-01-01
- Vue 3 – <过渡>渲染不能动画的非元素根节点 2022-01-01
- 如何使用TypeScrip将固定承诺数组中的项设置为可选 2022-01-01