html5中提供的绘图元素(使用Html5中的cavas画一面国旗)
类别:Web前端 浏览量:1256
时间:2021-10-09 00:38:48 html5中提供的绘图元素
使用Html5中的cavas画一面国旗使用Html5中的cavas画一面国旗,具体代码如下所示:
var canvas = document.getElementById("canvas");//创建一个cavas画板 var context = canvas.getContext('2d');//设置画板属性 var width=canvas.width; var height=width*2/3; context.fillStyle="red"; context.fillRect(0,0,width,height); var maxR = 0.15, minR = 0.05; var maxX = 0.55, maxY = 0.35;//大五星的位置 var minX = [0.80, 0.90, 0.90, 0.80,0.65,0.50,0.40];//各个小五角星的x坐标 var minY = [0.20, 0.30, 0.45, 0.55,0.60,0.60,0.50];//各个小五角星的y坐标 var ox = height * maxX, oy = height * maxY;
html代码
<canvas id="canvas" width="600" height="400"></canvas>
js代码
create5star(context,ox,oy,height * maxR,"#ff0",0);//绘制大五角星 for (var idx = 0; idx < 7; idx++) { var sx = minX[idx] * height, sy = minY[idx] * height; var theta = Math.atan((oy - sy)/(ox - sx)); create5star(context,sx, sy, height * minR, "#ff0",-Math.PI/2+theta); // 画小五角星 } //绘制五角星 function create5star(context,sx,sy,radius,color,rotato){ context.save(); context.fillStyle=color; context.translate(sx,sy);//移动坐标原点 context.rotate(Math.PI+rotato);//旋转 context.beginPath();//创建路径 var x = Math.sin(0); var y= Math.cos(0); var dig = Math.PI/5 *4; for(var i = 0;i< 5;i++){//画五角星的五条边 var x = Math.sin(i*dig); var y = Math.cos(i*dig); context.lineTo(x*radius,y*radius); } context.closePath(); context.stroke(); context.fill(); context.restore(); }
总结
以上所述是小编给大家介绍的使用Html5中的cavas画一面国旗,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对开心学习网网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
您可能感兴趣
- html5的优点是什么
- js如何解决iphone异形屏适配(Html5适配iphoneX刘海屏的简单实现)
- h5页面强制关注微信公众号(Html5页面获取微信公众号的openid的方法)
- ih5如何点击按钮跳转至网页(HTML5跳转小程序wx-open-launch-weapp的示例代码)
- html5拖动效果怎么写(Html5 滚动穿透的方法)
- html5菜单栏(html5写一个BUI折叠菜单插件的实现方法)
- HTMl5 sessionStorage和localStorage
- html5怎么修改背景颜色(HTML5 body设置全屏背景图片的示例代码)
- html5隐藏数字(HTML5去掉输入框type为number时的上下箭头的实现方法)
- php 处理html表单(PHP使用HTML5 FormData对象提交表单操作示例)
- html5元素列表(HTML5触摸事件touchstart、touchmove和touchend的实现)
- html5自定义字体图标(HTML5给汉字加拼音收起展开组件的实现代码)
- html5导航栏怎么设计(html5 横向滑动导航栏的方法示例)
- html5复制修改(HTML5实现无刷新修改URL的方法)
- html5标签图片(HTML5图片层叠的实现示例)
- html5video怎么优化(HTML5 video循环播放多个视频的方法步骤)
- 招财化煞神兽,金蟾变了(招财化煞神兽金蟾变了)
- 26岁杨紫的白素贞遇上24岁鞠婧祎,哪个最美(26岁杨紫的白素贞遇上24岁鞠婧祎)
- 鞠婧祎和杨紫两种风格的女生,你心里谁比较美(鞠婧祎和杨紫两种风格的女生)
- 三千年第一美女鞠婧祎出演白素贞pk杨紫,颜值胜赵雅芝王祖贤(三千年第一美女鞠婧祎出演白素贞pk杨紫)
- 成都轨道交通13号线一期工程最新进展(成都轨道交通13号线一期工程最新进展)
- 越南没事(越南没事情做)
热门推荐
- python面向对象基本思想(详解Python:面向对象编程)
- mysql8.0.23.0官方安装手册(MySQL8.0.23安装超详细教程)
- docker的启动的绝对命令(在docker中开启sshd操作)
- 简单laravel框架教程交流(使用composer 安装 laravel框架的方法图文详解)
- asp.net网站如何优化
- html5div怎样居中(HTML5+CSS设置浮动却没有动反而在中间且错行的问题)
- css3基础选择器有哪些(对CSS3选择器的研究详解)
- python语句for循环(Python基础之循环语句用法示例for、while循环)
- css导航栏字怎么分开设置(纯CSS实现导航栏Tab切换效果)
- web服务器与应用服务器的区别(web服务器是什么?web服务器有哪些呢?)