Cesium随笔:视锥绘制(下)

摘要:
3.总结了模型在铯中的平移、缩放和旋转是通过矩阵参数ModelMatrix实现的。学习好矩阵运算对理解三维世界非常有帮助。

0.前言

上一次Cesium随笔中介绍的视锥的绘制方法并不准确,使用camera.debugShow便可以检查到实际视锥和我们计算的视锥的姿态的误差情况,本文将简单介绍正确的视锥绘制方法,重点说明怎么根据两点来计算视锥的姿态。
笔者的可视域分析已经成功做出来,使用ShadowMap并对ShadowMapShader进行修改便可以实现(需要在源代码中修改GLSL以改变阴影着色效果),不过后续生产环境还需要借助后期处理技术将功能独立出来。

Cesium随笔:视锥绘制(下)第1张

GIF.gif

1.根据两点计算相机射向

参考自SandCastle里面的根据两点计算射线的例子,

let spotLightCamera = new Cesium.Camera(window.app.viewer.scene);
let direction = Cesium.Cartesian3.normalize(Cesium.Cartesian3.subtract(this.secondPos, this.firstPos, new Cesium.Cartesian3()), new Cesium.Cartesian3());
spotLightCamera.position = this.firstPos;//firstPos是相机起点
spotLightCamera.direction=direction;//direction是相机面向的方向


2.视锥绘制部分

视锥绘制代码参考自Cesium源代码中的Camera debug show部分

let scratchRight = new Cesium.Cartesian3();
let scratchRotation = new Cesium.Matrix3();
var scratchOrientation = new Cesium.Quaternion();
let position = spotLightCamera.positionWC;
let direction = spotLightCamera.directionWC;
let up = spotLightCamera.upWC;
let right = spotLightCamera.rightWC;
right = Cesium.Cartesian3.negate(right, scratchRight);

let rotation = scratchRotation;
Cesium.Matrix3.setColumn(rotation, 0, right, rotation);
Cesium.Matrix3.setColumn(rotation, 1, up, rotation);
Cesium.Matrix3.setColumn(rotation, 2, direction, rotation);
//计算视锥姿态
let orientation = Cesium.Quaternion.fromRotationMatrix(rotation, scratchOrientation);
//视锥轮廓线图形
let instanceOutline = new Cesium.GeometryInstance({
                geometry: new Cesium.FrustumOutlineGeometry({
                    frustum: spotLightCamera.frustum,
                    origin: this.firstPos,
                    orientation: orientation
                }),
                id: "pri" + window.app.viewer.scene.primitives.length + 1,
                attributes: {
                    color: Cesium.ColorGeometryInstanceAttribute.fromColor(new Cesium.Color(0.0, 1.0, 0.0, 1.0)),
                    show: new Cesium.ShowGeometryInstanceAttribute(true)
                }
            });
//添加图元
let newPrimitive = window.app.viewer.scene.primitives.add(new Cesium.Primitive({
                geometryInstances: instanceOutline,
                appearance: new Cesium.PerInstanceColorAppearance()
            }));

对了,上述代码之前别忘了先修改视锥的相关参数(不修改的话使用默认参数画出来的视锥会突破天际),上一篇随笔中有相关参数的说明。

spotLightCamera.frustum.near=1;
spotLightCamera.frustum.far=100;

除了上述方法外还可以直接使用DebugCameraPrimitive实体绘制视锥,但缺点是该实体好像不方便修改near和far参数。

3.总结

Cesium中模型的平移、缩放、旋转是通过ModelMatrix这个矩阵参数来实现的,学好矩阵运算对理解三维世界很有帮助。

本文转自 https://www.jianshu.com/p/f2c9a4cac078,如有侵权,请联系删除。

免责声明:文章转载自《Cesium随笔:视锥绘制(下)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇LaTex 制作表格 合并行multirow 合并列multicolumnIPMItool小结下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

DMA映射 dma_addr_t

DMA映射 一个DMA映射是要分配的DMA缓冲区与为该缓冲区生成的、设备可访问地址的组合。 DMA映射建立了一个新的结构类型——dma_addr_t来表示总线地址。dma_addr_t类型的变量对驱动程序是不透明的, 唯一允许的操作是将它们传递给DMA支持例程以及设备本身。 根据DMA缓冲区期望保留的时间长短,PCI代码有两种DMA映射: 1) 一致性映射...

Linux如何进行GPIO读写操作的?

摘要:本文介绍GPIO的读写,介绍基本原理,以及不同读写方式的性能。 本文分享自华为云社区《Linux 基于sysfs的GPIO读写操作》,作者:一颗小树x 。 前言 最近接触到Linux系统中的GPIO开发,这里做个小总结,也分享一下;本文会介绍GPIO的读写,介绍基本原理,以及不同读写方式的性能。 一、GPIO sysfs interface 基本原...

Java 关于SpringbootJPA分页及排序

创建Pageable对象 看了网上很多博客,都是在用 new PageRequest的方法创建Pageable对象。可是估计很多同学写了之后才发现原来这个方法作者已经标记为过时了; 替代的方法是不要new PageRequest,而是直接用 PageRequest.of这个方法 根据你的需求选择入参; 下面贴出对比 @Override @Transact...

图像边缘检测

一、实验目的:熟悉边缘检测的基本方法 二、实验内容:以chairgray.jpg图像为例,分别采用sobel、prewitt、roberts和 log对该图像及其加上噪声后的图像进行边缘检测。用到的matlab函数为edge,imnoise。 1 a=imread('D:/picture/ZiXia.jpg'); 2 a=rgb2gray(a); 3...

Dapper完美兼容Oracle,执行存储过程,并返回结果集。

Dapper完美兼容Oracle,执行存储过程,并返回结果集。 这个问题,困扰了我整整两天。 刚刚用到Dapper的时候,感觉非常牛掰。特别是配合.net 4.0新特性dynamic,让我生成泛型集合,再转json一气呵成。 不过,各种ORM总有让人吐槽的地方。。。 比如,我之前在SqlServer上写测试,搞封装,没有任何问题。CURD、批量操作、存储过...

JS判断鼠标移入元素的方向

最终效果 这里的关键主要是判断鼠标是从哪个方向进入和离开的 $("li").on("mouseenter mouseleave",function(e) { var w = this.offsetWidth; var h = this.offsetHeight; var x = e...