完善说明

This commit is contained in:
blitheli 2024-08-14 21:18:19 +08:00
parent 674988a23a
commit 5b7eb96c62
2 changed files with 17 additions and 9 deletions

View File

@ -1,7 +1,9 @@
# Cesium天空盒子(Skybox)制作和显示
# Cesium天空盒子(Skybox)制作(js代码)和显示
#### 介绍
在Cesium中星空背景是通过天空盒子方式6张图片来显示的原生的图片分辨率太低本项目用于生成天空盒子的6张图片。
在Cesium中星空背景是通过天空盒子方式6张图片来显示的原生的图片分辨率太低本项目用于生成天空盒子的6张图片。最终生成的6个图片大小约为500kb(每个)格式为jpg总共的恒星数目约为1万颗左右在最终的地球星空背景中仅出现恒星点不会出现模糊的效果
有关Cesium天空盒子的原理和介绍请参见我之前写的一篇文章[Cesium与STK中的天空盒子(skybox)](https://blog.csdn.net/u011575168/article/details/109889699)。
#### 原理
星空背景本质上就是将所有的恒星投影到天空盒子对应的6个方位的图片上。
@ -10,22 +12,28 @@
对应的星等画一个白色的点,点的像素大小和透明度由星等决定(恒星越亮,则点的像素越大,越不透明)。
目前基本设置为详见createSkyboxImage.js
- 最亮: -1等对应为5像素透明度为1.0(不透明)
- 中等: 7等对应为1像素透明度为0.75
- 最亮: -1等对应为5像素透明度为1.0(不透明)
- 中等: 7等对应为1像素透明度为0.75
本项目中最暗为7等星因为超过8等星人眼就看不到了
#### 软件架构
- CesiumUnminified文件夹为Cesium下载安装包里面的内容Build目录下本项目用于引用Cesium.js文件
#### 项目目录
- CesiumUnminified文件夹为Cesium安装包里面的内容Build目录下本项目用于引用Cesium.js文件
- Skybox文件夹里存放了其它方式生成的天空盒子可供测试使用
- CatalogSkybox.js为天球坐标系ICRF到立方体盒子的投影转换相关函数
- CatalogSkybox.js本人编写的天球坐标系ICRF到立方体盒子的投影转换相关函数
- createSkyboxImage.js用于生成立方体盒子的一副图片
- hipparcos_7_concise.js包含了依巴谷星表hipparcos7等星以上的所有数据经过处理的来源: https://github.com/gmiller123456/hip2000
- hipparcos_7_concise.js包含了依巴谷星表hipparcos7等星以上的所有数据经过处理的数据来源: https://github.com/gmiller123456/hip2000
#### 使用说明
1. 使用Live Server打开index.html即可加载Cesium默认的启动界面同时加载了内置生成的天空盒子
1. VS Code里使用Live Server打开index.html即可加载Cesium默认的启动界面同时加载了内置生成的天空盒子
2. 网页启动后会自动将创建的6张天空盒子照片存放在浏览器的下载目录下
3. 实际使用时可以将本项目的代码集成到项目中页面启动时动态创建6个图片如index.html中那样也可以使用生成好的图片以静态图片引用的方式加载。
加载后效果如下:
![本地路径](cesium_skybox.png)
#### 其它

BIN
cesium_skybox.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 181 KiB