canva畫曲線圖效果
本章節分享一段程式碼例項,此程式碼能夠實現畫曲線圖和心形圖等,感興趣的朋友可以自己做一下分析。
程式碼例項如下:
[HTML] 純文字檢視 複製程式碼執行程式碼<!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="author" content="http://www.softwhy.com/" /> <title>螞蟻部落</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="900" height="600">瀏覽器不支援canvas</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.restore(); } window.onload=function (){ draw(); } </script> </body> </html>
相關文章
- delphi 畫圖表,曲線圖
- Flutter 動畫曲線Curves 效果一覽Flutter動畫
- Unity Dotween Ease曲線 圖表 效果展示Unity
- Android動畫曲線庫AndroidEasingFunctionsAndroid動畫IdeaFunction
- canvas小畫板--(1)平滑曲線Canvas
- Flutter 實現平滑曲線折線圖Flutter
- canvas進階——如何畫出平滑的曲線?Canvas
- 任務2 使用Canva的繪圖工具繪圖
- 鴻蒙HarmonyOS實戰-ArkUI動畫(彈簧曲線動畫)鴻蒙UI動畫
- sk-learn 學習曲線圖
- MPAndroidChart繪製曲線圖、柱狀圖總結Android
- 解析csv資料繪製曲線圖
- 利用Jupyter Notekook做初步分析,包括給行情畫圖,加入分析曲線,和買賣點
- matlab畫折線圖Matlab
- VBA,Shapes.AddCurve SafeArrayOfPoints:=pts 畫貝塞爾曲線
- Android 窗簾(Curtain)效果四之賽貝爾曲線優化AndroidAI優化
- Python畫圖——matplotlib(普通折線圖)Python
- Flutter 自定義元件之貝塞爾曲線畫波浪球Flutter元件
- Android-貝塞爾曲線實現水波紋動畫Android動畫
- CSS滑鼠懸浮圖片動畫放大效果CSS動畫
- Qt QPolarChart極座標圖(阿基米德線、四葉曲線、六葉花瓣、三葉花瓣、心形曲線)QT
- HarmonyOS NEXT應用開發案例—使用彈簧曲線實現抖動動畫及手機振動效果案例動畫
- ROC曲線,曲線下的面積(Aera Under Curve,AUC),P-R曲線
- 強大的CSS:文字下波浪線動畫效果CSS動畫
- flutter 自定義view 繪製曲線統計圖FlutterView
- CSS3圖片上下動畫浮動效果CSSS3動畫
- CAD夢想畫圖---雲線
- 以《荒野亂鬥》為例,一文搞懂介面動畫曲線動畫
- 4次Bezier曲線--計算機圖形學 opengl計算機
- SVG動畫應用-酷炫的圖片展示效果SVG動畫
- jQuery 效果 – 動畫jQuery動畫
- 【Android 動畫】動畫詳解之仿微信檢視大圖效果(四)Android動畫
- 圖形學 畫直線 DDA掃描法與中點畫線法
- 使用二階貝塞爾曲線實現新增購物車動畫動畫
- R語言之視覺化①③散點圖+擬合曲線R語言視覺化
- 【CSS】曲線陰影CSS
- 圓錐曲線15
- 圓錐曲線14