canvas绘制虚线图表

简介: canvas绘制虚线图表

最近有读者加我微信咨询这个问题,如下图所示:

微信图片_20220425140109.png


要实现的效果如下:


微信图片_20220425140112.png


其实难度不大,但是考虑一些人员对于canvas不熟悉,还是简单的介绍下。


其实该图表,就是一个圆圈外面在套一个圆弧的效果, 主要的难点在于不知道怎么绘制圆圈的虚线效果。其实canvas本身已经支持了虚线的绘制,就是一个api调用的事情,api是setLineDash。


示例代码如下:


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Line Dash</title>
    <style>
        canvas {
            border: 1px solid #000;
        }
    </style>
</head>
<body>
    <canvas id="canvas" width="600" height="400"></canvas>
    <script>
        var ctx = document.getElementById( 'canvas' ).getContext( '2d' );
        var w = canvas.width,
                h = canvas.height;
        var x = w / 2,
                y = h / 2;
        ctx.save();
        ctx.strokeStyle = "gray";
        ctx.setLineDash([5,5]);
        ctx.lineWidth = 10;
        ctx.beginPath();
        ctx.arc(200,200,75,0,Math.PI *2);
        ctx.stroke();
        ctx.restore();
        ctx.save();
        ctx.beginPath();
        ctx.lineWidth = 12;
        ctx.lineCap = "round";
        ctx.joinCap = "round";
        ctx.strokeStyle = "red";
        ctx.arc(200,200,75,0,-Math.PI/2,Math.PI /2 );
        ctx.stroke();
        ctx.restore();
    </script>
</body>
</html>


绘制效果如下图所示:


微信图片_20220425140117.png


ps:后面那个读者也给我看了下css的实现, css实现这种东西还是太麻烦,一般不建

议。


微信图片_20220425140120.png

相关文章
|
8月前
|
前端开发
canvas绘制圆环
canvas绘制圆环
|
6月前
|
前端开发
Canvas如何画一个线条,画布效果最好添加字体和线条回溯
Canvas如何画一个线条,画布效果最好添加字体和线条回溯
|
6月前
|
前端开发
Canvas如何画一个网格线条
Canvas如何画一个网格线条
|
8月前
|
缓存 前端开发 JavaScript
canvas详解01-绘制基本图形
canvas详解01-绘制基本图形
140 2
echarts折线图折线点大小,颜色,折线的颜色设置
echarts折线图折线点大小,颜色,折线的颜色设置
120 1
Echarts折线图的x和y轴坐标颜色修改
Echarts折线图的x和y轴坐标颜色修改
277 1
echarts折线图线条颜色和区域颜色设置
echarts折线图线条颜色和区域颜色设置
266 0
144Echarts - 矩形树图(How $3.7 Trillion is Spent)
144Echarts - 矩形树图(How $3.7 Trillion is Spent)
57 0
|
前端开发
canvas绘制五角星
canvas绘制五角星
195 0
|
前端开发 JavaScript 存储