cesium获取模型实时坐标_Cesium 顶点着色器中求解模型坐标

1. 由世界坐标转模型坐标

顶点着色器:

attribute vec3 position3DHigh;

attribute vec3 position3DLow;

attribute vec3 normal;

attribute vec2 st;

attribute float batchId;

varying vec3 v_positionEC;

varying vec3 v_normalEC;

varying vec2 v_st;

void main()

{

vec3 positionWC = position3DHigh + position3DLow; // 得到世界坐标

// 官方得到世界坐标(齐次)是这么做的,在三维模式下等价

// vec4 positionWC = czm_computePosition();

vec4 positionMC = czm_inverseModel * vec4(positionWC, 1); // 得到模型坐标

// 以下为官方代码,未改动,仅修改注释

vec4 p = czm_computePosition(); // 得到世界坐标

v_positionEC = (czm_modelViewRelativeToEye * p).xyz; // 得到相机坐标

v_normalEC = czm_normal * normal; // 得到相机坐标系下的法线向量

v_st = st; // 传递uv

gl_Position = czm_modelViewProjectionRelativeToEye * p; // 世界坐标到裁剪空间坐标

}

2. 由相机坐标转模型坐标

顶点着色器

attribute vec3 position3DHigh;

attribute vec3 position3DLow;

attribute vec3 normal;

attribute vec2 st;

attribute float batchId;

varying vec3 v_positionEC;

varying vec3 v_normalEC;

varying vec2 v_st;

void main()

{

vec4 p = czm_computePosition(); // 得到齐次世界坐标

v_positionEC = (czm_modelViewRelativeToEye * p).xyz; // 得到相机坐标

v_normalEC = czm_normal * normal;

v_st = st;

/** 此处开始添加计算模型坐标的代码 */

vec4 positionMC = czm_inverseModelView * vec4(v_positionEC, 1.0); // 得到模型坐标

/** 添加的代码结束 */

gl_Position = czm_modelViewProjectionRelativeToEye * p; // 世界坐标到裁剪空间坐标

}

3. 坐标陷阱:模型坐标系≠东北上坐标系

参考如下代码:

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

viewer.scene.globe.depthTestAgainstTerrain = true;

viewer.camera.setView({

destination : new Cesium.Cartesian3(-2644963.9889313546, 5763731.142118295, 2199400.7089496767), //世界坐标系下的一个坐标点

orientation : {//旋转角度

heading :6.075,

pitch :-0.727,

roll : 6.283

}

});

const extrudedPolygon = new Cesium.PolygonGeometry({

polygonHierarchy : new Cesium.PolygonHierarchy(

Cesium.Cartesian3.fromDegreesArray([

112.41726298378288, 23.290411251106182,

113.67072522399741, 23.560312361463682,

114.09370956893551, 22.590768298743153,

112.83803246418894, 22.285610818885644

])

),

extrudedHeight: 30000

});

const instance = new Cesium.GeometryInstance({

geometry: extrudedPolygon,

id: 'box with height'

});

const m = new Cesium.Material({

fabric: {

type: 'Color',

uniforms: {

color: new Cesium.Color(216 / 255.0, 170 / 255.0, 208 / 255.0).withAlpha(0.618),

},

}

});

const aper = new Cesium.MaterialAppearance({

fragmentShaderSource:

` varying vec3 v_positionEC;

varying vec3 v_normalEC;

varying vec2 v_st;

void main()

{

vec3 positionToEyeEC = -v_positionEC;

vec3 normalEC = normalize(v_normalEC);

#ifdef FACE_FORWARD

normalEC = faceforward(normalEC, vec3(0.0, 0.0, 1.0), -normalEC);

#endif

czm_materialInput materialInput;

materialInput.normalEC = normalEC;

materialInput.positionToEyeEC = positionToEyeEC;

materialInput.st = v_st;

czm_material material = czm_getMaterial(materialInput);

material.diffuse = vec3(0.24313725490196078, 0.7372549019607844, 0.9333333333333333);

material.emission = vec3(0.0, 0.66666666, 0.0);

material.specular = 0.5;

material.shininess = 0.8;

#ifdef FLAT

gl_FragColor = vec4(material.diffuse + material.emission, material.alpha);

#else

gl_FragColor = czm_phong(normalize(positionToEyeEC), material, czm_lightDirectionEC);

#endif

}

`,

vertexShaderSource:

`

attribute vec3 position3DHigh;

attribute vec3 position3DLow;

attribute vec3 normal;

attribute vec2 st;

attribute float batchId;

varying vec3 v_positionEC;

varying vec3 v_normalEC;

varying vec2 v_st;

void main()

{

vec4 p = czm_computePosition();

v_positionEC = (czm_modelViewRelativeToEye * p).xyz; // position in eye coordinates

v_normalEC = czm_normal * normal; // normal in eye coordinates

v_st = st;

vec4 positionMC = czm_inverseModelView * vec4(v_positionEC, 1.0);

vec4 positionMC_new = vec4(positionMC.xy, positionMC.z + czm_frameNumber * 100.0, 1.0); // z轴向上平移动画

vec4 resultPosition = czm_modelViewInfiniteProjection * positionMC_new; // 一步直接算到 gl_Position 所需的坐标

gl_Position = resultPosition;

}

`,

});

var p = viewer.scene.primitives.add(new Cesium.Primitive({

geometryInstances: instance,

appearance: aper,

releaseGeometryInstances: false,

compressVertices: false,

}));

在顶点着色器处,我对模型坐标的z值进行了修改,达到z轴平移动画的效果

d95c21aa22acd5dbe5a0186873eef584.png

可是动画的效果并不是沿着地表的垂直向上的方向平移,换做是 x、y 平移也不是对应的正东方、正北方(如果平移量大,还要考虑曲率的问题)

所以,可以下结论:

顶点着色器中的模型坐标所用的局部坐标系,仅仅是原点在模型中心,但是三轴并不是沿着正东x、正北y、垂直朝上z这三轴的。

要格外注意这一点,这是我在使用 Primitive API 时发现的问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/436807.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【转】关于CLR内存管理一些深层次的讨论[上篇]

半年之前,PM让我在部门内部进行一次关于“内存泄露”的专题分享,我为此准备了一份PPT。今天无意中将其翻出来,觉得里面提到的关于CLR下关于内存管理部分的内存还有点意思。为此,今天按照PPT的内容写了一篇文章。本篇文章不会再讨论…

mysql数据库连接地址utf8_在Python中连接到MySQL数据库时UTF8不工作

我正在努力使Python更好地使用UTF-8编码的MySQL数据库,例如,挪威字符。我找了好几个小时,但没能找到像预期的那样有效的东西。以下是从数据库中提取的示例表:mysql> select * from my_table;---------------------| id | shop_…

【转】.NET Remoting

.Net Remoting提供了一种允许一个应用域中的对象与另一个应用域中的对象进行交互的框架。是.NET框架中的一个重要技术改进,它用于减轻运行应用程序的系统开销. 中文名 .Net Remoting 作 用 减轻运行应用程序的系统开销 目录 1 介绍2 .NET Remoting的原理 ▪ 1.NET Rem…

python多重赋值技巧_python教程12课:多元赋值、多重赋值、运算符以及判断字符串类型...

# 多元赋值:# x,y,z 和 1,2,‘String是两个元组,只不过元组的 () 被省略掉了x, y ,z 1, 2, Stringprint(x, y, z)(x, y ,z) (3, 4, String)print(x,y,z)# 一般用在交换变量值#交换变量值常规思路x 10,y 20z 30x ,y, z y,z,xprint(x,y,z)#使用多元赋值…

【转】关于CLR内存管理一些深层次的讨论[下篇]

《上篇》中我们主要讨论的是程序集(Assembly)和应用程序域(AppDomain)的话题,着重介绍了两个不同的程序集加载方式——独占方式和共享方式(中立域方式);以及基于进程范围内的字符串驻…

python正则表达式处理txt_Python文本处理服务(re正则表达式例子)

正则表达式例子检查对子在此示例中,我们将使用以下帮助函数来更优雅地显示匹配对象:def displaymatch(match): if match is None: return None return % (match.group(), match.groups())假设你在写一个扑克程序,一个玩家的一手…

【转】深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第一节 理解堆与栈

理解堆与栈 导航 深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第一节 理解堆与栈 深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第二节 栈基本工作原理 深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第三节 栈与堆,值类型与引用类型 深入浅出图…

bi 存储过程方案_BI 系统中容易被忽视的数据源功能

BI 系统中容易被忽视的数据源功能用户在选购 BI 解决方案的时候,常常会更关注界面环节的功能指标,比如美观性、操作的流畅性、移动端支持等等。毕竟,BI 是要给业务人员使用的,这些看得见的内容一般不容易被遗漏。然而,…

【转】深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第二节 栈基本工作原理

栈基本工作原理 导航 深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第一节 理解堆与栈 深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第二节 栈基本工作原理 深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第三节 栈与堆,值类型与引用类型 深入浅…

matlab将二值图像与原图重叠_图像处理matlab及图像融合图像镶嵌图像拼接

要把double的图像(范围是0到1)再次转化为256灰度值的,可以这样Igrey uint8(I2*255)图像类型转换函数:dither() 通过颜色抖动,把真彩图像转换成索引图像或灰度图象转换成二值图像gray2ind() 将灰度图像(或二值图像)转换成索引图像grayslice() …

【转】深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第三节 栈与堆,值类型与引用类型

前言 虽然在.Net Framework 中我们不必考虑内在管理和垃圾回收(GC),但是为了优化应用程序性能我们始终需要了解内存管理和垃圾回收(GC)。另外,了解内存管理可以帮助我们理解在每一个程序中定义的每一个变量是怎样工作的。 简介 本文将介绍值类型与引用类…

mysql udf sm4_SM4国密算法Java版

根据 国密SM4 文档 编写的一个Java 加密解密样例package javasm4;/**** author Jeen*/public class JavaSM4 {public static int[] key new int[4];//密钥public static int[] temp new int[4];//中间量 存储运算结果public static int[] rkey new int[32];//轮密钥public s…

【转】.net框架读书笔记---CLR内存管理\垃圾收集(一)

一、垃圾收集平台基本原理解析 在C#中程序访问一个资源需要以下步骤: 调用中间语言(IL)中的newobj指令,为表示某个特定资源的类型实例分配一定的内存空间。初始化上一步所得的内存,设置资源的初始状态,从而…

gperftools mysql_利用 gperftools 对nginx mysql 内存管理 性能优化

利用 gperftools 对nginx 与 mysql 进行 内存管理 性能优化 降低负载.Gperftools 是由谷歌开发。官方对gperftools 的介绍为:These tools are for use by developers so that they can create more robust applications. Especially of use to those developing m…

【转】.net框架读书笔记---CLR内存管理\垃圾收集(二)

前几天学习了CLR垃圾收集原理和基本算法,但是那些是仅仅相对于托管堆而言的,任何非托管资源的类型,例如文件、网络资源等,都必须支持一种称为终止化(finalization)的操作。 终止化 终止化操作允许一种资源…

python time 时间戳_Python的time.time()返回本地或UTC时间戳吗?

这是可以在文本文件中使用的时间戳记的文本形式。(问题的标题在过去是不同的,因此对此答案的介绍进行了更改,以阐明如何将其解释为时间。[2016年1月14日更新])您可以使用.now()或.utcnow()来将时间戳记作为字符串获取datetime.datetime:>&…

【转】.net框架读书笔记---CLR内存管理\垃圾收集(三)

接上一篇.net框架读书笔记---CLR内存管理\垃圾收集(二),主要学习了终止化对象(实现了Finalize方法的对象),了解了终止化对象的弊端,学习了通过实现IDisposable接口,通过Dispose方法来…

mysql实验三单表和多表查询_数据库实验三(单表查询)

实验三:select sno,snamefrom student;//(1)查询全体学生的学号和姓名select *from student;//(2)查询全体学生的详细记录select sname,sage,sdeptfrom student where sdeptMA;//(3)查询软件学院的学生姓名、年龄、系别select distinct snofrom sc;//(4)查询所有选修过课程的学…

【转】.net框架读书笔记---CLR内存管理\垃圾收集(四)

弱引用 当一个根指向一个对象时,该对象不可能被垃圾收集器收集,在这种情况下,通常说存在一个该对象的强引用(strong reference)。垃圾收集器还支持弱引用(weak reference)的概念。弱引用允许垃圾…

1756冗余_AB冗余模块1756-RM

AB冗余模块1756-RM100-C30UKJ01100-C30UKJ10100-C30UKL00100-C30UKL10AB冗余模块1756-RM100-C30UKP00100-C30UL00AB冗余模块1756-RM100-C30UL10100-C30UN00AB冗余模块1756-RM100-C30UN10100-C30UP001756-RM ControLogix冗余模块140U-H-RM12B 140U塑壳断路器外部附件1756-RMC1 C…