首次使用Cesium加载3D数据不成功

Posted bcbobo21cn

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了首次使用Cesium加载3D数据不成功相关的知识,希望对你有一定的参考价值。

接此;

https://blog.csdn.net/bcbobo21cn/article/details/110454547

 

参阅相关教程;Cesium加载3D数据是通过3D Tiles进行;
3D Tiles是cesium小组定义的一种数据集;格式公开;

 

先看一下有没有在线示例3D Tiles,有的话使用其url来做一个示例;

看cesium网,cesium中文网;需要注册;

看示例,示例带有示例3D Tiles文件;

 

基本的加载代码如下;

<script>

var viewer = new Cesium.Viewer("cesiumContainer");

var palaceTileset = new Cesium.Cesium3DTileset(
url: './SampleData/Cesium3DTiles/Classification/Photogrammetry/tileset.json'
//或者url: 'http://ip:port/www/DAEPalace/tileset.json'
);

var longitude = 114.33;
var latitude = 30.35;
height = 150;
var heading = 2;
palaceTileset.readyPromise.then(function(argument) 
     //经纬度、高转笛卡尔坐标
     var position = Cesium.Cartesian3.fromDegrees(longitude, latitude, height);
     var mat = Cesium.Transforms.eastNorthUpToFixedFrame(position);
     var rotationX = Cesium.Matrix4.fromRotationTranslation(Cesium.Matrix3.fromRotationZ

(Cesium.Math.toRadians(heading)));
     Cesium.Matrix4.multiply(mat, rotationX, mat);
     palaceTileset._root.transform = mat;
)

viewer.scene.primitives.add(palaceTileset); 

</script>

使用json数据的url来new一个Cesium3DTileset类对象;
然后把此对象添加到viewer.scene上面;
可以通过指定经纬高调整模型位置:
    由经纬度和height得到一个position;
    由position得到一个mat,矩阵;
    fromRotationTranslation是坐标转换方式;
    Cesium.Matrix4.multiply(mat, rotationX, mat), 矩阵转换以后获得一个新的mat;
    palaceTileset._root.transform = mat,mat赋给数据集的transform参数;

运行一下;然后定位到加载的经纬度,114.33,30.35;没有3D数据出来;只有此经纬度的底图;

调整不同的参数;height,heading;3D数据还是没出来;

不同的时候错误如下;

 

    从错误来看是加载的某些参数不对;

它的3D数据是如下;一个json文件,一个b3dm文件;如果自己有一个3d型的话需要自己转换;有时间再继续;

 

以上是关于首次使用Cesium加载3D数据不成功的主要内容,如果未能解决你的问题,请参考以下文章

Cesium加载Cesium3DTileset&Cesium3DTileFeature模型高亮显示&实时显示经纬度以及高度

理解加载3D数据的Cesium基本代码

cesium编程入门添加 3D Tiles,并调整位置,贴地

cesium加载3D—gltf模型

cesium czml 3d模型动画

cesium obj转b3dm转换及加载