iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >利用canvas怎么绘制一个多边形
  • 710
分享到

利用canvas怎么绘制一个多边形

2023-06-09 14:06:27 710人浏览 泡泡鱼
摘要

利用canvas怎么绘制一个多边形?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 初始化js代码  //初始化  (function()

利用canvas怎么绘制一个多边形?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

初始化js代码

  //初始化  (function(){    var canvas = document.createElement('canvas');    document.body.appendChild(canvas);    canvas.height = mH;    canvas.width = mW;    mCtx = canvas.getContext('2d');    drawPolyGon(mCtx); // 绘制多边形边    drawLines(mCtx); //顶点连线    drawText(mCtx); // 绘制文本    drawRegion(mCtx);  // 绘制数据    drawCircle(mCtx);  // 画数据圆点  })();

上面代码中,通过一个立即执行函数,进行对所有的设置进行初始化,对于canvas正六边形的画法,可参见canvas画正六边形

在蜘蛛图中,我们可以进行拆分一下,通过画六边形,直线,圆圈的方式,分别进行完整个体的组件,然后通过方法进行统一调用绘制

如下面所示源代码:

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>蜘蛛图canvas</title>    <style type="text/CSS">        canvas{        }    </style></head><body><script type="text/javascript">  var mW = 400;  var mH = 400;  var mData = [['法力', 77],['防御', 72],['生命值', 46],['物理伤害', 50],['回复值', 80],['耐力', 60]];  var mCount = mData.length; //边数  var mCenter = mW /2; //中心点  var mRadius = mCenter - 100; //半径(减去的值用于给绘制的文本留空间)  var mAngle = Math.PI * 2 / mCount; //角度  var mCtx = null;  var mColorPolygon = '#B8B8B8'; //多边形颜色  var mColorLines = '#B8B8B8'; //顶点连线颜色  var mColorText = '#000000';  //初始化  (function(){    var canvas = document.createElement('canvas');    document.body.appendChild(canvas);    canvas.height = mH;    canvas.width = mW;    mCtx = canvas.getContext('2d');    drawPolygon(mCtx);    drawLines(mCtx);    drawText(mCtx);    drawRegion(mCtx);    drawCircle(mCtx);  })();  // 绘制多边形边  function drawPolygon(ctx){    ctx.save(); // save the default state    ctx.strokeStyle = mColorPolygon;    var r = mRadius/ mCount; //单位半径    //画6个圈    for(var i = 0; i < mCount; i ++){      ctx.beginPath(); //开始路径      var currR = r * ( i + 1); //当前半径      //画6条边      for(var j = 0; j < mCount; j ++) {        var x = mCenter + currR * Math.cos(mAngle * j);        var y = mCenter + currR * Math.sin(mAngle * j);        console.log('x:' + x, 'y:' + y);        ctx.lineTo(x, y);      }      ctx.closePath();  //闭合路径      ctx.stroke();    }    ctx.restore(); // restore to the default state  }  //顶点连线  function drawLines(ctx){    ctx.save();    ctx.beginPath();    ctx.strokeStyle = mColorLines;    for(var i = 0; i < mCount; i ++){      var x = mCenter + mRadius * Math.cos(mAngle * i);      var y = mCenter + mRadius * Math.sin(mAngle * i);      ctx.moveTo(mCenter, mCenter);      ctx.lineTo(x, y);    }    ctx.stroke();    ctx.restore();  }  //绘制文本  function drawText(ctx){    ctx.save();    var fontSize = mCenter / 12;    ctx.font = fontSize + 'px Microsoft Yahei';    ctx.fillStyle = mColorText;    for(var i = 0; i < mCount; i ++){      var x = mCenter + mRadius * Math.cos(mAngle * i);      var y = mCenter + mRadius * Math.sin(mAngle * i);      if( mAngle * i >= 0 && mAngle * i <= Math.PI / 2 ){        ctx.fillText(mData[i][0], x, y + fontSize);      }else if(mAngle * i > Math.PI / 2 && mAngle * i <= Math.PI){        ctx.fillText(mData[i][0], x - ctx.measureText(mData[i][0]).width, y + fontSize);      }else if(mAngle * i > Math.PI && mAngle * i <= Math.PI * 3 / 2){        ctx.fillText(mData[i][0], x - ctx.measureText(mData[i][0]).width, y);      }else{        ctx.fillText(mData[i][0], x, y);      }    }    ctx.restore();  }  //绘制数据区域  function drawRegion(ctx){    ctx.save();    ctx.beginPath();    for(var i = 0; i < mCount; i ++){      var x = mCenter + mRadius * Math.cos(mAngle * i) * mData[i][1] / 100;      var y = mCenter + mRadius * Math.sin(mAngle * i) * mData[i][1] / 100;      ctx.lineTo(x, y);    }    ctx.closePath();    ctx.fillStyle = 'rgba(255, 0, 0, 0.5)';    ctx.fill();    ctx.restore();  }  //画点  function drawCircle(ctx){    ctx.save();    var r = mCenter / 18;    for(var i = 0; i < mCount; i ++){      var x = mCenter + mRadius * Math.cos(mAngle * i) * mData[i][1] / 100;      var y = mCenter + mRadius * Math.sin(mAngle * i) * mData[i][1] / 100;      ctx.beginPath();      ctx.arc(x, y, r, 0, Math.PI * 2);      ctx.fillStyle = 'rgba(255, 0, 0, 0.8)';      ctx.fill();    }    ctx.restore();  }</script></body></html>

看完上述内容,你们掌握利用canvas怎么绘制一个多边形的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网精选频道,感谢各位的阅读!

--结束END--

本文标题: 利用canvas怎么绘制一个多边形

本文链接: https://www.lsjlt.com/news/256442.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • c#怎么判断文件夹是否存在
    如何用 c# 判断文件夹是否存在?使用 directory.exists 方法,指定文件夹路径,获取布尔值判断是否存在。若不存在,使用 directory.createdirectory...
    99+
    2024-05-14
    c#
  • c#文件路径引用变量怎么写
    在 c# 中,您可以通过字符串插值或 string.format 方法将变量引用到文件路径中。字符串插值使用 ${} 语法,而 string.format 方法需要提供格式字符串和要插入...
    99+
    2024-05-14
    c#
  • C++ 原子库的使用和限制
    c++++ 原子库提供线程安全的数据类型,以确保数据原子性。原子变量是不可中断的,并且提供了广泛的原子操作,包括加、减和交换。常见的类型包括 std::atomic 和 std::ato...
    99+
    2024-05-14
    c++ 原子库
  • c#中怎么定义全局变量
    在 c# 中定义全局变量:在类或方法外声明,使用语法:access_modifier type variable_name;可用 access_modifier 修饰符:public、p...
    99+
    2024-05-14
    access c#
  • c#怎么调用另一个类的方法
    在 c# 中调用另一个类的方法有三种方式:直接调用:创建该类的实例,然后使用实例调用方法。通过接口调用:创建接口,定义要调用的方法;创建实现该接口的类;使用接口创建类的实例,然后通过接口...
    99+
    2024-05-14
    c#
  • C++ 服务器架构的未来发展趋势和最佳实践
    未来c++++服务器架构趋势包括:异步和非阻塞编程可提升性能;微服务架构提高可扩展性和灵活性;云原生设计带来无状态性和可观测性。最佳实践包括:使用libcuckoo优化数据存储;采用tc...
    99+
    2024-05-14
    c++ 服务器架构 docker 高可扩展性
  • c#多线程访问同一变量应该怎么解决
    解决 c# 多线程访问同一变量的问题的方法如下:使用锁(lock)使用互斥体(mutex)使用自旋锁(spinlock)使用原子操作 处理 C# 多线程访问同一变量问题 多线程编程中,...
    99+
    2024-05-14
    c# 同步机制
  • c#数据表怎么建立时间列
    在 c# datatables 中创建时间列只需 4 个步骤:创建 datatable。创建并指定 datetime 类型的 datacolumn。将 datacolumn 添加到 da...
    99+
    2024-05-14
    c#
  • c#怎么把类实例化
    在c#中,实例化一个类是创建一个类的对象,使用new关键字,如:类名 对象名 = new 类名()。构造函数是实例化类时调用的特殊方法,用于初始化属性,如:public person(s...
    99+
    2024-05-14
    c#
  • PHP数据结构:链表的魅力,探索动态数据组织
    链表是一种数据结构,采用一系列带有数据和指针的节点组织元素,特别适合处理大型数据集和频繁的插入/删除操作。它的基本组成部分包括节点(数据和指向下一个节点的指针)和头节点(指向链表中第一个...
    99+
    2024-05-14
    php 链表
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作