three.js+WebGL踩坑经验合集(8.3):合理设置camera.near和camera.far缓解实际场景中的z-fighting叠面问题

本篇延续上篇内容:

three.js+WebGL踩坑经验合集(8.2):z-fighting叠面问题和camera.near的坑爹关系-CSDN博客

笔者也是狠佩服自己:一个还没划上句号的文章都能拖了半年才继续写。这次也是运气好,工作上再次遇到叠面问题,可以借这机会继续深入研究。

在重新进入状态之前,笔者先不给大家深入探讨帮助文档说得让人一知半解的,polygonOffset的两个系数m和r的工作原理,而是先承接上篇内容,把camera.far也简单说一说。

上篇我们重点讨论了near以及far/near这两个指标在处理z-figting问题上的重要性,至于far是还没有单独揪出来说。

实际上,这玩意儿也不用太纠结,我们继续沿用上一篇的曲线图进行直观的演示。

因为图像不是直线,所以叠面问题的严重程度不仅仅取决于far和near,还要看我们的应用场景处于曲线的哪个区间,越是陡峭的区间,z深度拉得越开,叠面问题越少。所以笔者在上述演示的基础上完善了下,每200像素绘制一条竖直线,观察在near和far调整的过程中,曲线跟这些竖直线的交点处的斜率变化。

注意:本文说的错开,是看白色曲线的斜率,而非每根紫色线的距离

不难看出,在这个案例中,near越大或者far越大,5个面的z都错得越开。实际上,大多数的业务场景都有这个规律,但至于near和far具体设置多少,这还得看场景物体的具体坐标。这里说的坐标,指的是物体的世界坐标跟camara.matrixWorldInverse相乘后的结果。

由此可见,near和far都尽可能调大,对叠面问题的缓解会有非常大的帮助,结合上一篇文章,我们来小结一下:

1 透视相机下缓解叠面问题的方案,首先要让far/near尽可能大

2 在far/near足够大的情况下,far和near同时调大,能非常有效地缓解叠面问题

3 我们应该根据业务场景来确定项目中最终的near和far值,一是确保物体不被裁切,二是尽可能让物体落在z深度错开程度比较高的区间内,可以用跟笔者类似的方法调出一个满意的结果

4 正交相机无视这些问题

笔者这几天对polygonOffset再次做了深入的研究,api给出的offset计算公式

m*polygonOffsetFactor+r*polygonOffsetUnits

中的r笔者已经搞明白了是啥,下篇会给大家分享,而m值,目前还没搞透,但也有点眉目了,所以下篇先来聊聊r这个系数到底是个什么玩意儿,敬请期待!

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

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

相关文章

记一次生产环境Hbase填坑之路、Hbase客户端登陆、kerberos认证、端口列表、Pod上手撕代码【Hbase最佳实践】

背景 1、软件系统(转储系统)需要向生产环境迁移:迁到国产操作系统、国产资源池(Hbase存储不变) 2、老环境上的转储系统本身存在写入hbase的性能问题、及部分省份写入hbase失败的问题(20%失败)…

C++知识杂项搜集

C使用如下库优化事件的注册和发布,ZeroMQzmqpp 通信机制,请求-应带方式,push-pull方式,publisher-subcriber发布-订阅模式eventpp 事件注册和回调sockpp tcp/udp封装threadpool 线程池Jinja 一个 python 的模板实现配置是实现…

连锁零售排班难?自动排班系统来解决

零售、连锁企业门店多、员工杂、班次密,排班时总有绕不开的问题:跨门店调人成本怎么算?节假日高峰期人手怎么补?全职兼职混合排班怎么平衡?其实,这些场景化难题,盖雅自动排班系统早就有了针对性…

Android用Coil 3检查媒体资源是否有效,Kotlin

Android用Coil 3检查媒体资源是否有效,Kotlin WorkerThreadfun checkImage(ctx: Context, uri: Uri): Boolean {val t System.currentTimeMillis()val request ImageRequest.Builder(ctx).data(uri).memoryCacheKey(uri.toString()).precision(Precision.INEXACT)…

Seaborn数据可视化实战:Seaborn数据可视化入门-绘制统计图表与数据分析

使用Seaborn绘制统计图表:从入门到精通 学习目标 通过本课程的学习,你将掌握如何使用Seaborn库绘制各种统计图表,包括直方图、密度图和箱形图。你将了解这些图表在数据分析中的应用,以及如何通过图表来更好地理解数据。 相关知识点…

​Mac用户安装JDK 22完整流程(Intel版dmg文件安装指南附安装包下载)​

一、准备工作 ​确认你的 Mac 是 Intel 芯片的​ 如果你的 Mac 是 2020 年及之前出的,大概率是 Intel 芯片,可以用这个 ​jdk-22_macos-x64_bin.dmg。如果是 2020 年之后出的 M1 或 M2 芯片的 Mac(就是 Apple 芯片),那…

C语言——链表指定区间反转

目录 1.创建一个链表 1.链表节点定义 2.创建新节点 3.链表生成(输入) 4.链表输出 2.链表指定区间反转函数 1.创建哑节点 2.找到第m-1位的节点,开始 反转 3.连接反转后的链表与未反转的链表 3.未使用哑节点的运行结果 这段代码可以…

设计一个完整可用的 Spring Boot Starter

目录 1. 创建项目结构 2. 添加核心依赖 (pom.xml) 3. 实现核心组件 (1) 配置属性类 (2) 服务实现类 (3) 自动配置类 4. 注册自动配置 5. 配置元数据支持 6. 打包发布 7. 其他项目引用 (1) 添加依赖 (2) 配置参数 (3) 使用服务 设计要点 要设计一个完整可用的 Spr…

Bright Data 代理 + MCP :解决 Google 搜索反爬的完整方案

个人主页:chian-ocean 专栏 引言 人工智能技术和大数据的发展,实时访问网页数据成为许多应用的核心需求。相比传统方案依赖静态或定期更新的数据,AI可以实时抓取和分析网页上的及时更新的信息,迅速适应变化的环境,提…

Java基础第4天总结(多态)

package com.itheima.duotai;public class Animal {String name "动物";public void run(){System.out.println("动物会跑~~~");} }package com.itheima.duotai;public class Wolf extends Animal{String nama "狼";Overridepublic void run(…

Git克隆时遇到“Filename too long“错误的完美解决方案

Git克隆时遇到"Filename too long"错误的完美解决方案 问题描述 在使用Git克隆项目时,你是否遇到过这样的错误: $ git clone gitexample.com:project.git Cloning into project... remote: Enumerating objects: 1883, done. remote: Count…

分享一个基于Python与spark大数据的护肤品市场用户行为分析与可视化平台,基于hadoop的护肤品使用行为追踪与分析可视化平台的设计与实现

💕💕作者:计算机源码社 💕💕个人简介:本人八年开发经验,擅长Java、Python、PHP、.NET、Node.js、Spark、hadoop、Android、微信小程序、爬虫、大数据、机器学习等,大家有这一块的问题…

页面中嵌入Coze的Chat SDK

Coze 为将 AI 聊天机器人(Bot)嵌入您的网页提供了两种主流方式:Web SDK 和 API 接口调用。它们分别适用于不同的场景,下面我将为您介绍这两种方法,并提供一些选择建议。 特性 Web SDK API 接口调用 实现方式 引入一段JS代码,快速嵌入一个预制的聊天窗口 通过HTTP API发送…

DataEase+MaxKB:让BI再多个“A”

一、前言当前DataEase BI更多聚焦于BI展示层,然而,在与组件Copilot 以及后续计划替换的 Sqlbot的融合方面,目前仍存在一些亟待解决的问题,当它们尝试与 DataEase 进行结合应用时,出现了两种较为突出的状况。一方面&…

VUE 的弹出框实现图片预览和视频预览

这是一个基于Vue3封装的媒体预览组件,主要功能包括:多格式支持:可同时预览图片和视频图片操作功能:缩放(支持滚轮缩放和按钮控制)旋转(90度增量旋转)拖拽(仅在放大状态下…

【Linux基础知识系列】第一百零九篇 - 使用shell的输入与输出重定向

在 Linux 系统中,Shell 是用户与操作系统交互的界面,通过命令行输入命令来执行各种操作。输入与输出重定向是 Shell 编程中非常重要的概念,它允许用户将命令的输出保存到文件中,或者从文件中读取输入,从而实现更灵活的…

Redis面试精讲 Day 30:Redis面试真题解析与答题技巧

【Redis面试精讲 Day 30】Redis面试真题解析与答题技巧 在“Redis面试精讲”系列的第30天,我们迎来收官之作——Redis面试真题解析与答题技巧。这一天的核心目标是:帮助你系统化梳理前29天所学知识,掌握高频面试题的解题思路,提升…

设计模式:单例模式(Singleton Pattern)

文章目录一、单例模式的概念二、单例模式的结构三、常见实现方式3.1 饿汉式单例3.2 懒汉式单例一、单例模式的概念 单例模式(Singleton Pattern)是一种创建型设计模式,它的核心思想是:保证在一个进程中,某个类仅有一个…

Swift 解法详解 LeetCode 362:敲击计数器,让数据统计更高效

文章目录 摘要 描述 题解答案 题解代码分析 代码讲解 示例测试及结果 时间复杂度 空间复杂度 总结 摘要 “敲击计数器”这道题听上去像个小游戏里的功能,但其实它背后对应的是一个常见的需求:在过去一段时间内统计事件发生的次数。比如网站的访问量统计、API 调用次数限制、…

coze工作流200+源码,涵盖AI文案生成、图像处理、视频生成、自动化脚本等多个领域

AI 博主风哥在github分享了 200 实用生产力coze工作流,涵盖AI文案生成、图像处理、视频生成、自动化脚本等多个领域,导入即用,项目地址https://github.com/Hammer1/cozeworkflows github下载慢也可前往该地址下载https://pan.baidu.com/s/1fC…