当前位置: 首页 > news >正文

Cesium 天空盒教程

天空盒 ·Sky Box· ▶ 在线运行案例

  • 案例合集:三维可视化功能案例(threehub.cn)
  • 开源仓库github地址:https://github.com/z2586300277/three-cesium-examples
  • 400个案例代码:网盘链接

你将学到什么

  • scene.skyBox替换默认渐变天空
  • 立方体贴图六面命名(positiveX / negativeX …)
  • UrlTemplateImageryProvider加载 XYZ 瓦片底图

效果说明

使用高德卫星影像作底图,天空换成自定义六面 PNG,形成「地面实景 + 定制天空」的视觉效果。

核心概念

SkyBox

viewer.scene.skyBox = new Cesium.SkyBox({

sources: { positiveX: 'px.png', // 右 (+X) negativeX: 'nx.png', // 左 (-X) positiveY: 'py.png', // 前 (+Y) — 注意与 Three.js 轴向可能不同 negativeY: 'ny.png', // 后 (-Y) positiveZ: 'pz.png', // 上 (+Z) negativeZ: 'nz.png', // 下 (-Z) } });

本案例注释说明了贴图轴与 Cesium 期望面的映射关系(px/nx/py 等需按实际摄影机朝向调整)。

关闭默认底图

const viewer = new Cesium.Viewer(box, { baseLayer: false });

viewer.imageryLayers.addImageryProvider( new Cesium.UrlTemplateImageryProvider({ url: 'https://.../{z}/{x}/{y}', maximumLevel: 18, }) );

实现步骤

  • Viewer 设baseLayer: false,手动 add 影像
  • 准备 6 张无缝立方体贴图
  • new Cesium.SkyBox({ sources })赋给scene.skyBox
  • 若天空方向不对,交换 positiveY/negativeY 等面
  • 代码要点

    import * as Cesium from 'cesium'

    const box = document.getElementById('box')

    const viewer = new Cesium.Viewer(box, {

    animation: false,//是否创建动画小器件,左下角仪表

    baseLayerPicker: false,//是否显示图层选择器,右上角图层选择按钮

    baseLayer: false, // 不显示默认图层

    fullscreenButton: false,//是否显示全屏按钮,右下角全屏选择按钮

    timeline: false,//是否显示时间轴

    infoBox: false,//是否显示信息框

    }) viewer.imageryLayers.addImageryProvider(

    new Cesium.UrlTemplateImageryProvider({

    //高德卫星影像 url: 'https://webst03.is.autonavi.com/appmaptile?style=6&x={x}&y={y}&z={z}',

    maximumLevel: 18

    })

    )

    // px => -90, nx => 90, py => 0, ny => 180, pz => 0, nz => 180 viewer.scene.skyBox = new Cesium.SkyBox({ sources: { positiveX: FILE_HOST + 'files/cesiumSky/px.png', // 右面 negativeX: FILE_HOST + 'files/cesiumSky/nx.png', // 左面 positiveY: FILE_HOST + 'files/cesiumSky/pz.png', // 将前面用作上面 negativeY: FILE_HOST + 'files/cesiumSky/nz.png', // 将后面用作下面 positiveZ: FILE_HOST + 'files/cesiumSky/py.png', // 将上面用作前面 negativeZ: FILE_HOST + 'files/cesiumSky/ny.png' // 将下面用作后面 } });

    完整源码:GitHub

    小结

    • 本文提供天空盒完整 Cesium.js 源码与在线 Demo,建议先运行案例再改 uniform/参数做二次实验
    • 更多 Cesium.js 实战案例见 three-cesium-examples 合集 与 GitHub 开源仓库
http://www.jsqmd.com/news/1056560/

相关文章:

  • Ubuntu 20.04 LAMP生产就绪:Apache MySQL PHP兼容性配置指南
  • 天堂寨好吃的吊锅推荐哪家靠谱 本地人实测正宗测评榜 - 速递信息
  • 基于MC9S08AC16的无传感器BLDC电机控制:反电动势过零检测实战解析
  • 零经验大学生简历模板:4个带案例的简历模板网站 - HR小张
  • 武汉买宠物前先收藏,梦宠山庄这5家门店一次看懂 - 园友3800037
  • 2026工业与商业空调厂家如何选?冷水机组/变频多联机/风冷模块机厂家推荐榜|专业技术+全维度避坑深度解析 - 速递信息
  • 2026河北热镀锌钢格板工程采购全解析 源头工厂选型实操指南 - 速递信息
  • DigiForest:数字技术与机器人融合的智能林业管理新范式
  • ModTheSpire终极指南:如何轻松为《杀戮尖塔》安装和管理数百个创意模组
  • 苏州吴江哪家海鲜店好吃?本地人首推这家 - 速递信息
  • 2026无锡黄金回收全攻略四家实体门店横向评测附地址避坑指南 - 生活测评君
  • Ubuntu 14.04 部署 Piwigo 图片相册系统实战指南
  • IPXWrapper:让经典游戏在现代Windows上重获联机能力的魔法钥匙
  • Ubuntu 20.04 NFS手动挂载实战:从连接拒绝到稳定自启
  • BSC9131异构多核调试实战:以太网TAP配置与CodeWarrior多核调试指南
  • 魔兽争霸III辅助工具:免费开源的游戏体验增强方案
  • 免费图片工具有哪些 手机小程序不用下载直接用 - 玩机日常
  • Ubuntu 18.04 + Unison 实现大目录双向安全同步
  • 185、计算摄影的视频应用:AI EIS、AI 降噪、AI 超分在视频实时处理中的挑战
  • 抖店下单软件全解析,详解功能流程与技巧,覆盖采集、加密解密等用法 - 速递信息
  • 清运效率提升42%:常州旗硕智慧科技案例解析 - 速递信息
  • SuiteCRM CVE-2024-36412 SQL注入漏洞深度剖析与实战复现
  • 如何用Photon光影包为Minecraft打造电影级画质:新手快速入门指南
  • i.MX 6SoloX引脚配置全解析:从BGA封装到PCB设计实战
  • UE5.7 FDeferredShadingSceneRenderer::Render 函数学习 之 FSceneRenderer::RenderVelocities
  • IPv6最长前缀匹配算法优化:线性化B+树与SIMD无分支设计
  • VisualCppRedist AIO:终极VC++运行库一站式解决方案完全指南
  • 模块化架构解析:wangEditor v5如何重构富文本编辑体验
  • 第16章:Ollama服务化架构——从本地工具到团队服务
  • 小众纯粮白酒推荐排行:2026纯粮好酒榜单,喝出地道粮食香 - 速递信息