【问题标题】:Rounded corners on Canvas trapezoid shape帆布梯形上的圆角
【发布时间】:2020-11-04 12:35:57
【问题描述】:

我正在尝试使用画布绘制一个形状,并且与我想要的非常接近。只是圆角有点难以达到我的需要。

我有以下代码

var canvas = $("#myCanvas");
var context = canvas.get(0).getContext("2d");

// Set rectangle and corner values
var cornerRadius = 5;

// Set faux rounded corners
context.lineJoin = "round";
context.lineWidth = 50;

context.beginPath();
context.moveTo(400, 60);
context.lineTo(360, 140);
context.lineTo(240, 135);
context.lineTo(180, 60);
context.closePath();
context.stroke();
context.fill();

这导致了这里的形状

我想要实现的是让左右底角都变圆,而不是顶部。

如果我删除 lineJoin,那么圆角就消失了。

那么,我该如何设置 lineJoin 应该运行的点?

非常感谢。

【问题讨论】:

  • 根据您的尝试,使用context.drawImage 函数可能更容易。
  • @luekbaja 我认为它现在不是一个选项,因为我打算将来将其转换为可重用的组件。
  • 这个答案展示了如何将圆角 stackoverflow.com/a/44856925/3877726 添加到任何多边形,包括代码。

标签: javascript canvas html5-canvas


【解决方案1】:

使用quadraticCurveTo 进行检查,这就是我在此示例中使用的内容。不幸的是,您无法更改连接类型的中间形状,但是您可以实际绘制圆形路径。

const canvas = document.querySelector("canvas");
const ctx = canvas.getContext("2d");

canvas.width = canvas.height = 800;

// Set rectangle and corner values
const cornerRadius = 1;

ctx.lineWidth = 50;
ctx.beginPath();
ctx.moveTo(180, 60);
ctx.lineTo(400, 60);
ctx.quadraticCurveTo(400, 60, 400, 60);
ctx.lineTo(360, 140 - cornerRadius);
ctx.quadraticCurveTo(360, 140, 360 - cornerRadius, 140);
ctx.lineTo(240 + cornerRadius, 135);
ctx.quadraticCurveTo(240, 135, 240, 135 - cornerRadius);
ctx.lineTo(180, 60);
ctx.closePath();
ctx.stroke();
ctx.fill();
<canvas></canvas>

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2017-12-04
    • 2012-02-15
    • 2014-01-25
    • 2020-12-07
    • 1970-01-01
    • 2020-06-14
    • 1970-01-01
    相关资源
    最近更新 更多