canvas绘制太极图的实现示例
这篇文章主要介绍了canvas绘制太极图的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
看到了很多人写的太极图案,自己也来搞一下,今天就来介绍一下
css样式代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | .animation{ width : 800px ; height : 800px ; border : 1px solid #000 ; } #canvas{ animation: rotate 6 s linear infinite; } /* 给太极图设置旋转动画 */ @keyframes rotate{ 0% { transform: none ; } 100% { transform: rotate( 360 deg); } } |
javascript代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 | //文档加载完毕后执行函数 window.onload = function (){ //获取画布对象 var canvas = document.getElementById( 'canvas' ); //获取上下文对象 var context = canvas.getContext( '2d' ); //圆开始路径 context.beginPath(); //绘制最外层的大圆(黑色) context.arc(400, 400, 300, Math.PI / 180 * 0, Math.PI / 180 * 360); //将大圆填充为黑色 context.fillStyle = '#000' ; context.fill(); //绘制左半圆(白色) context.beginPath(); context.arc(400, 400, 300, Math.PI / 180 * 90, Math.PI / 180 * 270); context.fillStyle = '#fff' ; context.fill(); //绘制右半圆(黑色),会覆盖外层大圆,颜色一样。所以写不写都可以 /* context.beginPath(); context.arc(400, 400, 300, Math.PI / 180 * 270, Math.PI / 180 * 90); context.fillStyle = '#000'; context.fill(); */ //绘制左上半圆(黑色) context.beginPath(); context.arc(400, 250, 150, Math.PI / 180 * 90, Math.PI / 180 * 270); context.fillStyle = '#000' ; context.fill(); //绘制右下半圆(白色) context.beginPath(); context.arc(400, 550, 150, Math.PI / 180 * 270, Math.PI / 180 * 90); context.fillStyle = '#fff' ; context.fill(); //绘制左上小半圆(白色) context.beginPath(); context.arc(400, 250, 35, Math.PI / 180 * 0, Math.PI / 180 * 360); context.fillStyle = '#fff' ; context.fill(); //绘制右下小半圆(黑色) context.beginPath(); context.arc(400, 550, 35, Math.PI / 180 * 0, Math.PI / 180 * 360); context.fillStyle = '#000' ; context.fill(); } |
html代码
1 2 3 | < div class = "animation" > < canvas id = "canvas" width = "800" height = "800" ></ canvas > </ div > |
设置动画之后的太极图效果
到此这篇关于canvas绘制太极图的实现示例的文章就介绍到这了