Focus On 3D Terrain Programming·Chapter 5(1)

2024-09-01 02:38

本文主要是介绍Focus On 3D Terrain Programming·Chapter 5(1),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

写在前面的话

原著:《Focus On 3D Terrain Programming》
章节:Chapter5 Geomipmapping for the CLOD Impaired
说明:图形渣、英语渣,学习的同时记录下来的(主要是不翻译就读不下去TT),希望能和大家相互交流学习,翻译有误的地方欢迎指出^^

正文开始↓

哦吼!你将要学习地形编程中的核心内容,里面包含了相当复杂的算法。实际上,这是个谎话啦。本章我将讲述3种简单且高效的算法。并且,再一次,我会让你省略漫长的介绍而简要地告诉你本章内容:

■连续层次细节(CLOD)的含义
■Geomipmapping(Geometrical Mipmap)背后的理论
■实现Geomipmapping的方法

简单起见,我将本章的内容分成了3个部分。尽管如此,内容仍相当地多。不过,千万别被本章的篇幅吓到,我会一如既往地用一种风趣而简洁的方式来呈现。不过,要注意我将稍稍改变一下学习风格。第5、6、7章比之前的章节更注重算法和伪代码。在后面的章节,我仍会为你提供自己的示例及实现,但是这些实现是简单的,你需要结合文章使用。照之前所说,让我们开始吧。

CLOD Terrain 101

你已经多次在本书中听到Continuous Level of Detail(CLOD)一词,现在是时候告诉你它到底是什么了。CLOD算法,用一句话来解释,即一个动态多边形网格“给”需要更多细节的区域额外的三角形。这只是一个简单的陈述,学习本章之后,你将了解更多关于CLOD的内容。如果你还不理解CLOD,也别烦恼哈。

为什么要费心使用CLOD地形呢?

CLOD算法需要更多的研究,更难编写程序且比暴力实现方法占用更多的CPU周期。既然如此,为什么还要费心使用CLOD算法呢?答案很简单:为了创建更真实,更细致,最重要的是,更快速的地形。

更多细节添加到更多需要细节的地方

CLOD的一个基本思想就是添加更多的细节(更多三角形)到需要的地方。例如,我们想要一个相对平滑的地形曲面(见图5.1),比起一个相对复杂的地形曲面(见图5.2),需要平均较少的三角形。

这里写图片描述
图5.1 需要较少的三角形渲染平滑地形

这里写图片描述
图5.2 需要较多的三角形渲染复杂地形

然而,不是所有算法都担心需要细化的区域中三角形的分布。Geomipmapping不会对需要细化的区域放置更多三角形,但是Rottger的四叉树算法(第6章,“Climbing the Quadtree”)是这样做的。因此,对CLOD而言,从整体来看,在需要细化的地方添加更多细节,并不总是这样的,但大多数情况下是的。我已经完全把你搞混乱了吗?

剔除之前从未剔除的

基于CLOD算法的另一个优点是比起暴力方法允许选择性地对多边形进行剔除(cull)。这意味着那些看不见的多边形不用发送给API。例如,我们从一系列地形瓦片开始实现geomipmapping。如果某些瓦片不可见,我们一下子消除潜在的289个渲染顶点(17×17的顶点块)。这极大地减轻了显卡加载的负担,并且剔除操作也没有让CPU繁忙。这个简单的方法使得GPU、CPU甚至整个主板工作起来更加轻松。

CLOD地形并不是完美的

尽管使用CLOD地形算法确实存在一些缺点。说来奇怪的是,全世界都在帮我写下这一节,今天我的邮箱收到了8月发行的Game Developer Magazine。大多数CLOD算法的主要缺点是在每帧多边形网格更新时复杂的“薄记(book-keeping)”。

这种“簿记”的缺点几乎不那么普遍当这些算法(geomipmapping,Rottger的四叉树算法以及ROAM)中的大部分被设计时。这是因为这些算法想将大部分工作放在CPU运行,并且只将少量需要的信息传给GPU。不过,从那时起,处理方式已将在发生改变。现在比起CPU,我们更关注GPU。

CLOD地形介绍总结

很显然,如果geomipmapping、四叉树以及ROAM等算法过时了的话,那么现在你就没有机会读它们了,意思就是还有人对每个算法进行优化,让它们成为当今重要的地形渲染算法。考虑到这一点,我将不再唠叨CLOD并开始讲述geomipmapping的实现。

这篇关于Focus On 3D Terrain Programming·Chapter 5(1)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1125708

相关文章

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

SAM2POINT:以zero-shot且快速的方式将任何 3D 视频分割为视频

摘要 我们介绍 SAM2POINT,这是一种采用 Segment Anything Model 2 (SAM 2) 进行零样本和快速 3D 分割的初步探索。 SAM2POINT 将任何 3D 数据解释为一系列多向视频,并利用 SAM 2 进行 3D 空间分割,无需进一步训练或 2D-3D 投影。 我们的框架支持各种提示类型,包括 3D 点、框和掩模,并且可以泛化到不同的场景,例如 3D 对象、室

Chapter 13 普通组件的注册使用

欢迎大家订阅【Vue2+Vue3】入门到实践 专栏,开启你的 Vue 学习之旅! 文章目录 前言一、组件创建二、局部注册三、全局注册 前言 在 Vue.js 中,组件是构建应用程序的基本单元。本章详细讲解了注册和使用 Vue 的普通组件的两种方式:局部注册和全局注册。 本篇文章参考黑马程序员 一、组件创建 ①定义 Vue 组件是一种具有特定功能的 Vue 实

模具要不要建设3D打印中心

随着3D打印技术的日益成熟与广泛应用,模具企业迎来了自建3D打印中心的热潮。这一举措不仅为企业带来了前所未有的发展机遇,同时也伴随着一系列需要克服的挑战,如何看待企业引进增材制造,小编为您全面分析。 机遇篇: 加速产品创新:3D打印技术如同一把钥匙,为模具企业解锁了快速迭代产品设计的可能。企业能够迅速将创意转化为实体模型,缩短产品从设计到市场的周期,抢占市场先机。 强化定制化服务:面

Chapter 10 Stability and Frequency Compensation

Chapter 10 Stability and Frequency Compensation Chapter 8介绍了负反馈, 这一章介绍稳定性, 如果设计不好, 负反馈系统是要发生震荡的. 首先我们学习理解稳定判断标准和条件, 然后学习频率补偿, 介绍适用于不同运放的补偿方式, 同时介绍不同补偿对两级运放slew rate的影响, 最后介绍Nyquist’s判断标准 10.1 Gener

WPF入门到跪下 第十三章 3D绘图 - 3D绘图基础

3D绘图基础 四大要点 WPF中的3D绘图涉及4个要点: 视口,用来驻留3D内容3D对象照亮部分或整个3D场景的光源摄像机,提供在3D场景中进行观察的视点 一、视口 要展示3D内容,首先需要一个容器来装载3D内容。在WPF中,这个容器就是Viewport3D(3D视口),它继承自FrameworkElement,因此可以像其他元素那样在XAML中使用。 Viewport3D与其他元素相

python画图|3D图基础教程

python画3D图和2D流程类似: 【a】定义一个自变量x; 【b】定义两个因变量y和z; 【c】直接输出plot(x,y,z) 今天就一起快乐学习一下画3D图的基础教程。 【1】官网教程 打开官网,可以迅速找到学习教程,参考下述链接: https://matplotlib.org/stable/plot_types/3D/plot3d_simple.html 然后我们解读一下示

OGRE 3D----创建第一个OGRE 3D示例

目录 1. OGRE 3D概述 2. OGRE 3D vs VTK 3. 编译OGRE 3D 源码 4. 创建示例和配置其编译环境 5. 配置示例程序的执行环境 1. OGRE 3D概述 OGRE (Object-Oriented Graphics Rendering Engine) 是一个开源的、高级的 3D 图形渲染引擎,它提供了一个抽象层,使得开发者可以专注于创建内容和

echarts 多个3D柱状图

图片样式: 代码实现: <template><div :class="className" :style="{height:height,width:width}" /></template><script>require("echarts/theme/sakura"); // echarts themeexport default {props: {className: {typ