canvas绘制太极图的实现示例
程序员文章站
2022-04-23 18:26:32
这篇文章主要介绍了canvas绘制太极图的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 20-04-29...
看到了很多人写的太极图案,自己也来搞一下,今天就来介绍一下
css样式代码
.animation{ width: 800px; height: 800px; border: 1px solid #000; } #canvas{ animation: rotate 6s linear infinite; } /* 给太极图设置旋转动画 */ @keyframes rotate{ 0%{ transform: none; } 100%{ transform: rotate(360deg); } }
javascript代码
//文档加载完毕后执行函数 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代码
<div class="animation"> <canvas id="canvas" width="800" height="800"></canvas> </div>
设置动画之后的太极图效果
到此这篇关于canvas绘制太极图的实现示例的文章就介绍到这了,更多相关canvas太极图内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!