【绘制】HTML5 Canvas 中路径(path)、描边(stroke)与填充(fill)详细介绍(图文、代码示例)

本文主要是介绍【绘制】HTML5 Canvas 中路径(path)、描边(stroke)与填充(fill)详细介绍(图文、代码示例),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我的处女作《Canvas系列教程》在我的Github上正在连载更新,希望能得到您的关注和支持,让我有更多的动力进行创作。

教程介绍、教程目录等能在README里查阅。

传送门:https://github.com/827652549/CanvasStudy

目录

 

引入

案例

介绍

在线演示

效果图

代码

路径

子路径 

填充路径中的“非零环绕规则”

“非零环绕规则”的判断过程


引入

至今为止,我们所绘制的唯一图形,就是通过strokeRect()绘制矩形,也使用fillRect()进行填充。这两个方法都是立即生效的,的。

立即生效的Canvas API中的方法:

  • strokeRect()
  • fillRect()
  • strokeText()
  • fillText()

绘图环境中,可以绘制更为复杂的图形,如贝塞尔曲线等,这些方法都是基于路径(path)的。

大多数绘制系统,如SVG、Apple的Cocoa框架、Adobe illustrator等,都是基于路径的,使用这些绘制系统时,都是先定义一个路径,然后对其描边或填充。图示演示了三种绘制方式(描边、填充、描边和填充)。

案例

介绍

分别用矩形、开放路径、闭合路径演示三种不同的绘制方式。

在线演示

https://827652549.github.io/Canvas/Unit2/PathStrokeFill.html

效果图

闭合路径的代码实现比开放路径多写了一条closePath,用于将此时的路径从当前点回到起点。

代码

https://github.com/827652549/CanvasStudy/blob/master/Unit2/PathStrokeFill.html

路径

CanvasRenderingContext2D之中与路径有关的方法
方法描述
arc(x,y,r,sAngle,eAngle,true)

在当前路径中添加一段表示圆弧或圆形的子路径。五个参数分别是:

x坐标,y坐标,半径,起始角,结束角,(顺/逆时针)

beginPath()清除所有子路径,开始一段新路径
closePath()将当前路径位置连接到起点
fill()使用fillStyle对当前路径内部进行填充
rect(x,y,width,height)创建一个矩形
stroke()使用strokeStyle对当前路径进行描边

路径与隐形墨水

这是一个恰当对比喻,用来说明“创建路径随后对其进行描边或填充”,我们将这个操作比作“使用隐形墨水来绘图”。

你用隐形墨水所控制对内容不会立即显示出来,但你可以调节隐形墨水的颜色,笔尖宽度等等,最后用“特殊的方法(fill或stroke)”将图像显示出来。

子路径 

在某一时刻,canvas之中只能有一条路径存在,Canvas规范将其称为“当前路径(current path)”,这条路径可以包含很多子路径(subpath):有两个或更多的点组成。

为了理解什么是子路径,我们先来看一段代码:

context.beginPath();context.rect(10,10,100,100);
context.stroke();context.beginPath();context.rect(30,30,100,100);
context.stroke();

首先调用一次beginPath()开启一段新路径,该方法会将当前路径中所有子路径都清除掉,然后调用rect()方法,该方法向当前路径中添加了一个含有4个点的子路径,最后调用stroke()方法描边显形。

接下来再次调用了beginPath()方法,清除了上次调用rect()方法所创建的子路径(指那个矩形路径),然后再添加了另一个矩形子路径,最后进行描边显形。

如果我们第二次不调用beginPath()方法,那么此时路径便有两个矩形,那么第二次stroke()时便又会重新绘制一遍第一个矩形。当然,我们也可以同时删除第一个stroke()和第二个beginPath()来达到同样的效果,但为了让你理解,我有意这么做。

个人认为,子路径(subpath)不应该这么翻译,容易与继承关系中的“父子”中的“子”混淆,在Canvas这个应用场景中,被翻译成“补充路径”应该更容易理解。个人愚见,还请多指教。

填充路径中的“非零环绕规则”

如果当路径是循环的,或者包含多个相交的子路径,那fill()就会按照“非零环绕规则(nonzero winding rule)”来判断填充哪些区域。

“非零环绕规则”的判断过程

  1. 对于路径中的任意给定区域,在区域内画一条足够长的线段,使线段终点完全落于路径范围之外。(图中三个箭头表示此过程)
  2. 计数器初始化为0,对于每一条线段来说,每当线段与路径顺时针部分相交时+1,与路径逆时针部分相交时-1。
  3. 如果计数器最终值不是0,则证明在内部,如果是0,则证明在外部。仅填充在内部的区域。

以上图为例

上箭头与逆时针相交,计数器结果-1,填充;

右箭头与两个逆时针相交,结果-2,填充;

左箭头同时与一个顺时针和逆时针路径相交,结果为0,不填充。

这篇关于【绘制】HTML5 Canvas 中路径(path)、描边(stroke)与填充(fill)详细介绍(图文、代码示例)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/253486

相关文章

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

Java高效实现PowerPoint转PDF的示例详解

《Java高效实现PowerPoint转PDF的示例详解》在日常开发或办公场景中,经常需要将PowerPoint演示文稿(PPT/PPTX)转换为PDF,本文将介绍从基础转换到高级设置的多种用法,大家... 目录为什么要将 PowerPoint 转换为 PDF安装 Spire.Presentation fo

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

使用Java填充Word模板的操作指南

《使用Java填充Word模板的操作指南》本文介绍了Java填充Word模板的实现方法,包括文本、列表和复选框的填充,首先通过Word域功能设置模板变量,然后使用poi-tl、aspose-words... 目录前言一、设置word模板普通字段列表字段复选框二、代码1. 引入POM2. 模板放入项目3.代码