HTML5 Canvas实现玫瑰曲线和心形图案的代码实例


Posted in HTML / CSS onApril 10, 2014

效果图:
HTML5 Canvas实现玫瑰曲线和心形图案的代码实例 

HTML5 Canvas实现玫瑰曲线和心形图案的代码实例

提示:把代码复制到一个html文件中并保存,直接打开即可看到效果。

实现代码:
 

 

<!DOCTYPE html>
<html>
<head>
<meta charset = "gbk">
<title>HTML5 Demo</title>
<style type="text/css">
#apDiv1 {
position:absolute;
width:120px;
height:300px;
z-index:1;
left: 840px;
top: 80px;
}
</style>
</head>
<body>
<canvas id="canvas" width="800" height="600" style="border:1px solid #c3c3c3;"> 
Your browser does not support the canvas element. </canvas> 
<div id="apDiv1">
<form>
玫瑰曲线方程:<br>
r=a+bsin(m/n*x)<br><br>
选择参数:<br><br>
m: <input type="number" name="m" min="2" max="29" value="29"/><br><br>
n: <input type="number" name="n" min="1" max="12" value="11"/><br><br>
a: <input type="number" name="a" min="0" max="5" value="1"/><br><br>
b: <input type="number" name="b" min="1" max="7" value="5"/><br><br>
<input type="button" value=" 画 图 " onClick="draw();"><br><br>
<hr><br>
<input type="button" value=" 画 图 2 " onClick="draw2();"><br><br>
<hr><br>
<input type="button" value=" 心形图 " onClick="draw3();"><br>
</form>
</div>
<script type="text/javascript"> 
function draw() { 
var ctx = document.getElementById('canvas').getContext('2d'); 
ctx.save(); 
ctx.translate(400,300); 
ctx.clearRect(-400,-300,800,600);
ctx.strokeStyle = "#cc0000"; 
var a = 0, b = 1, m = 6, n = 1;
m = document.forms[0].m.value;
n = document.forms[0].n.value;
a = document.forms[0].a.value; 
b = document.forms[0].b.value; 
drawRose(ctx,a,b,m,n); 
ctx.restore(); 
} 
function drawRose(ctx,a,b,m,n){ 
ctx.beginPath(); 
var e = 0, c = 120; 
var k = 2 * Math.PI / 360;
do { 
var r = a/b + Math.sin( m * e / n * k);
r = r * c; 
var x = r * Math.cos( e * k );
var y = r * Math.sin( e * k );
e += 0.1; 
ctx.lineTo(x,y); 
} while ( e <= 4320 ); 
ctx.stroke(); 
} 
function draw2(){ 
var ctx = document.getElementById('canvas').getContext('2d'); 
ctx.save(); 
ctx.translate(400,300); 
ctx.clearRect(-400,-300,800,600);
ctx.strokeStyle = "#cc0000"; 
ctx.beginPath(); //ctx.moveTo(0,0);
var e = 0, c = 150; 
var k = 2 * Math.PI / 360;
do { 
x = 150*Math.cos( 5/2 * e*k ) + 50*Math.cos( 15/16 * 5/2 * e*k ); 
y = 150*Math.sin( 5/2 * e*k ) - 50*Math.sin( 15/16 * 5/2 * e*k ); 
e += 0.1; 
ctx.lineTo(x,y); 
} while ( e <= 3600 ); 
ctx.stroke(); 
ctx.restore();
} 
function draw3(){ 
var ctx = document.getElementById('canvas').getContext('2d'); 
ctx.save(); 
ctx.translate(400,300); 
ctx.clearRect(-400,-300,800,600);
ctx.strokeStyle = "#ff0000"; 
ctx.beginPath(); 
var x = 1, y;
do { 
y = -80*(Math.sqrt(1-x*x) + Math.pow(x*x,1/3)); 
x -= 0.001; 
ctx.lineTo(100*x,y); 
} while ( x >= -1 ); 

do { 
y = 80*(Math.sqrt(1-x*x) - Math.pow(x*x,1/3)); 
x += 0.001; 
ctx.lineTo(100*x,y); 
} while ( x <= 1 );
ctx.closePath(); 

var grad = ctx.createRadialGradient(-40,-60,10,-40,-40,200);
grad.addColorStop(0, "#ffcc00"); 
grad.addColorStop(1, "#ff0000"); 
ctx.fillStyle = grad;
ctx.fill();
// ctx.stroke(); 
ctx.restore();
} 
window.onload = function (){ 
draw();
} 
</script>
</body>
</html>

 

HTML / CSS 相关文章推荐
利用CSS3实现自定义滚动条代码分享
Aug 18 HTML / CSS
手把手教你用纯css3实现轮播图效果实例
May 04 HTML / CSS
CSS3的文字阴影—text-shadow的使用方法
Dec 25 HTML / CSS
利用CSS3制作简单的3d半透明立方体图片展示
Mar 25 HTML / CSS
HTML5 Canvas图像模糊完美解决办法
Feb 06 HTML / CSS
使用canvas绘制超炫时钟
Dec 17 HTML / CSS
使用HTML5的Notification API制作web通知的教程
May 08 HTML / CSS
HTML5拖放API实现拖放排序的实例代码
May 11 HTML / CSS
微信小程序“圣诞帽”的实现思路详解
Dec 28 HTML / CSS
详解html5 canvas 微信海报分享(个人爬坑)
Jan 12 HTML / CSS
移动端HTML5开发神器之vconsole详解
Dec 15 HTML / CSS
HTML静态页面获取url参数和UserAgent的实现
Aug 05 HTML / CSS
使用HTML5捕捉音频与视频信息概述及实例
Aug 22 #HTML / CSS
CSS3只让背景图片旋转180度的实现示例
Mar 09 #HTML / CSS
CSS3 真的会替代 SCSS 吗
Mar 09 #HTML / CSS
css3实现书本翻页效果的示例代码
Mar 08 #HTML / CSS
纯CSS3实现圆圈动态发光特效动画的示例代码
Mar 08 #HTML / CSS
巧用 CSS3的webkit-box-reflect 倒影实现各类动效
Mar 05 #HTML / CSS
详解利用css3的var()实现运行时改变scss的变量值
Mar 02 #HTML / CSS
You might like
PHP下用rmdir实现删除目录的三种方法小结
2008/04/20 PHP
PHP中英混合字符串截取函数代码
2011/07/17 PHP
php查找任何页面上的所有链接的方法
2013/12/03 PHP
PHP代码优化技巧小结
2015/09/29 PHP
php实现概率性随机抽奖代码
2016/01/02 PHP
php设计模式之正面模式实例分析【星际争霸游戏案例】
2020/03/24 PHP
javascript 命名规则 变量命名规则
2010/02/25 Javascript
JavaScript replace(rgExp,fn)正则替换的用法
2010/03/04 Javascript
javaScript checkbox 全选/反选及批量删除
2010/04/28 Javascript
jquery绑定事件不生效的解决方法
2014/02/11 Javascript
JavaScript中双叹号(!!)作用示例介绍
2014/04/10 Javascript
jquery实现无限分级横向导航菜单的方法
2015/03/12 Javascript
jQuery+CSS实现滑动的标签分栏切换效果
2015/12/17 Javascript
Node.js开启Https的实践详解
2016/10/25 Javascript
AngularJS中指令的四种基本形式实例分析
2016/11/22 Javascript
Vue实例简单方法介绍
2017/01/20 Javascript
前端框架学习总结之Angular、React与Vue的比较详解
2017/03/14 Javascript
分析javascript中9 个常见错误阻碍你进步
2017/09/18 Javascript
移动端效果之IndexList详解
2017/10/20 Javascript
Angular17之Angular自定义指令详解
2018/01/21 Javascript
vue-cli 打包后提交到线上出现 &quot;Uncaught SyntaxError:Unexpected token&quot; 报错
2018/11/06 Javascript
JS使用iView的Dropdown实现一个右键菜单
2019/05/06 Javascript
vue集成openlayers加载geojson并实现点击弹窗教程
2020/09/24 Javascript
SpringBoot在yml配置文件中配置druid的操作
2020/11/16 Javascript
[11:12]2018DOTA2国际邀请赛寻真——绿色长城OpTic
2018/08/10 DOTA
分析Python编程时利用wxPython来支持多线程的方法
2015/04/07 Python
python查找指定具有相同内容文件的方法
2015/06/28 Python
详解Django之admin组件的使用和源码剖析
2018/05/04 Python
详解Python中@staticmethod和@classmethod区别及使用示例代码
2020/12/14 Python
2014年自我评价
2014/01/04 职场文书
幼儿园五一活动方案
2014/02/07 职场文书
婚礼秀策划方案
2014/05/19 职场文书
2014年污水处理厂工作总结
2014/12/19 职场文书
Python Matplotlib绘制条形图的全过程
2021/10/24 Python
宝塔更新Python及Flask项目的部署
2022/04/11 Python
vue router 动态路由清除方式
2022/05/25 Vue.js