Cesium 加载B3DM模型

一、引入Cesium,可以使用该链接下载cesium

链接: https://pan.baidu.com/s/1BRQyaFCkxO2xQQT5RzFUCw?pwd=kcv9 提取码: kcv9

在index.html文件中引入cesium

复制代码
<script type="text/javascript" src="/Cesium/Cesium.js"></script>

二、初始化cesium,cesium初始化参数可自行配置

复制代码
const cesiurView = ref();
const initCesiut = () => {
	Cesium.Ion.defaultAccessToken ='';
	cesiurView.value = new Cesium.Viewer(props.id, {
		animation: false, //是否显示动画控件
		shouldAnimate: true,
		homeButton: false, //是否显示Home按钮
		fullscreenButton: false, //是否显示全屏按钮
		baseLayerPicker: false, //是否显示图层选择控件
		geocoder: false, //是否显示地名查找控件
		timeline: false, //是否显示时间线控件
		sceneModePicker: false, //是否显示投影方式控件
		navigationHelpButton: false, //是否显示帮助信息控件
		infoBox: false, //是否显示点击要素之后显示的信息
		requestRenderMode: true, //启用请求渲染模式
		scene3DOnly: true, //仅渲染3D
		sceneMode: 3, //初始场景模式 1 2D模式 2 2D循环模式 3 3D模式  Cesium.SceneMode
		selectionIndicator: false,//不创建selectionIndicator小部件
		skyAtmosphere:false,//不显示天空
	});
	cesiurView.value._cesiumWidget._creditContainer.style.display = 'none';// 隐藏logo
	cesiurView.value.scene.screenSpaceCameraController.inertiaZoom = 0.5;
	cesiurView.value.scene.screenSpaceCameraController.enableTilt = true; // 禁止俯仰角
	cesiurView.value.scene.globe.depthTestAgainstTerrain = false; //关闭地形
	cesiurView.value.scene.globe.show = false;
	cesiurView.value.scene.sun.show = false; //是否显示太阳
	cesiurView.value.scene.moon.show = false; //是否显示有月亮
	cesiurView.value.scene.skyBox.show = false; //是否显示星空
	cesiurView.value.scene.backgroundColor = new Cesium.Color(0,0,0,1)
};

cesium内置token,容易因token过期造成cesium加载失败,可以在Cesium官网中注册账号,获取token,然后可使用Cesium.Ion.defaultAccessToken该方法替换内置token。

二、添加B3DM到cesium中

复制代码
const addB3DMModel = async () => {
	let tileset = await Cesium.Cesium3DTileset.fromUrl(``, {
		maximumScreenSpaceError: 2,//各级别最大误差
		show: true,
		skipLevels: 0,//加载图层是跳转的最小级别,0 不跳转
		immediatelyLoadDesiredLevelOfDetail: false,//只加载所需图块
		loadSiblings: false,//是否下载所有图块
		cullWithChildrenBounds: true,
	});
	cesiurView.value.scene.primitives.add(tileset, {
		disableDepthTestDistance: Number.POSITIVE_INFINITY,
	});
	cesiurView.value.zoomTo(tileset);//定位到当前模型
};

效果如下:

以上方法仅仅是记录使用cesium展示B3DM模型,具体详情大家可以自行研究

相关推荐
悟能不能悟1 小时前
java的java.sql.Date和java.util.Date的区别,应该怎么使用
java·开发语言
高山上有一只小老虎2 小时前
java 正则表达式大全
java·正则表达式
_院长大人_3 小时前
设计模式-工厂模式
java·开发语言·设计模式
凌波粒3 小时前
MyBatis完整教程IDEA版(2)--ResultMap/注解/一对多/多对一/lombok/log4j
java·intellij-idea·mybatis
蓝-萧3 小时前
【玩转全栈】----Django基本配置和介绍
java·后端
priority_key3 小时前
排序算法:堆排序、快速排序、归并排序
java·后端·算法·排序算法·归并排序·堆排序·快速排序
devincob4 小时前
js原生、vue导出、react导出、axios ( post请求方式)跨平台导出下载四种方式的demo
javascript·vue.js·react.js
编程社区管理员4 小时前
React 发送短信验证码和验证码校验功能组件
前端·javascript·react.js
葡萄城技术团队4 小时前
迎接下一代 React 框架:Next.js 16 核心能力解读
javascript·spring·react.js
全马必破三4 小时前
React“组件即函数”
前端·javascript·react.js