cesium 学习() 坐标转换

一、前言

  在场景中,不管是二维还好还是三维也罢,只要涉及到空间概念都会提到坐标,坐标是让我们理解位置的一个非常有效的东西。有了坐标,我们能很快的确定位置相关关系,但是坐标有很多种,专业的说,坐标系有很多种,比如大地2000、北京54、西安80、WGS84、墨卡托投影坐标系……还有各个地方的地方坐标系。如果用北京54坐标带入到WGS84坐标中去使用,你会发现偏差的不说十万八千里也会让你怀疑人生!

  所以我们需要坐标转换这个东西,把一个坐标系的坐标转换成另一个想要的坐标系的坐标。

二、GPS坐标转Cartesian3坐标

  Cesium提供了这两个坐标系的转换方法,是比较简单的,可以直接转换,但是有一点是Cartesian3坐标转换成GPS坐标时,它的结果是弧度值,不是角度值,所以如果需要我们常用的GPS坐标就需要再转换一下,将弧度转换为角度。

//GPS转世界坐标(x,y,z)

this.GPSToWorldCoordinate = function(longtitude,latitude,height){

var result = Cesium.Cartesian3.fromDegrees(longtitude, latitude, height);

return result;

};

//世界坐标转GPS坐标(角度值)[经度,纬度,高度]

this.WorldCoordinateToGPS = function(x,y,z){

var result = Cesium.Cartographic.fromCartesian(new Cesium.Cartesian3(x,y,z));

var arr = [result.longitude*180/Math.PI,result.latitude*180/Math.PI,result.height];

return arr;

};

三、Transforms

  Cesium的Transforms做的真的不错,刚开始的时候我所有的坐标转换特别是世界坐标与Matrix4的转换,根本搞不懂,还好API讲的还很清楚,不然是根本做不了坐标的一系列计算。

  对于坐标转换,建议多看看Cesium的Transforms类。里面有很多与坐标转换相关的方法(包括屏幕坐标与世界坐标的互相转换等),比如下面我做了一个相对坐标与世界坐标的转换就用了Transfroms的方法。

四、本地坐标转换世界坐标

  自己做了一个本地与世界转换坐标的类,建立一个本地坐标,然后相互计算。

/**

* 相对坐标系与世界坐标系转换,相对坐标系的轴方向由可选参数direction控制,默认是eastNorthUp北、东、上为轴线

*

* @param {Number} longitude 世界坐标系中的经度

* @param {Number} latitude 世界坐标系中的纬度

* @param {Number} height 世界坐标系中的高度

* @param {Number} direction 坐标轴方向,值是"northEastDown","northUpEast","northWestUp","eastNorthUp"(默认)

*/

LocalAndWorldTransform = function(longitude,latitude,height,direction){

var RCSorigincenter = Cesium.Cartesian3.fromDegrees(longitude,latitude,height);

if (direction == "northEastDown")

this.RCSMatrix = Cesium.Transforms.northEastDownToFixedFrame(RCSorigincenter);

else if (direction == "northUpEast")

this.RCSMatrix = Cesium.Transforms.northUpEastToFixedFrame(RCSorigincenter);

else if (direction == "northWestUp")

this.RCSMatrix = Cesium.Transforms.northWestUpToFixedFrame(RCSorigincenter);

else

this.RCSMatrix = Cesium.Transforms.eastNorthUpToFixedFrame(RCSorigincenter);

this.RCSmatrixInverse = Cesium.Matrix4.inverseTransformation(this.RCSMatrix, new Cesium.Matrix4());

/**

* 相对坐标转换成对应的世界坐标

*

* @param {Object} localCoordinates 相对坐标系中的坐标,如 {x:1,y:1,z:1}

* @param {Object} result 世界坐标系中的对应坐标,XYZ格式

* @returns

*/

this.localToWorldCoordinates = function(localCoordinates, result){

if (!result) {

result = new Cesium.Cartesian3();

}

Cesium.Matrix4.multiplyByPoint(this.RCSMatrix, localCoordinates, result);

return result;

};

/**

* 世界坐标转换成对应的相对坐标

*

* @param {Object} WorldCoordinates 世界坐标系中的坐标,XYZ格式

* @param {Object} result 相对坐标系中的坐标,XYZ格式

* @returns

*/

this.WorldCoordinatesTolocal = function(WorldCoordinates, result){

if (!result) {

result = new Cesium.Cartesian3();

}

Cesium.Matrix4.multiplyByPoint(this.RCSmatrixInverse, WorldCoordinates, result);

return result;

};

};

五、总结

  总的来说,Cesium对于坐标转换已经给我们做的太好了,大多时候我们直接使用即可。因为我有很多地方都用到了相对坐标与世界坐标的转换,所以自己就做了一个公共方法。在使用中还是很方便的,实例化一个相对转换关系对象,然后就可以互转了(: P)。

cesium 学习(六) 坐标转换的更多相关文章

  1. Hbase深入学习(六) Java操作HBase

    Hbase深入学习(六) ―― Java操作HBase 本文讲述如何用hbase shell命令和hbase java api对hbase服务器进行操作. 先看以下读取一行记录hbase是如何进行工作 ...

  2. TweenMax动画库学习(六)

    目录            TweenMax动画库学习(一)            TweenMax动画库学习(二)            TweenMax动画库学习(三)            Tw ...

  3. SVG 学习<六> SVG的transform

    目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...

  4. C#多线程学习(六) 互斥对象

    如何控制好多个线程相互之间的联系,不产生冲突和重复,这需要用到互斥对象,即:System.Threading 命名空间中的 Mutex 类. 我们可以把Mutex看作一个出租车,乘客看作线程.乘客首先 ...

  5. Unity学习(六)5.x依赖打包

    http://blog.sina.com.cn/s/blog_89d90b7c0102w2ox.html unity5已经封装好了接口,所以依赖打包并没有那么神秘和复杂了. 打包: 1.定义好资源的a ...

  6. (转)MyBatis框架的学习(六)——MyBatis整合Spring

    http://blog.csdn.net/yerenyuan_pku/article/details/71904315 本文将手把手教你如何使用MyBatis整合Spring,这儿,我本人使用的MyB ...

  7. cesium 学习(五) 加载场景模型

    cesium 学习(五) 加载场景模型 一.前言 现在开始实际的看看效果,目前我所接触到基本上都是使用Cesium加载模型这个内容,以及在模型上进行操作.So,现在进行一些加载模型的学习,数据的话可以 ...

  8. Cesium学习系列汇总

    内容比较多,完整看完需要大概10分钟,废话不多说,撸起袖子,加油干!!! 1.前言 按照套路,先介绍一下什么是Cesium. Cesium ['siːzɪəm]是JavaScript开源库,通过Ces ...

  9. day 84 Vue学习六之axios、vuex、脚手架中组件传值

    Vue学习六之axios.vuex.脚手架中组件传值   本节目录 一 axios的使用 二 vuex的使用 三 组件传值 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 axios的 ...

随机推荐

  1. 新玩法,CentOS7中LVM通过扩展逻辑卷扩展swap空间

    在我们日常运维工作中,偶尔也会遇到需要扩展swap空间的操作.扩展swap空间的方法很多,现在让我们一起来探讨一下,在LVM下扩展swap空间的方法. 1.查看一下卷组,是否还有空闲空间能用于扩展sw ...

  2. 注册表Demo

    一.获取安装程序信息 #include <windows.h> #include <iostream> #include <string> #include < ...

  3. face='Webdings' 的字体对照表

    刚才研究动网论坛代码,发现一个页面提示标记 i 感觉很神奇,看了半天才明白原来是一种叫“Webdings”的字体,其实很简单,只需要<font face='webdings' size=&quo ...

  4. orm单表操作

    二.orm简介 ORM:object relation mapping (ORM是“对象-关系-映射”的简称) MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦, ...

  5. 解决Linux和Windos不同步的问题

    两种方式: 一:在windos上进行操作      (1).cmd中输入如下命令      Reg add HKLM\SYSTEM\CurrentControlSet\Control\TimeZone ...

  6. SQL Server Alwayson架构下 服务器 各虚拟IP漂移监控告警的功能实现 -2(虚拟IP视角)

    1.需求描述 我们知道Windows Cluster 都是多节点的,当虚拟IP漂移的时候,一般都是从一个节点漂移到另外一个节点.如果可以及时捕捉到旧节点信息是什么.新节点信息是什么对我们提供高可用的数 ...

  7. 代码审计之seacms v6.45 前台Getshell 复现分析

    1.环境: php5.5.38+apache+seacms v6.45 seacms目录结构: │─admin //后台管理目录 │ │─coplugins //已停用目录 │ │─ebak //帝国 ...

  8. vim 列编辑模式

    vim 列编辑模式 标签: vim 视窗模式 列编辑模式 vim 列编辑模式 例子:给列批量添加前缀.后缀.修改字段 vim 列编辑模式 vim 有三种编辑模式,命令模式.输入模式.视窗模式,我们常用 ...

  9. Zookeeper详解-API(六)

    ZooKeeper有一个绑定Java和C的官方API.Zookeeper社区为大多数语言(.NET,python等)提供非官方API.使用ZooKeeper API,应用程序可以连接,交互,操作数据, ...

  10. Spring boot中Spring-Data-JPA操作MySQL数据库时遇到的错误(一)

    执行遇到如下错误: 看错误时要注意两点: 1.控制台报错情况,一般情况下红色第一行很重要,举例:上图info之下,蓝底标出的部分. 2.这种一般是以堆栈形式描述的,也就是重点在栈底的最后的一个完整的句 ...