技术栈&资源

汽车行驶效果

添加车辆模型

let position = [1.998931022772786, 0.6645500890446009, 0]
//添加车辆
var json = {
"czmObject": {
"xbsjType": "Model",
"url": "/assets/glb/delivery.glb",
"minimumPixelSize": 128,
"maximumScale": 20,
"viewDistance": 500,
// "maximumScale": 500,
// "viewDistance": 1000,
"xbsjPosition": position,
},
"ref": "model1",
}
//添加到场景
this._earth.sceneTree.root.children.push(json)

添加车辆行驶路径

let path = [
[1.9996593978198705, 0.6643798949112332, 0],
[1.999667332682519, 0.6643399484248445, 0],
[1.999661980266788, 0.6643084183139442, 0],
[1.9996677912020882, 0.6642558052776021, 0],
[1.9996703854084483, 0.6642032457083487, 0],
........
] let json_path = {
"ref": 'path1',
"czmObject": {
"xbsjType": "Path",
"positions": path,
"rotations": [
[0, 0, 0]
],
"currentSpeed": 50,//当前播放速度,单位为米
"alwaysAlongThePath": true,//始终沿着路径方向运动
"show": false, // 显示路径
"loop": true, // 是否为环线
"playing": true, // 飞行
// 是否循环播放
// 如果为false,则playing设置为true时,会从当前位置播放到最后一个关键点,并停止播放,此时playing属性会自动变成false。 若此属性为true时,播放到最后一个关键点以后,将自动重第一个关键点继续播放。
"loopPlay": true,
"cameraAttached": false// 相机绑定
}
}
this._earth.sceneTree.root.children.push(json_path)

绑定车辆和路径,让车辆在路径上按照一定速度行驶

let model1 = this._earth.sceneTree.$refs.model1.czmObject;
let path1 = this._earth.sceneTree.$refs.path1.czmObject; this._uw1 = XE.MVVM.watch(path1, 'currentPosition', position => {
model1.xbsjPosition = [...position];
});

其他

实例代码仅供参考,还需考虑以下问题,

  • 车辆的车头方向和即将进行路线一致
  • camera视角绑定
  • 车辆头部指向性箭头的绑定

楼栋分层效果

准备数据

  1. 自有楼栋面数据,且必须有楼高或层数信息
  2. 使用arcmap或qgis等数据处理工具,给shp添加一个字段,字段内容为面的顶点信息coordinates,要根据面的顶点去构造每层的面
  3. 使用cesiumLab的矢量楼块切片功能进行shp切片
  4. 切片完成后,在cesiumLab的服务界面中,可以看到刚刚进行切片的url访问路径,或者处理结果放到自己的web服务器下进行访问
  5. 思路
    1. 双击建筑物后隐藏当前建筑物
    2. 读取建筑物的顶点和层数属性,构造层数个面,每层间隔为楼高
    3. 生成楼层标注,1F , 2F , 3F…
    4. 双击其他建筑物,还原上一个建筑物的 1 , 2, 3 步骤,再重新执行当前建筑物的 1 , 2, 3 步骤

加载建筑白膜

//动态效果
var fsBody = `
// 可以修改的参数
// 注意shader中写浮点数是,一定要带小数点,否则会报错,比如0需要写成0.0,1要写成1.0
float _baseHeight = 0.0; // 物体的基础高度,需要修改成一个合适的建筑基础高度
float _heightRange = 20.0; // 高亮的范围(_baseHeight ~ _baseHeight + _heightRange) 默认是 0-60米
float _glowRange = 120.0; // 光环的移动范围(高度) // 建筑基础色
float vtxf_height = v_elevationPos.z - _baseHeight;
float vtxf_a11 = fract(czm_frameNumber / 120.0) * 3.14159265 * 2.0;
float vtxf_a12 = vtxf_height / _heightRange + sin(vtxf_a11) * 0.1;
gl_FragColor *= vec4(vtxf_a12, vtxf_a12, vtxf_a12, 1.0); // 动态光环
float vtxf_a13 = fract(czm_frameNumber / 360.0);
float vtxf_h = clamp(vtxf_height / _glowRange, 0.0, 1.0);
vtxf_a13 = abs(vtxf_a13 - 0.5) * 2.0;
float vtxf_diff = step(0.005, abs(vtxf_h - vtxf_a13));
gl_FragColor.rgb += gl_FragColor.rgb * (1.0 - vtxf_diff);
`; this._earth.sceneTree.root.children.push({
"ref": "tileset_sjz_building",
"czmObject": {
"xbsjType": "Tileset",
"name": "楼栋白膜",
"url": "http://localhost/building3d-tiles/tileset.json",
"xbsjStyle": "var style = {\n color: \"vec4(0, 0.5, 1.0,1)\"\n}",//颜色
"xbsjClippingPlanes": {},
"xbsjCustomShader": {//光环上下的动态效果
"fsBody": fsBody,
}
}
})

楼栋分层

//双击事件,建筑物创建切片
var _that = this
this._earth._viewer.screenSpaceEventHandler.setInputAction(function onLeftClick(movement) {
//判断是否为3DTileFeature对象
if (pickedFeature !== undefined && pickedFeature instanceof Cesium.Cesium3DTileFeature) {
//隐藏当前对象,并且创建楼层切片
pickedFeature.show = false;
//coordinate 和 floor 即为顶点和层高信息
var res = _that.createBuildingLevelImg(pickedFeature.getProperty("coordinate"), pickedFeature.getProperty("floor"));
} }, Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK); //创建楼层切片
createBuildingLevelImg(coordinate, level) {
var l = parseFloat(level);
var positions = this.PolygonWktToArray(coordinate); var x_min = positions[0];
var y_min = positions[1];
for (var i = 0; i < positions.length; i++) {
if (i % 2 == 0) {
if (x_min > positions[i]) {
x_min = positions[i]
}
} else {
if (y_min > positions[i]) {
y_min = positions[i]
}
}
} //设置材质
var material = new Cesium.Material({
fabric: {
type: 'Color', //Image
uniforms: {
color: new Cesium.Color(30 / 255, 144 / 255, 1.0, 0.5) //imgUrl color
}
}
})
var primitives = [];
var indexs = [] //循环生成GeometryInstance,高度累乘
for (i = 1; i <= l; ++i) {
let height = 0 + 3 * (i - 1); var t = "";
if (t < 10) {
t = i;
} else {
t = ("" + i).split('').join(' ')
} // 添加层数 1F、2F、3F、4F.......
this._earth._viewer.entities.add({
id: "building_label_" + i,
position: Cesium.Cartesian3.fromDegrees(x_min, y_min, height),
label: {
text: t + " F",
verticalOrigin: Cesium.VerticalOrigin.BASELINE,
font: "12px sans-serif",
pixeloffset: new Cesium.Cartesian2(300.0, 100.0),
scale: 0.2,
horizontalOrigin: Cesium.HorizontalOrigin.RIGHT,
distanceDisplayCondition: new Cesium.DistanceDisplayCondition(0, 2000),
scaleByDistance: new Cesium.NearFarScalar(100, 10, 2000, 1),
},
}); // 添加面
var primitive = new Cesium.Primitive({
geometryInstances: new Cesium.GeometryInstance({
geometry: new Cesium.PolygonGeometry({
polygonHierarchy: new Cesium.PolygonHierarchy(
Cesium.Cartesian3.fromDegreesArray(positions)
),
vertexFormat: Cesium.EllipsoidSurfaceAppearance.VERTEX_FORMAT,
height: height
}),
id: "building_level_" + i
}),
appearance: new Cesium.EllipsoidSurfaceAppearance({
material: material,
aboveGround: true, //显示背面
})
});
var index = this._earth._viewer.scene.primitives._primitives.length;
this._earth._viewer.scene.primitives.add(primitive, index)
primitives.push(primitive);
indexs.push(index);
}
}

其他

  • 双击事件需要考虑
  1. 判断双击对象是否为3DTileFeature对象
  2. 标注和面通过ID前缀进行分组,一批操作里的ID前缀一致( 个人拙技,只能想到通过此行为区分 )
  3. 是否只允许一个对象进行切片,若不允许,需要把上一次双击的对象( 3DTileFeature 和 楼层面 )显示状态还原。
  4. 分层后,面的点击事件,例如:点击选中为红色,鼠标经过为黄色
  5. 退出按钮:和(3)一致,即把双击的对象( 3DTileFeature 和 楼层面 )显示状态还原。
  6. 3DTile对象也分level,在level5下双击建筑物进行了建筑物分层后,若缩放至level6,建筑物则又会重新显示,此时需要记录点击的位置,监听视角变化(类似的事件都可以),当变化时,重新判定双击处是否有新的3DTileFeature生成,若有,则继续隐藏。

广告牌、Label、光线效果

光柱、DIV跟随且超过距离隐藏

Ceisum三维场景demo的更多相关文章

  1. 超图GIS入门iserver搭建,前端调用iserver加载三维场景demo

    目录 前言 一.GIS介绍,为什么选择它? 二.环境安装 三.调用三维GIS场景 设置地图风格 添加地图iServer服务 前言 前段时间因为对3D制图感兴趣,学习了一下国内制作GIS的公司产品技术, ...

  2. cesium 之三维场景展示篇(附源码下载)

    前言 cesium 官网的api文档介绍地址cesium官网api,里面详细的介绍 cesium 各个类的介绍,还有就是在线例子:cesium 官网在线例子,这个也是学习 cesium 的好素材. 内 ...

  3. three.js-走进3d的奇妙世界一创建一个三维场景

      一.git代码仓库地址 git clone https://github.com/josdirksen/learning-threejs-third  下载并解压 二.创建一个三维场景 如下图所示 ...

  4. 三维场景中使用BillBoard技术

    三维场景中对于渲染效果不是很精致的物体可以使用BillBoard技术实现,使用该技术需要将物体实时朝向摄像机,即计算billboard的旋转矩阵M. 首先根据摄像机位置cameraPos和billBo ...

  5. SuperMap 二维地图和三维场景弹窗窗口大小控制

    注:此处所说的弹窗窗口,主要指的是那些弹窗窗口中嵌入iframe,包含信息页面的窗口大小控制. 1.首先来了解下 SuperMap 示例中的处理方案 二维的处理方式 //初始化Anchored类 po ...

  6. 从WW中剥离一个三维场景框架

    从WW中剥离一个三维场景框架,初步实现的一个.可以绘制一个三角形,但是不能够控制摄像机,没有增加鼠标事件.没有投影,世界变幻之类的东西.以后会不断学习逐步增加进来. 下载地址 下载V1.0.0.2

  7. 3D游戏引擎中常见的三维场景管理方法

    对于一个有很多物体的3D场景来说,渲染这个场景最简单的方式就是用一个List将这些物体进行存储,并送入GPU进行渲染.当然,这种做法在效率上来说是相当低下的,因为真正需要渲染的物体应该是视椎体内的物体 ...

  8. World Wind Java开发之七——读取本地栅格文件(影像+高程)构建三维场景(转)

    http://blog.csdn.net/giser_whu/article/details/41679515 首先,看下本篇博客要达到的效果图: 下面逐步分析如何加载影像及高程文件. 1.World ...

  9. 三维场景如何嵌入到PPT中展示?

    今天要跟大家一起交流的大体内容如标题所示,日常生活中,ppt已经成为人们工作学习生活中不可或缺的工具之一,那么三维场景是如何在ppt中加载展示的呢?请大家慢慢往下看. 1.创建命令按钮和web bro ...

  10. SLAM: Structure From Motion-移动中三维场景重建

    wiki链接:https://en.wikipedia.org/wiki/Structure_from_motion 三维重建: 三维物体建模总结 1. 视野内三维物体重建 : Kinect fusi ...

随机推荐

  1. LLM论文研读: GraphRAG的替代者LightRAG

    1. 背景 最近有一个很火的开源项目LightRAG,Github6.4K+星※,北邮和港大联合出品,是一款微软GraphRAG的优秀替代者,因此本qiang~得了空闲,读读论文.跑跑源码,遂有了这篇 ...

  2. MySQL查询BLOB类型的字段

    1.MySQL有四种BLOB类型: 1.TinyBlob 最大能容纳255B的数据 2.Blob 最大能容纳65KB的 3.MediumBlob 最大能容纳16MB的数据 4.LongBlob 最大能 ...

  3. 《用广义CNOT门产生质数幂维的图态》

    参考文献:Graph states of prime-power dimension from generalized CNOT quantum circuit 主机文件:<2016质数图态.p ...

  4. sprintboot-aop切面编程demo

    AOP(面向切面编程)的核心概念是"切面". 切面是一个跨越多个对象的类,它封装了横切关注点的具体实现.通过定义切面,开发人员可以将通用功能从业务逻辑中分离出来,形成独立的模块.在 ...

  5. The 2024 ICPC Asia East Continent Online Contest (I) C

    Link: Permutation Counting 4 我的评价是神题,给出两种做法. 方法一 利用线代技巧. 设法构造矩阵 \(A\), 其中 \(A_{ij} = [j \in [l_i, r_ ...

  6. golang WEB框架Hertz --- 获取参数

    安装Hertz命令行工具 请确保您的Go版本在1.15及以上版本,笔者用的版本是1.18 配置好GO的环境后,按照Hertz的命名行工具 go install github.com/cloudwego ...

  7. antlr的使用

    我从以下几个问题入手介绍ANTLR的相关知识. 1 ANTLR是什么? ANTLR, ANother Tool for Language Recognition, 是一个可以接受含有语法描述的语言描述 ...

  8. PHP扩展之Yaconf

    这个是继鸟哥出品的yaf,yar 之后的又一个好用的工具.  Yaconf配置管理工具 具体可以看鸟哥的文档: https://www.laruence.com/2015/06/12/3051.htm ...

  9. PHP之环境搭建(php7.4 + php8.1)

    之前写过几次,使用lnmp,宝塔,源码编译等方式来进行PHP环境的搭建, 随着接触的越来越多, 这里做一个总结, 常用的搭建方式 1.编译安装 之前写个几次,可以参考之前的 这次记录下多个版本PHP的 ...

  10. springboot 前后端大打包成一个JAR

    1.概述 现在开发使用前后端开发机制,在部署的时候,我们需要将前后端分别打包,使用nginx 进行统一部署.这样就比较复杂,我们可以使用前后端打包到一个jar中,这样我们只需要一个包就可以了. 2.实 ...