校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > HTML5 Canvas實現玫瑰曲線和心形圖案的代碼實例

HTML5 Canvas實現玫瑰曲線和心形圖案的代碼實例

熱門標簽:漯河外呼調研線路 電銷專用外呼線路 威力最大的電銷機器人 400電話唐山辦理 電銷外呼系統是違法的嗎 廣西房產智能外呼系統推薦 地圖標注位置怎么弄圖 電話機器人鑰匙扣 旅游地圖標注線路

效果圖:
 

提示:把代碼復制到一個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>

 

 

標簽:綏化 試駕邀約 銅陵 湘西 焦作 欽州 湖北 無錫

巨人網絡通訊聲明:本文標題《HTML5 Canvas實現玫瑰曲線和心形圖案的代碼實例》,本文關鍵詞  HTML5,Canvas,實現,玫瑰,曲線,和,心形,圖案,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《HTML5 Canvas實現玫瑰曲線和心形圖案的代碼實例》相關的同類信息!
  • 本頁收集關于HTML5 Canvas實現玫瑰曲線和心形圖案的代碼實例的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 镶黄旗| 安平县| 呈贡县| 托里县| 大厂| 兴宁市| 河南省| 山阴县| 镇远县| 元阳县| 江城| 开远市| 九龙县| 广东省| 廊坊市| 鸡泽县| 海阳市| 辛集市| 普宁市| 深圳市| 建水县| 日土县| 连云港市| 赣州市| 婺源县| 连州市| 珠海市| 济阳县| 垦利县| 肥乡县| 北流市| 长岭县| 尼木县| 渭南市| 肥城市| 武威市| 左云县| 剑川县| 乃东县| 南通市| 漳州市|