最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

HTML5Canvas实现玫瑰曲线和心形图案的代码实例_html5教程技巧

来源:动视网 责编:小采 时间:2020-11-27 15:18:45
文档

HTML5Canvas实现玫瑰曲线和心形图案的代码实例_html5教程技巧

HTML5Canvas实现玫瑰曲线和心形图案的代码实例_html5教程技巧:效果图: 提示:把代码复制到一个html文件中并保存,直接打开即可看到效果。 实现代码:代码如下: HTML5 Demo #apDiv1 { position:absolute; width:120px; height:300px; z-index:1; left: 840px; top: 80px
推荐度:
导读HTML5Canvas实现玫瑰曲线和心形图案的代码实例_html5教程技巧:效果图: 提示:把代码复制到一个html文件中并保存,直接打开即可看到效果。 实现代码:代码如下: HTML5 Demo #apDiv1 { position:absolute; width:120px; height:300px; z-index:1; left: 840px; top: 80px


效果图:

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

实现代码:

代码如下:




HTML5 Demo




Your browser does not support the canvas element.





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();
}



文档

HTML5Canvas实现玫瑰曲线和心形图案的代码实例_html5教程技巧

HTML5Canvas实现玫瑰曲线和心形图案的代码实例_html5教程技巧:效果图: 提示:把代码复制到一个html文件中并保存,直接打开即可看到效果。 实现代码:代码如下: HTML5 Demo #apDiv1 { position:absolute; width:120px; height:300px; z-index:1; left: 840px; top: 80px
推荐度:
标签: 教程 代码 html5
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top