使用Arc的HTML5 Canvas Clip剪辑错误
HTML5 Canvas Clip using Arc is clipping wrong
所以我尝试过使用ctx.clip和ctx.arc来剪裁图像,如下所示:
ctx.beginPath();
ctx.arc(250, 250, 250, -Math.PI / 4, Math.PI / 4);
ctx.clip();
ctx.drawImage(img, 0, 0, canvas.width, canvas.height);
正如你所看到的,我已经将起始角设置为-45度,将结束角设置为45度,但我得到的是一个圆形/半月形的切口,而不是一个吃豆人的图形,就像你使用ctx.fill填充圆弧时看到的那样。
小提琴
为什么会出现这种情况,我该如何修复?
提前谢谢。
对HTML5或JavaScript一无所知,我认为您只是没有正确关闭路径。在弧后添加ctx.lineTo(250,250);
:http://jsfiddle.net/7em21gvk/
好的,所以我发现了问题,只需添加ctx.moveTo(x,y),其中x和y是弧的中心,如下所示:
ctx.beginPath();
ctx.moveTo(250, 250);
ctx.arc(250, 250, 250, -Math.PI / 4, Math.PI / 4);
ctx.clip();
ctx.drawImage(img, 0, 0, canvas.width, canvas.height);
FIDDLE
相关文章:
- Node.js v6.2.0类扩展不是函数错误
- Jquery菜单操作不稳定,定位不正确,存在一般错误
- document.open/document.write没有正确地清除chrome中的文档——这是chrome的错误吗
- 试图在引导模式内动态生成图表,得到offsetWidth错误
- 为什么会出现错误;未捕获的类型错误:undefined不是函数;
- 我如何修复包含在captcha的addthis中的错误
- 同样,同样的错误'ahorcado.js:26未捕获类型错误:无法读取属性'beginPath'
- 节点是否需要模块传递带有方括号的arg?这是个错误吗
- Webpack/Rect:遵循egghead.io教程,但出现错误:您可能需要一个合适的加载程序来处理此文件类型
- CKFinder 3为所选文件返回错误的URL
- 同位素库错误:未捕获错误无布局模式包装生产线8
- 铬:“;未捕获的语法错误:意外的标记:"
- 如何通过自己获得Chrome扩展的用户反馈/错误报告
- 相位器状态未捕获参考错误
- /undefined在我的404错误日志中多次出现
- Javascript未捕获语法错误意外的标识符错误
- javascript:如何在antlr生成的Lexer中进行错误处理
- Angularjs工厂注入错误
- 可以设置“;文件名"发生错误时显示的内联脚本标记的
- 使用Arc的HTML5 Canvas Clip剪辑错误