`

Canvas绘制线条(直线、折线等)

阅读更多

使用html5 Canvas绘制直线所需的CanvasRenderingContext2D对象的主要属性和方法(有"()"者为方法)如下:

属性或方法 基本描述
strokeStyle 用于设置画笔绘制路径的颜色、渐变和模式。该属性的值可以是一个表示css颜色值的字符串。如果你的绘制需求比较复杂,该属性的值还可以是一个CanvasGradient对象或者CanvasPattern对象
globalAlpha 定义绘制内容的透明度,取值在0.0(完全透明)和1.0(完全不透明)之间,默认值为1.0。
lineWidth 定义绘制线条的宽度。默认值是1.0,并且这个属性必须大于0.0。较宽的线条在路径上居中,每边各有线条宽的一半。
lineCap 指定线条两端的线帽如何绘制。合法的值是 "butt"、"round"和"square"。默认值是"butt"。你可以点击这里查看lineCap的具体示例,以帮助你更好地理解lineCap
beginPath() 开始一个新的绘制路径。每次绘制新的路径之前记得调用该方法。它将重置内存中现有的路径。
moveTo(int x, int y) 移动画笔到指定的坐标点(x,y),该点就是新的子路径的起始点
lineTo(int x, int y) 使用直线连接当前端点和指定的坐标点(x,y)
stroke(int x, int y) 沿着绘制路径的坐标点顺序绘制直线
closePath() 如果当前的绘制路径是打开的,则关闭掉该绘制路径。此外,调用该方法时,它会尝试用直线连接当前端点与起始端点来关闭路径,但如果图形已经关闭(比如先调用了stroke())或者只有一个点,它会什么都不做。

在Canvas的图形绘制过程中,几乎都是先按照一定顺序先定下几个坐标点,也就是所谓的绘制路径,然后再根据我们的需要将这些坐标点用指定的方式连接起来,就形成了我们所需要的图形。当我们了解了CanvasRenderingContext2D对象的上述API后,那么绘制线条就显得非常简单了。

使用canvas绘制基本的直线

现在,我们就使用canvas来绘制最基本的直线。

<!DOCTYPE html>
<html>
<head>
<metacharset="UTF-8">
<title>HTML5 Canvas绘制线条入门示例</title>
</head>
<body>
<!-- 添加canvas标签,并加上红色边框以便于在页面上查看 -->
<canvasid="myCanvas"width="400px"height="300px"style="border:1px solid red;">
您的浏览器不支持canvas标签。
</canvas>
<scripttype="text/javascript">
//获取Canvas对象(画布)
var canvas = document.getElementById("myCanvas");
//简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误
if(canvas.getContext){  
    //获取对应的CanvasRenderingContext2D对象(画笔)
    var ctx = canvas.getContext("2d");
   
    //注意,Canvas的坐标系是:Canvas画布的左上角为原点(0,0),向右为横坐标,向下为纵坐标,单位是像素(px)。
   
    //开始一个新的绘制路径
    ctx.beginPath();
    //定义直线的起点坐标为(10,10)
    ctx.moveTo(10,10);
    //定义直线的终点坐标为(50,10)
    ctx.lineTo(50,10);
    //沿着坐标点顺序的路径绘制直线
    ctx.stroke();
    //关闭当前的绘制路径
    ctx.closePath();
}
</script>
</body>
</html>

 

显示效果如下

使用canvas绘制最基本的直线使用canvas绘制最基本的直线

使用canvas绘制带颜色的直线

大家都知道,在现实世界中,画笔也是多种多样的,并且具有各种不同的颜色。同样的,Canvas的画笔CanvasRenderingContext2D对象也同样可以具有你所需要的各种颜色。在上面的代码示例中,我们没有指定颜色的话,Canvas的画笔就默认为最常见的黑色。

现在我们再次使用Canvas的画笔绘制一条蓝色的直线(基于页面简洁考虑,下面只给出关键的JavaScript代码,请同时参考上面完整的代码示例)。

<!DOCTYPE html>
<html>
<head>
<metacharset="UTF-8">
<title>HTML5 Canvas绘制线条入门示例</title>
</head>
<body>
<!-- 添加canvas标签,并加上红色边框以便于在页面上查看 -->
<canvasid="myCanvas"width="400px"height="300px"style="border:1px solid red;">
您的浏览器不支持canvas标签。
</canvas>
<scripttype="text/javascript">
//获取Canvas对象(画布)
var canvas = document.getElementById("myCanvas");
//简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误
if(canvas.getContext){  
    //获取对应的CanvasRenderingContext2D对象(画笔)
    var ctx = canvas.getContext("2d");  
   
    //开始一个新的绘制路径
    ctx.beginPath();
    //定义直线的起点坐标为(10,10)
    ctx.moveTo(10,10);
    //定义直线的终点坐标为(50,10)
    ctx.lineTo(50,10);
    //沿着坐标点顺序的路径绘制直线
    ctx.stroke();
    //关闭当前的绘制路径
    ctx.closePath();
    //绘制一条带颜色的直线
    ctx.moveTo(10,30);
    ctx.lineTo(50,30);
    //支持css颜色值的各种表现形式,例如:"blue"、"#0000ff"、"#00f"、"rgb(0,0,255)"、"rgba(0,0,255,1)"
    //颜色等各种设置,必须在最终的绘制函数stroke()之前调用
    ctx.strokeStyle ="blue";
    ctx.stroke();
    //关闭当前的绘制路径
    ctx.closePath();
}
</script>
</body>
</html>

 

对应的显示效果如下图

使用canvas绘制的蓝色直线使用canvas绘制的蓝色直线

使用canvas绘制基本的折线

当我们掌握了Canvas绘制直线之后,绘制折线等其他形式的线条就简单多了。我们只需要多绘制几个路径中间点,并依次将它们连接起来即可。

<scripttype="text/javascript">
//获取Canvas对象(画布)
var canvas = document.getElementById("myCanvas");
//简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误
if(canvas.getContext){  
    //获取对应的CanvasRenderingContext2D对象(画笔)
    var ctx = canvas.getContext("2d");  
   
    //开始一个新的绘制路径
    ctx.beginPath();
    //设置线条颜色为蓝色
    ctx.strokeStyle ="blue";
    //设置路径起点坐标
    ctx.moveTo(20,50);
    //定义中间点坐标1
    ctx.lineTo(60,50);
    //定义中间点坐标2
    ctx.lineTo(60,90);
    //定义中间点坐标3(这是最后一个中间点,也就是终点)
    ctx.lineTo(100,90);
    //按照绘制路径顺序连接各个坐标点
    ctx.stroke();
    //关闭绘制路径
    ctx.closePath();
}
</script>

 

对应的显示效果如下图

使用Canvas绘制的折线效果使用Canvas绘制的折线效果

掌握上述内容后,相信大家对使用Canvas绘制线条有一些基本的了解了吧。由于对线条的宽度、透明度等控制只是设置单个属性即可,请参考上面的相关API,这里就不再赘述了。

 

强烈注意:

①在绘制图形路径时,一定要先调用beginPath()beginPath()方法将会清空内存中之前的绘制路径信息。如果不这样做,对于绘制单个图形可能没什么影响,但是在绘制多个图形时(例如上面示例的两条直线),将会导致路径绘制或者颜色填充等操作出现任何意料之外的结果。

②对于closePath()方法,初学者一定要稍加注意,尤其是上面API表格中closePath()方法描述中的红色文字。在上面绘制折线的代码示例中,我们先调用了stroke(),再调用了closePath()。其实在调用stroke()方法时,折线就已经绘制好了,当前的绘制路径也就被关闭掉了,所以再调用closePath()方法时,它就不会使用直线连接当前端点和起始端点(也就是说,这里的closePath()是可有可无的,不过为了保持良好的习惯,还是建议写上)。

 

此外,如果我们交换一下stroke()closePath()的调用顺序,则情况完全不一样了。由于closePath()先调用,此时绘制路径并没有关闭,那么closePath()将会用直线连接当前端点和起始端点。

交换stroke()closePath()调用顺序后的示例代码如下:

<scripttype="text/javascript">
//获取Canvas对象(画布)
var canvas = document.getElementById("myCanvas");
//简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误
if(canvas.getContext){  
    //获取对应的CanvasRenderingContext2D对象(画笔)
    var ctx = canvas.getContext("2d");  
   
    //开始一个新的绘制路径
    ctx.beginPath();
    //设置线条颜色为蓝色
    ctx.strokeStyle ="blue";
    //设置路径起点坐标
    ctx.moveTo(20,50);
    //定义中间点坐标1
    ctx.lineTo(60,50);
    //定义中间点坐标2
    ctx.lineTo(60,90);
    //定义中间点坐标3(这是最后一个中间点,也就是终点)
    ctx.lineTo(100,90);
    //先关闭绘制路径。注意,此时将会使用直线连接当前端点和起始端点。
    ctx.closePath();
    //最后,按照绘制路径顺序连接各个坐标点
    ctx.stroke();
}
</script>

 

交换调用顺序后,对应的显示效果如下

交换调用顺序后的canvas绘制效果交换调用顺序后的canvas绘制效果

分享到:
评论

相关推荐

    canvas绘制的直线动画

    2. `color`: 绘制线条的颜色。 3. `staX` 和 `staY`: 直线的起始坐标。 4. `len`: 目标坐标,即线条的长度。 5. `timing`: 动画帧间隔时间(单位:毫秒)。 6. `num`: 每次移动的距离。 7. `direc`: 判断线条绘制的...

    Canvas彩色发光3D线条动画特效

    这个特效利用了Canvas的绘图函数,如`beginPath()`, `moveTo()`, `lineTo()`,以及`stroke()`,来绘制线条。`beginPath()`用于开始一个新的路径,`moveTo()`定义了路径的起始点,而`lineTo()`则添加直线到路径。`...

    canvas绘图之线条及线条属性.pdf

    开始绘制线条之前,首先要了解的是绘制线条的两个基本方法:moveTo()和lineTo()。moveTo()方法用于设置一个点作为绘制的起点,而lineTo()方法则定义了从上一个点到当前位置之间的一条直线。举个例子,调用context....

    HTML5 Canvas绘制的云雾中电流交织2D动画特效源码.zip

    这个压缩包"HTML5 Canvas绘制的云雾中电流交织2D动画特效源码.zip"显然是一个示例项目,展示了如何使用HTML5 Canvas技术来实现一种特定的动画效果——云雾中电流交织。 首先,让我们深入了解一下HTML5 Canvas的基本...

    android画直线、箭头、折线(平移、定义点击事件)源码

    在Android开发中,有时我们需要在屏幕上绘制自定义图形,如直线、箭头和折线,以实现各种交互式用户界面。本示例源码提供了一种方法,通过使用`Path`类来绘制这些图形,并实现了图形的平移以及定义点击事件。`Path`...

    html5 canvas微信运动步数折线图代码

    这个对象提供了各种方法,如`fillRect()`、`strokeRect()`、`beginPath()`、`moveTo()`、`lineTo()`等,用于绘制线条、矩形、圆弧等。 在创建折线图时,首先要确定画布的尺寸,然后绘制网格背景。使用`fillStyle`和...

    基于Cesium+VUE实现的态势标绘之简单(直线和曲线)箭头功能,完整demo和源代码,代码未加密/未压缩,可直接调用运行

    基于Cesium+VUE实现的态势标绘之简单(直线和曲线)箭头功能,完整demo和源代码,代码未加密/未压缩,可直接调用运行 文章描述:https://blog.csdn.net/qq_34205305/article/details/124285032 代码不易,略收小费,...

    JS绘制折线,多边形,椭圆案例

    在JavaScript(JS)中,利用HTML5的Canvas API可以实现各种图形的绘制,包括折线、多边形和椭圆。Canvas是一个二维绘图上下文,允许开发者在网页上进行动态图形绘制。以下是对这些知识点的详细说明: 1. **绘制折线...

    canvas进阶之如何画出平滑的曲线

    在上述的简单画板示例中,线条的锯齿状和平滑度问题主要是由于两点间直线连接导致的。要解决这个问题,我们可以在鼠标移动过程中添加额外的逻辑,以计算出更平滑的曲线路径。一种常见的做法是使用贝塞尔曲线,通过在...

    Canvas收益率曲线进度条动画特效.zip

    开发者可能会定义一组坐标点,表示不同时间段的收益率,然后使用`context.beginPath()`开始路径,`context.lineTo(x, y)`添加点,最后`context.stroke()`来绘制线条。 3. **进度条**:进度条的实现可能涉及一个矩形...

    经典JS绘图库,可绘制折线,椭圆,多边形等

    使用Paper.js,你可以使用其内置的Path类来绘制折线,Ellipse类来绘制椭圆,而多边形可以通过组合直线和闭合路径来实现。Paper.js的强项在于它的路径操作,使得复杂的形状构造变得简单。 在实际应用中,选择哪个库...

    Delphi中canvas(画布)运用

    通过`Canvas`对象,开发者可以控制绘制的颜色、线宽、字体等属性,并执行诸如绘制直线、矩形、圆形等操作。 #### 二、支持Canvas的控件 Delphi中有多种控件支持`Canvas`功能,包括但不限于: - `TBitmap`: 可用于...

    js HTML5 Canvas线性图表插件可以绘制不同的颜色.zip

    2. **绘图API**:2D渲染上下文提供了丰富的绘图方法,如`moveTo()`, `lineTo()`, `stroke()`, `fill()`, `beginPath()`, `closePath()`等,用于绘制线条、路径和填充。 3. **坐标系统**:Canvas的坐标系统是以像素...

    android自定义折线图曲线图

    4. 绘制线条:使用drawLine()或drawPath()方法,依次连接数据点。对于曲线,可能需要使用贝塞尔曲线(Bezier Curve)来平滑连接各个点。 5. 设置样式:可以定制线条的颜色、宽度、透明度等属性。同时,还可以实现...

    tcl tk canvas

    - **图形绘制**:Canvas可以绘制各种基本形状,如直线、曲线、矩形、椭圆等,还可以通过路径命令绘制自定义形状。 - **颜色和样式**:可以设置图形的颜色、边框宽度、填充样式等,支持多种颜色模式,如RGB、HSV等...

    canvas行情图

    例如,使用`moveTo()`和`lineTo()`方法画出连接各个价格点的线,`stroke()`来绘制线条。 6. **时间序列处理**:对于行情图,时间序列数据的处理很重要。可能需要将时间戳转换为可读的日期格式,并根据时间间隔决定x...

Global site tag (gtag.js) - Google Analytics