行星旋转案例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如何去除图片干扰代码示例

《Python如何去除图片干扰代码示例》图片降噪是一个广泛应用于图像处理的技术,可以提高图像质量和相关应用的效果,:本文主要介绍Python如何去除图片干扰的相关资料,文中通过代码介绍的非常详细,... 目录一、噪声去除1. 高斯噪声(像素值正态分布扰动)2. 椒盐噪声(随机黑白像素点)3. 复杂噪声(如伪

Java Spring ApplicationEvent 代码示例解析

《JavaSpringApplicationEvent代码示例解析》本文解析了Spring事件机制,涵盖核心概念(发布-订阅/观察者模式)、代码实现(事件定义、发布、监听)及高级应用(异步处理、... 目录一、Spring 事件机制核心概念1. 事件驱动架构模型2. 核心组件二、代码示例解析1. 事件定义

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

六个案例搞懂mysql间隙锁

《六个案例搞懂mysql间隙锁》MySQL中的间隙是指索引中两个索引键之间的空间,间隙锁用于防止范围查询期间的幻读,本文主要介绍了六个案例搞懂mysql间隙锁,具有一定的参考价值,感兴趣的可以了解一下... 目录概念解释间隙锁详解间隙锁触发条件间隙锁加锁规则案例演示案例一:唯一索引等值锁定存在的数据案例二:

深入解析 Java Future 类及代码示例

《深入解析JavaFuture类及代码示例》JavaFuture是java.util.concurrent包中用于表示异步计算结果的核心接口,下面给大家介绍JavaFuture类及实例代码,感兴... 目录一、Future 类概述二、核心工作机制代码示例执行流程2. 状态机模型3. 核心方法解析行为总结:三

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

MySQL 表的内外连接案例详解

《MySQL表的内外连接案例详解》本文给大家介绍MySQL表的内外连接,结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录表的内外连接(重点)内连接外连接表的内外连接(重点)内连接内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选,我

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L