当前位置: 首页 > news >正文

贝塞尔曲线详细讲解,如何用 Canvas 绘制三阶贝塞尔曲线?

比如我们要画一个这样的曲线,我们该怎么画了

两个点Y轴一样高,起点:(200,100)终点:(300,100)中间的弧度怎么弄了?

  <canvas id="c1" width="600" height="400"></canvas><script>// 1. 找到画布var c1 = document.getElementById("c1");// 判断是否有getContextif (!c1.getContext) {console.log("当前浏览器不支持canvas,请下载最新的浏览器");}// 2. 获取画笔,上下文对象var ctx = c1.getContext("2d");ctx.beginPath();// 起点ctx.moveTo(200,100)//终点var zh=[300,100]//控制点1的(190,50)也是按照横纵坐标//控制点2(280,70)也是按照横纵坐标ctx.bezierCurveTo(190,50,280,70,zh[0],zh[1]);ctx.stroke();ctx.closePath();</script>

 ctx.bezierCurveTo(190,50,280,70,zh[0],zh[1]);
一共6个参数,起那两个为控制点横纵坐标,最后两个参数为终点的横纵坐标。中间控制点可以不止两个

这样就出现了,不像的话可以详细调整数值。

<canvas id="c1" width="600" height="400"></canvas><script>// 1. 找到画布var c1 = document.getElementById("c1");// 判断是否有getContextif (!c1.getContext) {console.log("当前浏览器不支持canvas,请下载最新的浏览器");}// 2. 获取画笔,上下文对象var ctx = c1.getContext("2d");ctx.beginPath();// 起点ctx.moveTo(200,100)//终点var zh=[300,100]//控制点1的(190,50)也是按照横纵坐标//控制点2(280,70)也是按照横纵坐标ctx.bezierCurveTo(190,50,280,70,200,150);// 第二个起点ctx.moveTo(200,150)ctx.bezierCurveTo(120,70,210,50,200,100);ctx.stroke();ctx.closePath();</script>

http://www.lryc.cn/news/457054.html

相关文章:

  • Ubuntu20.04卸载ros2 foxy版本安装ros1 noetic版本
  • PicGo+Gitee搭建Typora图床
  • MySQL 脱敏函数使用详解:保护数据隐私的关键手段
  • nginx之virtual host
  • Windows 下纯手工打造 QT 开发环境
  • k8s的安装和部署
  • 第十八篇:一文说清楚ICMP的底层原理
  • 【优选算法】(第三十二篇)
  • 线程(四)线程的同步——条件变量
  • 二维数组的旋转与翻转(C++)(上(这只是简单讲解))
  • 【在Linux世界中追寻伟大的One Piece】System V共享内存
  • 【大数据】Spark弹性分布式数据集RDD详细说明
  • 人参玉桂膏简介
  • 消费者Rebalance机制
  • 消息队列介绍
  • 告别@Value,Spring Boot 3.3更优雅的配置注入方案
  • 甲虫身体图像分割系统源码&数据集分享
  • Qt - QMenu
  • 舵机驱动详解(模拟/数字 STM32)
  • dvwa:文件包含、文件上传
  • 基于 C# .NET Framework 4.0 开发实现 WCF 服务实例详解(二)——实现Windows服务内嵌WCF服务
  • 【ArcGIS/C#】调用控制台处理代码
  • 06_23 种设计模式之《适配器模式》
  • Go语言--快速入门
  • 京东云主机怎么用?使用京东云服务器建网站(图文教程)
  • Linux 基础入门操作-实验七 进程的介绍
  • SQL进阶技巧:SQL中的正则表达式应用?
  • 算法数组面试理论
  • ASP.NET Zero是什么?适合哪些业务场景?
  • 获取期货股票分钟级别数据以及均线策略