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 选择器 基本选择器介绍
Jan 21 HTML / CSS
html5 利用canvas手写签名并保存的实现方法
Jul 12 HTML / CSS
一个不错的HTML5 Canvas多层点击事件监听实例
Apr 29 HTML / CSS
html5 更新图片颜色示例代码
Jul 29 HTML / CSS
html5定位获取当前位置并在百度地图上显示
Aug 22 HTML / CSS
phonegap常用事件总结(必看篇)
Mar 31 HTML / CSS
html5 figure和figcaption的使用方法
Sep 10 HTML / CSS
使用canvas来完成线性渐变和径向渐变的功能的方法示例
Jul 25 HTML / CSS
html5给汉字加拼音加进度条的实现代码
Apr 07 HTML / CSS
AmazeUI 评论列表的实现示例
Aug 13 HTML / CSS
HTML基础-标签分类(闭合标签,空标签,块级元素,行内元素,行级块元素,可替换元素)
Mar 31 HTML / CSS
CSS中理解层叠性及权重如何分配
Dec 24 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创建桌面快捷方式的实例代码
2014/02/17 PHP
PHP标准类(stdclass)用法示例
2016/09/28 PHP
javascript中的undefined 与 null 的区别  补充篇
2010/03/17 Javascript
在网页中使用document.write时遭遇的奇怪问题
2010/08/24 Javascript
jquery常用技巧及常用方法列表集合
2011/04/06 Javascript
jQuery焦点图切换简易插件制作过程全纪录
2014/08/27 Javascript
Javascript中的方法和匿名方法实例详解
2015/06/13 Javascript
jQuery过滤HTML标签并高亮显示关键字的方法
2015/08/07 Javascript
基于JavaScript实现仿京东图片轮播效果
2015/11/06 Javascript
基于JavaScript如何实现ajax调用后台定义的方法
2015/12/29 Javascript
简单的jQuery banner图片轮播实例代码
2016/03/04 Javascript
Node.js 实现简单小说爬虫实例
2016/11/18 Javascript
JavaScript实现点击按钮复制指定区域文本(推荐)
2016/11/25 Javascript
react配合antd组件实现的管理系统示例代码
2018/04/24 Javascript
vue实现todolist功能、todolist组件拆分及todolist的删除功能
2019/04/11 Javascript
VUEX 数据持久化,刷新后重新获取的例子
2019/11/12 Javascript
jQuery 图片查看器插件 Viewer.js用法简单示例
2020/04/04 jQuery
python网页请求urllib2模块简单封装代码
2014/02/07 Python
python openvc 裁剪、剪切图片 提取图片的行和列
2019/09/19 Python
Python各种扩展名区别点整理
2020/02/27 Python
利用Python的folium包绘制城市道路图的实现示例
2020/08/24 Python
香港万宁官方海外旗舰店:香港健与美连锁店
2018/09/27 全球购物
小学校园活动策划
2014/01/30 职场文书
中介业务员岗位职责
2014/04/09 职场文书
学习十八大的心得体会
2014/09/01 职场文书
毕业实习证明(4篇)
2014/10/28 职场文书
东京审判观后感
2015/06/01 职场文书
幼儿园小班教育随笔
2015/08/14 职场文书
装修安全责任协议书
2016/03/22 职场文书
MySQL root密码的重置方法
2021/04/21 MySQL
MySQL 覆盖索引的优点
2021/05/19 MySQL
用Python进行栅格数据的分区统计和批量提取
2021/05/27 Python
Python pandas求方差和标准差的方法实例
2021/08/04 Python
vue项目配置sass及引入外部scss文件
2022/04/14 Vue.js
解决spring.thymeleaf.cache=false不起作用的问题
2022/06/10 Java/Android
Navicat Premium自定义 sql 标签的创建方式
2022/09/23 数据库