0

0

在HTML5的CANVAS上绘制椭圆的几种方法

php中文网

php中文网

发布时间:2016-05-17 09:08:43

|

2021人浏览过

|

来源于php中文网

原创

  HTML5中的Canvas并没有直接提供绘制椭圆的方法,下面是对几种绘制方法的总结。各种方法各有优缺,视情况选用。各方法的参数相同:


  •   context为Canvas的2D绘图环境对象,
  •   x为椭圆中心横坐标,
  •   y为椭圆中心纵坐标,
  •   a为椭圆横半轴长,
  •   b为椭圆纵半轴长。



  参数方程法


  该方法利用椭圆的参数方程来绘制椭圆
  1. //-----------用参数方程绘制椭圆---------------------
  2. //函数的参数x,y为椭圆中心;a,b分别为椭圆横半轴、
  3. //纵半轴长度,不可同时为0
  4. //该方法的缺点是,当linWidth较宽,椭圆较扁时
  5. //椭圆内部长轴端较为尖锐,不平滑,效率较低
  6. function ParamEllipse(context, x, y, a, b)
  7. {
  8.    //max是等于1除以长轴值a和b中的较大者
  9.    //i每次循环增加1/max,表示度数的增加
  10.    //这样可以使得每次循环所绘制的路径(弧线)接近1像素
  11.    var step = (a > b) ? 1 / a : 1 / b;
  12.    context.beginPath();
  13.    context.moveTo(x + a, y); //从椭圆的左端点开始绘制
  14.    for (var i = 0; i
  15.    {
  16.       //参数方程为x = a * cos(i), y = b * sin(i),
  17.       //参数为i,表示度数(弧度)
  18.       context.lineTo(x + a * Math.cos(i), y + b * Math.sin(i));
  19.    }
  20.    context.closePath();
  21.    context.stroke();
  22. };
复制代码

  均匀压缩法


  这种方法利用了数学中的均匀压缩原理将圆进行均匀压缩为椭圆,理论上为能够得到标准的椭圆.
  1. //------------均匀压缩法绘制椭圆--------------------
  2. //其方法是用arc方法绘制圆,结合scale进行
  3. //横轴或纵轴方向缩放(均匀压缩)
  4. //这种方法绘制的椭圆的边离长轴端越近越粗,长轴端点的线宽是正常值
  5. //边离短轴越近、椭圆越扁越细,甚至产生间断,这是scale导致的结果
  6. //这种缺点某些时候是优点,比如在表现环的立体效果(行星光环)时
  7. //对于参数a或b为0的情况,这种方法不适用
  8. function EvenCompEllipse(context, x, y, a, b)
  9. {
  10.    context.save();
  11.    //选择a、b中的较大者作为arc方法的半径参数
  12.    var r = (a > b) ? a : b;
  13.    var ratioX = a / r; //横轴缩放比率
  14.    var ratioY = b / r; //纵轴缩放比率
  15.    context.scale(ratioX, ratioY); //进行缩放(均匀压缩)
  16.    context.beginPath();
  17.    //从椭圆的左端点开始逆时针绘制
  18.    context.moveTo((x + a) / ratioX, y / ratioY);
  19.    context.arc(x / ratioX, y / ratioY, r, 0, 2 * Math.PI);
  20.    context.closePath();
  21.    context.stroke();
  22.    context.restore();
  23. };
复制代码


      下面的代码会出现线宽不一致的问题,解决办法:


     均匀压缩法中把
  context.stroke();  context.restore();
  改為
  context.restore();  context.stroke();
  就可以

        三次贝塞尔曲线法一


  三次贝塞尔曲线绘制椭圆在实际绘制时是一种近似,在理论上也是一种近似。 但因为其效率较高,在计算机矢量图形学中,常用于绘制椭圆,但是具体的理论我不是很清楚。 近似程度在于两个控制点位置的选取。这种方法的控制点位置是我自己试验得出,精度还可以.
  1. //---------使用三次贝塞尔曲线模拟椭圆1---------------------
  2. //此方法也会产生当lineWidth较宽,椭圆较扁时,
  3. //长轴端较尖锐,不平滑的现象
  4. function BezierEllipse1(context, x, y, a, b)
  5. {
  6.    //关键是bezierCurveTo中两个控制点的设置
  7.    //0.5和0.6是两个关键系数(在本函数中为试验而得)
  8.    var ox = 0.5 * a,
  9.        oy = 0.6 * b;

  10.    context.save();
  11.    context.translate(x, y);
  12.    context.beginPath();
  13.    //从椭圆纵轴下端开始逆时针方向绘制
  14.    context.moveTo(0, b);
  15.    context.bezierCurveTo(ox, b, a, oy, a, 0);
  16.    context.bezierCurveTo(a, -oy, ox, -b, 0, -b);
  17.    context.bezierCurveTo(-ox, -b, -a, -oy, -a, 0);
  18.    context.bezierCurveTo(-a, oy, -ox, b, 0, b);
  19.    context.closePath();
  20.    context.stroke();
  21.    context.restore();

  22. };
复制代码

  三次贝塞尔曲线法二


  这种方法是从StackOverFlow中一个帖子的回复中改变而来,精度较高,也是通常用来绘制椭圆的方法.
  1. //---------使用三次贝塞尔曲线模拟椭圆2---------------------
  2. //此方法也会产生当lineWidth较宽,椭圆较扁时
  3. //,长轴端较尖锐,不平滑的现象
  4. //这种方法比前一个贝塞尔方法精确度高,但效率稍差
  5. function BezierEllipse2(ctx, x, y, a, b)
  6. {
  7.    var k = .5522848,
  8.    ox = a * k, // 水平控制点偏移量
  9.    oy = b * k; // 垂直控制点偏移量

  10.    ctx.beginPath();
  11.    //从椭圆的左端点开始顺时针绘制四条三次贝塞尔曲线
  12.    ctx.moveTo(x - a, y);
  13.    ctx.bezierCurveTo(x - a, y - oy, x - ox, y - b, x, y - b);
  14.    ctx.bezierCurveTo(x + ox, y - b, x + a, y - oy, x + a, y);
  15.    ctx.bezierCurveTo(x + a, y + oy, x + ox, y + b, x, y + b);
  16.    ctx.bezierCurveTo(x - ox, y + b, x - a, y + oy, x - a, y);
  17.    ctx.closePath();
  18.    ctx.stroke();
  19. };
复制代码


  光栅法


  这种方法可以根据Canvas能够操作像素的特点,利用图形学中的基本算法来绘制椭圆。 例如中点画椭圆算法等。


  其中一个例子是园友“豆豆狗”的一篇博文“HTML5 Canvas 提高班(一) —— 光栅图形学(1)中点画圆算法”。这种方法由于比较“原始”,灵活性大,效率高,精度高,但要想实现一个有使用价值的绘制椭圆的函数,比较复杂。比如,要当线宽改变时,算法就复杂一些。

      原文出自:Cloudy Waterman

相关文章

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Golang 网络安全与加密实战
Golang 网络安全与加密实战

本专题系统讲解 Golang 在网络安全与加密技术中的应用,包括对称加密与非对称加密(AES、RSA)、哈希与数字签名、JWT身份认证、SSL/TLS 安全通信、常见网络攻击防范(如SQL注入、XSS、CSRF)及其防护措施。通过实战案例,帮助学习者掌握 如何使用 Go 语言保障网络通信的安全性,保护用户数据与隐私。

2

2026.01.29

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

434

2026.01.28

包子漫画在线官方入口大全
包子漫画在线官方入口大全

本合集汇总了包子漫画2026最新官方在线观看入口,涵盖备用域名、正版无广告链接及多端适配地址,助你畅享12700+高清漫画资源。阅读专题下面的文章了解更多详细内容。

141

2026.01.28

ao3中文版官网地址大全
ao3中文版官网地址大全

AO3最新中文版官网入口合集,汇总2026年主站及国内优化镜像链接,支持简体中文界面、无广告阅读与多设备同步。阅读专题下面的文章了解更多详细内容。

251

2026.01.28

php怎么写接口教程
php怎么写接口教程

本合集涵盖PHP接口开发基础、RESTful API设计、数据交互与安全处理等实用教程,助你快速掌握PHP接口编写技巧。阅读专题下面的文章了解更多详细内容。

8

2026.01.28

php中文乱码如何解决
php中文乱码如何解决

本文整理了php中文乱码如何解决及解决方法,阅读节专题下面的文章了解更多详细内容。

13

2026.01.28

Java 消息队列与异步架构实战
Java 消息队列与异步架构实战

本专题系统讲解 Java 在消息队列与异步系统架构中的核心应用,涵盖消息队列基本原理、Kafka 与 RabbitMQ 的使用场景对比、生产者与消费者模型、消息可靠性与顺序性保障、重复消费与幂等处理,以及在高并发系统中的异步解耦设计。通过实战案例,帮助学习者掌握 使用 Java 构建高吞吐、高可靠异步消息系统的完整思路。

10

2026.01.28

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

24

2026.01.27

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

124

2026.01.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Node.js 教程
Node.js 教程

共57课时 | 9.6万人学习

CSS3 教程
CSS3 教程

共18课时 | 5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号