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

Cesium 使用Shadertoy教程

使用Shadertoy ·Use Shadertoy· ▶ 在线运行案例

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

你将学到什么

  • 场景雾效增强纵深

效果说明

本案例演示使用Shadertoy效果:基于 WebGL 实现「使用Shadertoy」可视化效果,附完整可运行源码;核心用到 场景雾效增强纵深。建议先打开文首在线案例查看动态画面,再对照下方源码逐步理解。

核心概念

  • Viewer聚合 Scene、Camera、Clock 与渲染循环,是 Cesium 应用入口。
  • 阅读下方完整源码时,建议从init/load/animate三条主线入手,再深入 shader 与工具函数。

实现步骤

  • 创建 Viewer,配置地形/影像(若案例需要)并设置初始相机
  • requestAnimationFrame循环中更新状态并 render(Cesium 为viewer.render或自动渲染)
  • 代码要点

    import * as Cesium from 'cesium'

    const viewer = new Cesium.Viewer(document.getElementById('box'), { animation: false, baseLayerPicker: false, baseLayer: Cesium.ImageryLayer.fromProviderAsync( Cesium.ArcGisMapServerImageryProvider.fromUrl('https://server.arcgisonline.com/arcgis/rest/services/World_Imagery/MapServer') ), fullscreenButton: false, timeline: false, infoBox: false, });

    const customMaterial = new Cesium.Material({ translucent: false, fabric: { type: "CustomBoxShader", uniforms: { iTime: 0.0, iResolution: new Cesium.Cartesian2(1024, 1024), }, source:uniform float iTime; uniform vec2 iResolution; void mainImage( out vec4 o, vec2 u ) { vec2 v = iResolution.xy; u = .2*(u+u-v)/v.y; vec4 z = o = vec4(1,2,3,0); for (float a = .5, t = iTime, i; ++i < 19.; o += (1. + cos(z+t)) / length((1.+idot(v,v))sin(1.5u/(.5-dot(u,u)) - 9.u.yx + t)) ) v = cos(++t - 7.upow(a += .03, i)) - 5.*u, u += tanh(40.dot(u= mat2(cos(i + .02*t - vec4(0,11,33,0))), u)cos(1e2u.yx + t)) / 2e2 + .2au + cos(4./exp(dot(o,o)/1e2) + t) / 3e2; o = 25.6 / (min(o, 13.) + 164. / o) - dot(u, u) / 250.; } czm_material czm_getMaterial(czm_materialInput materialInput) { czm_material material = czm_getDefaultMaterial(materialInput); vec4 color = vec4(0.0, 0.0, 0.0, 1.0); mainImage(color, materialInput.st * iResolution); material.diffuse = color.rgb; material.alpha = 1.0; return material; }, }, });

    const appearance = new Cesium.MaterialAppearance({ material: customMaterial, flat: false, faceForward: true, translucent: true, closed: true, materialCacheKey: "shadertoy-material-appearance", });

    const scene = viewer.scene; viewer.clock.currentTime.secondsOfDay = 65398; scene.globe.enableLighting = true; scene.fog.enabled = true;

    const destination = { x: -2280236.925141378, y: 5006991.049189922, z: 3215839.258024074, }; const boxSize = 25;

    const boxGeometry = Cesium.BoxGeometry.fromDimensions({ dimensions: new Cesium.Cartesian3(boxSize, boxSize, boxSize), }); const modelMatrix = Cesium.Transforms.eastNorthUpToFixedFrame(destination); const boxInstance = new Cesium.GeometryInstance({ geometry: boxGeometry });

    const primitive = new Cesium.Primitive({ geometryInstances: boxInstance, appearance, asynchronous: false, modelMatrix, }); scene.primitives.add(primitive);

    let lastTime = Date.now(); scene.preRender.addEventListener(() => { const now = Date.now(); appearance.material.uniforms.iTime += (now - lastTime) / 1000; lastTime = now; });

    viewer.camera.lookAt( destination, new Cesium.HeadingPitchRange(6.283185307179577, -0.4706003213405664, 100), );

    完整源码:GitHub

    小结

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

相关文章:

  • ASIL-D到底有多难达到?从ISO 26262看车规MCU的研发门槛
  • Windows热键冲突检测工具:Hotkey Detective的完整使用指南
  • ESP32智慧养殖盒开发:4G联网与GPS追踪实战
  • AI语音输入全面进步,BAT入局输入法,能否带来新体验?
  • 记录分布式事务的实现方式和用法(有借助AI)
  • Web开发
  • Cesium 后期处理教程
  • 设计数据密集型应用第2版:2025-2026出版新书的《人月神话》引用(4)
  • 夏天总疲惫乏力、容易累、爱出汗的人,常喝这杯茶,养出元气满满好状态~
  • 【MATLAB】时变障碍物无人机动态规避仿真
  • Cesium 动态围墙教程
  • Oracle SQL Plus 如何不显示结果集 (TERMOUT OFF)
  • Karpathy LLM Wiki 完整原理与双方案部署教程(Cursor _ Claude 通用)
  • 【课程设计/毕业设计】基于 SpringBoot+Vue 的企业员工档案与人事考评系统的设计与实现 基于 SpringBoot 的智能化企业人事运维管理系统【附源码、数据库、万字文档】
  • 68元对标Claude Opus,豆包2.1 Pro性价比拉满,但能否留住用户仍待考验?
  • SDR++:如何用开源软件构建你的无线电频谱分析系统
  • 安卓木马滥用虚拟化技术劫持银行应用:原理、检测与防御
  • tiktoken:OpenAI模型Token精准计量与工程实践指南
  • 终极无广告体验:SpotifyPremium桌面版完整配置指南
  • 智谱市值破万亿:是资本游戏还是 AI 新范式?解禁后命运几何?
  • 体检门店销量榜诊断模型
  • 【PC】 Vutron音乐-高颜值免费音乐软件-畅听全网
  • ts3380,G3000,ix6780,MG3640,ix6700,ix6800,G5080,TS8380,ts8220报错5B00,P07,E08,1700,5b02废墨垫清零,亲测可用
  • 告别链接失效烦恼:百度网盘秒传脚本完全指南
  • 进销存软件不一定贵,但要看这几点
  • 鸿蒙语音识别的 Flutter ↔ ArkTS 完整调用链:权限申请、引擎生命周期与结果回传的时序问题
  • 中医药现代化研究,国自然申请书怎么写才能中?
  • 一台高配置图形工作站带10人SolidWorks画图的实施方案是怎样的
  • 别再浪费Token了!教你用企微回调接口,做个低成本的AI“语料传送带”
  • MusicBee-NeteaseLyrics:让本地音乐库重获网易云音乐歌词生态的智能插件