如何使用Canvas画太极图案,代码是什么
Admin 2022-07-11 群英技术资讯 947 次浏览
今天这篇给大家分享的知识是“如何使用Canvas画太极图案,代码是什么”,小编觉得挺不错的,对大家学习或是工作可能会有所帮助,对此分享发大家做个参考,希望这篇“如何使用Canvas画太极图案,代码是什么”文章能帮助大家解决问题。看到了很多人写的太极图案,自己也来搞一下,今天就来介绍一下
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>
设置动画之后的太极图效果

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
css使图片自适应容器大小的效果怎么样做?在实际的项目中,我们往一个页面插入多张图片的话,可能会遇到图片尺寸不一致的问题,而一张张修改尺寸,效率太低,但如果直接设置图片的尺寸又可能会导致图片变形,这个时候使图片自适应容器大小就可以解决了。下面我们来看一下方法。
这篇文章我们来了解一个CSS中的一个属性——zoom属性,可能一些新手不清楚zoom属性是做什么用的,其实zoom属性能够用来清除浮动,来触发haslayou等等,本文就给大家来介绍一下zoom属性及其基本用法,感兴趣的朋友接下来就跟随小编来了解看看吧!
这篇文章主要介绍了html+css+js实现导航栏滚动渐变效果,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
这篇文章主要介绍了CSS 中重要的层叠概念详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
float的用途比较广, 本文主要给大家介绍HTML 悬浮float的一些常有用法,通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008