当前位置: 首页 > 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.gsyq.cn/news/1568485.html

相关文章:

  • 用户代理切换工具:5个技巧轻松实现多设备统一管理
  • 天堂寨好吃的吊锅推荐哪家靠谱 本地人实测正宗测评榜 - 速递信息
  • RAG实战:从概念到生产级系统的7个关键环节
  • Ubuntu 20.04 LAMP生产就绪:Apache MySQL PHP兼容性配置指南
  • 零经验大学生简历模板:4个带案例的简历模板网站 - HR小张
  • 基于MC9S08AC16的无传感器BLDC电机控制:反电动势过零检测实战解析
  • ModTheSpire终极指南:如何轻松为《杀戮尖塔》安装和管理数百个创意模组
  • 抖店下单软件全解析,详解功能流程与技巧,覆盖采集、加密解密等用法 - 速递信息
  • 185、计算摄影的视频应用:AI EIS、AI 降噪、AI 超分在视频实时处理中的挑战
  • Ubuntu 18.04 + Unison 实现大目录双向安全同步
  • BSC9131异构多核调试实战:以太网TAP配置与CodeWarrior多核调试指南
  • SuiteCRM CVE-2024-36412 SQL注入漏洞深度剖析与实战复现
  • 常州旗硕智慧科技常见问题解答(2026最新专家版) - 速递信息
  • UE5.7 FDeferredShadingSceneRenderer::Render 函数学习 之 FSceneRenderer::RenderVelocities
  • ClaudeCode对接GLM-4.7:协议网关构建指南
  • 2026年光伏智慧公共设施选型参考:常州旗硕智慧科技有限公司深度解析 - 速递信息
  • 炉石传说脚本终极指南:如何用智能自动化解放你的游戏时间
  • 国内合规使用Gemini API的两步实操指南
  • 英雄联盟终极助手:如何用League Akari实现游戏自动化与数据智能管理
  • 深度解析:光伏赋能智慧公共设施 原理与应用实践 - 速递信息
  • Ubuntu 18.04终端录屏实战:Terminalizer全链路部署与隐私合规指南
  • 2026年常州旗硕智慧科技有限公司深度测评:智慧公共设施如何选择最佳方案 - 速递信息
  • 2026年6月朗格官方售后维修服务网点,全国统一咨询电话与线下门店完整地址汇总 - 速递信息
  • 汽车软件AUTOSAR迁移实战:从私有架构到标准化的挑战与飞思卡尔服务解析
  • 2026年常州旗硕智慧科技有限公司深度分析:智慧公共设施方案选择指南 - 速递信息
  • 一文讲透:微信投票活动该如何制作(云帆投票vs腾讯投票) - 投票小程序
  • 锐龙AI Max + OpenClaw:本地智能体全链路实战指南
  • 安乐镇汽车汽修厂推荐 星达汽车维修(原程金汽车维修)优势解析 - 百航
  • 嵌入式USB DFU Bootloader实现:从内存规划到固件升级全流程解析
  • 南京工业大学浦江学院在全国 / 省内排名多少?是不是双一流 / 省重点院校? - 寻茫精选