行星旋转案例canvas-konva.js未封装前的代码

2023-12-26 22:48

本文主要是介绍行星旋转案例canvas-konva.js未封装前的代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

静止状态下:

整体代码:

 

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no"><title>webitcast案例</title><style>body {padding: 0;margin: 0;background-color: #f0f0f0;overflow: hidden;}</style><script src="bower_components/konva/konva.min.js"></script>
</head>
<body><div id="container"></div><script type="text/javascript">var stage=new Konva.Stage({//创建舞台container:'container',width:window.innerWidth,height:window.innerHeight});var bgLayer=new Konva.Layer();stage.add(bgLayer);//开始创建圆形//中心点坐标var centX=stage.width()/2;var centY=stage.height()/2;//圆形的半径var innerRadius=126;var outerRadius=220;//虚线圆环var innerCircle=new Konva.Circle({x:centX,y:centY,radius:innerRadius,stroke:'#ccc',strokeWidth:4,dash: [10,4],//虚线});var outerCircle=new Konva.Circle({x:centX,y:centY,radius:outerRadius,stroke:'#ccc',strokeWidth:4,dash: [10,4],});//中心蓝色的圆圈var centerCircle=new Konva.Circle({x:centX,y:centY,radius:70,fill:'#525A82',opacity:.8});//中心圆形的圆环var centerRing=new Konva.Ring({x: centX,y: centY,innerRadius: 70,//内环的半径outerRadius: 88,//外环的半径fill: '#E1E1E1',opacity: .6})//添加中心圆形的字体var centerText=new Konva.Text({x:centX-140/2,y:centY-9,width:130,align:'center',text:'web全栈',fontSize:18,fontFamily: '微软雅黑',fill: '#fff',fontStyle:'bold'});// 开始画动画层//第一层圆形,黄色的// 坐标设置var x1=centX+innerRadius*Math.cos(-60*Math.PI/180);var y1=centY+innerRadius*Math.sin(-60*Math.PI/180);var orangeCircle1=new Konva.Circle({x:x1,y:y1,radius:30,fill:'orange',opacity:.7});//黄色圆的圆环var orangeRing1=new Konva.Ring({x:x1,y:y1,innerRadius:30,outerRadius:38,fill: '#E1E1E1',opacity: .6});console.log(x1)console.log(y1)var orangeText=new Konva.Text({x:x1-30,y:y1-8,width:60,// align:'center',text:'HTML5',fontSize:16,fontFamily: '微软雅黑',fill: '#fff',fontStyle:'bold'});//第一层圆形,Pink色的var x2=centX+innerRadius*Math.cos(180*Math.PI/180);var y2=centY+innerRadius*Math.sin(180*Math.PI/180);var pinkCircle1=new Konva.Circle({x:x2,y:y2,radius:30,fill:'pink',opacity:.7});var pinkRing1=new Konva.Ring({x:x2,y:y2,innerRadius:30,outerRadius:38,fill: '#E1E1E1',opacity: .6});var pinkText=new Konva.Text({x:x2-30,y:y2-8,width:60,align:'center',text:'CSS3',fontSize:16,fontFamily: '微软雅黑',fill: '#fff',fontStyle:'bold'});第2层圆形,blue色的var x3=centX+outerRadius*Math.cos(45*Math.PI/180);var y3=centY+outerRadius*Math.sin(45*Math.PI/180);var blueCircle2=new Konva.Circle({x:x3,y:y3,radius:40,fill:'#A4C9F6',opacity:.7});var blueRing2=new Konva.Ring({x:x3,y:y3,innerRadius:40,outerRadius:50,fill: '#E1E1E1',opacity: .6});var blueText=new Konva.Text({x:x3-40,y:y3-8,width:80,align:'center',text:'JS',fontSize:16,fontFamily: '微软雅黑',fill: '#fff',fontStyle:'bold'});bgLayer.add(innerCircle);bgLayer.add(outerCircle);bgLayer.add(centerCircle);bgLayer.add(centerRing);bgLayer.add(centerText);bgLayer.add(orangeCircle1);bgLayer.add(orangeRing1);bgLayer.add(orangeText);bgLayer.add(pinkCircle1);bgLayer.add(pinkRing1);bgLayer.add(pinkText);bgLayer.add(blueCircle2);bgLayer.add(blueRing2);bgLayer.add(blueText);bgLayer.draw();</script>
</body>
</html>

 

 

 

 

 

 

这篇关于行星旋转案例canvas-konva.js未封装前的代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/541053

相关文章

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

RabbitMQ消费端单线程与多线程案例讲解

《RabbitMQ消费端单线程与多线程案例讲解》文章解析RabbitMQ消费端单线程与多线程处理机制,说明concurrency控制消费者数量,max-concurrency控制最大线程数,prefe... 目录 一、基础概念详细解释:举个例子:✅ 单消费者 + 单线程消费❌ 单消费者 + 多线程消费❌ 多

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性: