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>
玫瑰曲线方程:
r=a+bsin(m/n*x)

选择参数:

m: <input type="number" name="m" min="2" max="29" value="29"/>

n: <input type="number" name="n" min="1" max="12" value="11"/>

a: <input type="number" name="a" min="0" max="5" value="1"/>

b: <input type="number" name="b" min="1" max="7" value="5"/>

<input type="button" value=" 画 图 " onClick="draw();">

<hr>
<input type="button" value=" 画 图 2 " onClick="draw2();">

<hr>
<input type="button" value=" 心形图 " onClick="draw3();">
</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>

时间: 2024-11-01 13:29:18

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

利用php输出不同的心形图案_php技巧

首先为大家分享php输出心形曲线的代码,代码如下 <?php for($t=0;$t<360;$t++) { $y=2*cos($t)-cos(2*$t); //笛卡尔心形曲线函数 $x=2*sin($t)-sin(2*$t); $x+=3; $y+=3; $x*=70; $y*=70; $x=round($x); $y=round($y); $str[]=$x; $y=$y+2*(180-$y);//图像上下翻转 $x=$y; $str[]=$x; } $im=imagecreate(400

Photoshop心形工具绘制粉红色的心形图案

最终效果: 首先在Adobe Photoshop CS5中创建一个新文件(Ctrl + N),大小1280px*1024px(RGB颜色模式),分辨率72 pixels/inch.选择图层面板中的背景层,从图层面板底部点击添加图层样式图标,选择渐变叠加. 点击颜色条打开渐变编辑器,按下图设置颜色.点击OK关闭对话框 现在我们得到了下图的效果 在工具栏中选择自定义形状工具(U),在选项栏里点击形状打开选择菜单.找到心形图案,然后双击形状缩略图来选择它 单击并拖动心形.然后应用转换点工具对心做适当的

PhotoShop绘制漂亮的粉红心形图案教程

首先在Adobe Photoshop CS5中创建一个新文件(Ctrl + N),大小1280px*1024px(RGB颜色模式),分辨率72 pixels/inch.选择图层面板中的背景层,从图层面板底部点击添加图层样式图标,选择渐变叠加. 点击颜色条打开渐变编辑器,按下图设置颜色.点击OK关闭对话框 现在我们得到了下图的效果 在工具栏中选择自定义形状工具(U),在选项栏里点击形状打开选择菜单.找到心形图案,然后双击形状缩略图来选择它 单击并拖动心形.然后应用转换点工具对心做适当的修改 分类:

Photoshop制作超酷的水珠喷溅心形图案

教程制作过程虽然复杂,不过思路很好理解.我们只需要用喷溅笔刷或素材,按照心形的轮廓刷上笔刷.然后把得到的喷溅心形多复制几层,分别设置好图层样式,把颜色及水珠质感设置出来即可. 最终效果 1.新建1024*768的画布,分辨率72DPI,使用自定义形状工具做一个心形图案. 2.插入不同的飞溅素材,适当的变换和旋转,使之成为心形,每个图层的图层混合模式均为正片叠底,这样可以显现出背景的心形.如下图所示同样的飞溅素材使用了两次,只是适当的拉伸.移动和倒置.点这里下载所有喷溅素材. 3.和上述步骤一样,

想要在html5 canvas画布中打开一张本地图片,代码有什么问题

问题描述 想要在html5 canvas画布中打开一张本地图片,代码有什么问题 <!doctype html> <html> <head> <meta charset="utf-8"> <title>无标题文档</title> <script type="text/javascript"> var canvas=document.getElementById("demo&q

Photoshop绘制很漂亮的烟雾组成的心形图案

心形部分不是一步就可以完成,需要用简单的光束不断的变形处理,做出衔接自然的心形.大致心形确定后再根据火焰效果的制作方法渲染火焰效果即可最终效果 1.新建一个800 * 800像素的文档,背景填充黑色,也可以加上暗色径向渐变.然后新建一个图层,用矩形选框拉出下图所示的矩形选区,填充橙红色:#EE3F12,确定后把图层不透明度改为:40%. <图1> [1] [2] [3] [4] [5] [6] [7] [8] [9]  下一页

用Fireworks做个心形动画送给心上人

给最亲密的MM送什么礼物呢?当然是献上一颗赤诚的红心了,一路上就可以永远心心相印!^_^,下面就请跟我来吧!为你心爱的MM献上这份神秘的礼物. 制作心形图案 1.启动Fireworks 4.0,执行"File→New"命令,设定宽度为800Pixels,高度500Pixels,然后单击确定按钮. 2.在左侧的工具箱中,设定Color填充色为红色,然后选择椭圆工具,按住Shift键的同时,拖动鼠标画出一个红色的圆形.执行"Edit→Clone"命令,完成后使用箭头工具

基于html5 canvas实现漫天飞雪效果实例

 本文实例讲述了基于html5 canvas实现漫天飞雪效果的方法,运行该实例可以看到很棒的下雪效果.如下图所示: 主要代码如下: 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "<a href="http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">http://www.w3.org/T

PhotoShop制作彩色渐变心形新手教程

利用PhotoShop制作简单的彩色渐变心形,简单易学,适合新手同学,不信你可以试试! 效果图: 1.新建一个600 * 500大小的文档,背景选择黑色.将背景设为黑色,前景设置为白色,新建个图层,,用系统自带的自定义形状工具,选择心形形状,绘制白色心形, 如下图. 2.按住Ctrl键不放,鼠标单击心形图层前面的缩略图,调出选区.羽化选区15个像素,按Delete删除,按Ctrl + D 取消选区,复制一层,按Ctrl + E 向下合并图层, 使心形图层更亮. 相关教程: PS绘制心形飘带 PS