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

150 篇文章 1 订阅

接此;

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型的话需要自己转换;有时间再继续;

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值