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样式linear-gradient的使用实例
Jan 16 HTML / CSS
CSS书写规范、顺序和命名规则
Mar 06 HTML / CSS
css3实现3d旋转动画特效
Mar 10 HTML / CSS
CSS3中的clip-path使用攻略
Aug 03 HTML / CSS
css3 中translate和transition的使用方法
Mar 26 HTML / CSS
详解Html5 Canvas画线有毛边解决方法
Mar 01 HTML / CSS
阻止移动设备(手机、pad)浏览器双击放大网页的方法
Jun 03 HTML / CSS
Html5页面二次分享的实现
Jul 30 HTML / CSS
Html5调用手机摄像头并实现人脸识别的实现
Dec 21 HTML / CSS
吃透移动端 Html5 响应式布局
Dec 16 HTML / CSS
详解CSS伪元素的妙用单标签之美
May 25 HTML / CSS
CSS实现章节添加自增序号的方法
Jun 23 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(3)
2006/10/09 PHP
献给php初学者(入门学习经验谈)
2010/10/12 PHP
php使用parse_url和parse_str解析URL
2015/02/22 PHP
Ubuntu中启用php的mail()函数并解决发送邮件速度慢问题
2015/03/27 PHP
PHP 芝麻信用接入的注意事项
2016/12/01 PHP
laravel项目利用twemproxy部署redis集群的完整步骤
2018/05/11 PHP
JavaScript实现动态增加文件域表单
2009/02/12 Javascript
javascript检测浏览器flash版本的实现代码
2011/12/06 Javascript
js自定义事件及事件交互原理概述(二)
2013/02/01 Javascript
jQuery实现鼠标经过图片预览大图效果
2014/04/10 Javascript
一个css与js结合的下拉菜单支持主流浏览器
2014/10/08 Javascript
JSON格式化输出
2014/11/10 Javascript
js实现年月日表单三级联动
2020/04/17 Javascript
JQuery实现图片轮播效果
2017/05/08 jQuery
老生常谈js中的MVC
2017/07/25 Javascript
Vue使用Proxy监听所有接口状态的方法实现
2019/06/07 Javascript
JavaScript进阶(二)词法作用域与作用域链实例分析
2020/05/09 Javascript
python Django框架实现自定义表单提交
2016/03/25 Python
对Python中for复合语句的使用示例讲解
2018/11/01 Python
Python中函数的返回值示例浅析
2019/08/28 Python
python 实现批量替换文本中的某部分内容
2019/12/13 Python
Python中itertools的用法详解
2020/02/07 Python
python里反向传播算法详解
2020/11/22 Python
使用Python判断一个文件是否被占用的方法教程
2020/12/16 Python
TripAdvisor日本:全球领先的旅游网站
2019/02/14 全球购物
数学检讨书1000字
2014/02/24 职场文书
彩色的翅膀教学反思
2014/04/25 职场文书
大学生通用个人自我评价
2014/04/27 职场文书
党员目标管理责任书
2014/07/25 职场文书
2014年乡镇卫生院工作总结
2014/11/24 职场文书
2015元旦节寄语
2014/12/08 职场文书
2015年调度员工作总结
2015/04/30 职场文书
南极大冒险观后感
2015/06/05 职场文书
企业安全生产规章制度
2015/08/06 职场文书
2016春季校长开学典礼致辞
2015/11/26 职场文书
javascript canvas实现雨滴效果
2021/06/09 Javascript