当前位置: 首页 > article >正文

告别‘纸片感’!用C++手撸一个带虚焦模糊的光线追踪相机(附完整代码)

告别‘纸片感’用C手撸一个带虚焦模糊的光线追踪相机附完整代码你是否曾经觉得自己的光线追踪渲染图缺少一丝真实感那些完美聚焦的物体虽然清晰却总给人一种纸片般的扁平感。今天我们将一起探索如何通过实现虚焦模糊Defocus Blur来为你的渲染图注入电影级的景深效果。这不仅能让你的作品更加接近真实摄影效果还能显著提升场景的立体感和艺术表现力。1. 虚焦模糊背后的光学原理在真实世界中没有任何相机能够同时让所有距离的物体都保持完美聚焦。这种选择性聚焦的效果正是我们所说的景深而在光线追踪领域我们更倾向于使用虚焦模糊这个术语来描述这种现象。薄透镜模型是我们实现虚焦模糊的基础。想象一下光线从场景中的一点发出通过透镜的不同位置汇聚到传感器上的一个点这个过程中有三个关键参数影响着最终的模糊效果光圈大小控制透镜的有效开口直径焦距从透镜到完美聚焦平面的距离聚焦距离相机到需要清晰呈现的物体的距离提示在真实相机中改变聚焦距离通常需要物理移动镜头位置而在我们的虚拟相机中这一切都可以通过数学计算来实现。2. 相机类的关键扩展为了实现虚焦模糊效果我们需要对传统的针孔相机模型进行扩展。以下是改造后的camera类核心新增成员class camera { public: // ...原有成员... double defocus_angle 0; // 虚化圆锥的角度 double focus_dist 10; // 完美聚焦平面的距离 private: // ...其他私有成员... vec3 defocus_disk_u; // 虚化圆盘的水平半径向量 vec3 defocus_disk_v; // 虚化圆盘的垂直半径向量 point3 defocus_disk_sample() const { auto p random_in_unit_disk(); return center (p[0] * defocus_disk_u) (p[1] * defocus_disk_v); } };初始化过程中需要计算的关键步骤根据defocus_angle和focus_dist计算虚化圆盘半径确定圆盘在相机坐标系中的方向向量为后续随机采样做好准备void camera::initialize() { // ...其他初始化代码... // 计算虚化圆盘的基础向量 auto defocus_radius focus_dist * tan(degrees_to_radians(defocus_angle / 2)); defocus_disk_u u * defocus_radius; defocus_disk_v v * defocus_radius; }3. 光线生成算法的改造传统的光线追踪相机所有光线都从单一的相机中心点发出。要实现虚焦模糊我们需要让光线从虚化圆盘上的随机点发出。改造后的get_ray函数ray camera::get_ray(int i, int j) const { auto pixel_center pixel00_loc (i * pixel_delta_u) (j * pixel_delta_v); auto pixel_sample pixel_center pixel_sample_square(); auto ray_origin (defocus_angle 0) ? center : defocus_disk_sample(); auto ray_direction pixel_sample - ray_origin; return ray(ray_origin, ray_direction); }这个改造引入了几个重要概念虚化圆盘采样当defocus_angle大于0时光线从圆盘上的随机点发出聚焦逻辑所有光线都指向焦平面上的同一点确保聚焦区域清晰模糊程度控制defocus_angle越大圆盘半径越大模糊效果越明显4. 随机采样与单位圆盘生成为了实现从虚化圆盘的均匀采样我们需要一个能在单位圆盘内生成随机点的函数。这与常见的单位球体采样不同需要特别注意。高效的单位圆盘采样实现vec3 random_in_unit_disk() { while (true) { auto p vec3(random_double(-1,1), random_double(-1,1), 0); if (p.length_squared() 1) return p; } }这个函数采用拒绝采样法在[-1,1]范围内随机生成x和y坐标检查点是否落在单位圆内如果不在圆内则重新生成注意虽然看起来有无限循环的风险但实际上数学上保证了一定会在有限次尝试后返回有效点。5. 参数调优与效果对比正确设置相机参数对获得理想的虚焦模糊效果至关重要。下面是一个参数配置示例及其对应的视觉效果参数值视觉效果描述defocus_angle0无模糊所有物体都清晰defocus_angle5.0轻微模糊背景略有虚化defocus_angle10.0明显模糊电影级景深效果focus_dist3.4聚焦在近处物体focus_dist10.0聚焦在远处物体典型场景配置camera cam; cam.aspect_ratio 16.0 / 9.0; cam.image_width 400; cam.samples_per_pixel 100; cam.max_depth 50; cam.vfov 20; cam.lookfrom point3(-2,2,1); cam.lookat point3(0,0,-1); cam.vup vec3(0,1,0); cam.defocus_angle 10.0; // 明显的虚焦效果 cam.focus_dist 3.4; // 聚焦在距离相机3.4单位的位置6. 性能考量与优化技巧虚焦模糊虽然能显著提升视觉效果但也会增加渲染时间。以下是几个优化建议采样数平衡增加defocus_angle时需要相应增加samples_per_pixel过大模糊角度会导致噪点增加聚焦距离选择聚焦在场景中的主要兴趣点上次要元素可以适当模糊以减少计算量渐进式渲染先使用低采样数预览效果确定参数后再进行高质量渲染// 快速预览配置 camera preview_cam; preview_cam.samples_per_pixel 10; preview_cam.max_depth 5; preview_cam.defocus_angle 10.0; // 最终渲染配置 camera final_cam; final_cam.samples_per_pixel 100; final_cam.max_depth 50; final_cam.defocus_angle 10.0;7. 艺术化应用与创意效果虚焦模糊不仅是物理准确的模拟更是强大的艺术表达工具。你可以尝试选择性聚焦引导观众视线到场景关键元素极浅景深创造微缩模型般的特殊效果动态模糊结合相机移动模拟运动模糊创意参数组合// 极浅景深效果 cam.defocus_angle 15.0; cam.focus_dist 1.5; // 全景清晰效果 cam.defocus_angle 0.5; cam.focus_dist 20.0;在实际项目中我发现defocus_angle在5-15度之间最能平衡真实感和艺术效果。过大的角度虽然戏剧性强但会失去太多细节而过小的角度又难以产生明显的景深效果。

相关文章:

告别‘纸片感’!用C++手撸一个带虚焦模糊的光线追踪相机(附完整代码)

告别‘纸片感’!用C手撸一个带虚焦模糊的光线追踪相机(附完整代码) 你是否曾经觉得自己的光线追踪渲染图缺少一丝真实感?那些完美聚焦的物体虽然清晰,却总给人一种"纸片"般的扁平感。今天,我们将…...

KEIL开发必备:3种生成bin文件的实战方法(含路径问题解决方案)

KEIL开发实战:3种高效生成bin文件的工程化解决方案 在嵌入式开发领域,KEIL作为ARM架构的主流开发环境,其编译输出文件的管理往往成为团队协作的隐形痛点。许多开发者都遇到过这样的场景:当你在本地完美生成的bin文件,换…...

多任务处理原理揭秘:为什么你的电脑能同时运行微信和Chrome?

多任务处理原理揭秘:为什么你的电脑能同时运行微信和Chrome? 在数字时代,我们早已习惯一边用微信聊天,一边在Chrome浏览网页,同时后台还播放着音乐。这种看似平常的多任务体验,背后是操作系统经过半个世纪演…...

2026冲刺用!全场景通用降AIGC平台 千笔·专业降AIGC智能体 VS 灵感ai

在AI技术快速发展的今天,越来越多的学生和研究者开始依赖AI工具辅助论文写作,以提升效率和内容质量。然而,随着学术审查标准的不断提高,AI生成内容的痕迹愈发明显,查重系统对AIGC(人工智能生成内容&#xf…...

2026最新!10个降AIGC平台全场景通用测评,哪款最能帮你降AI率?

在当前学术写作和内容创作领域,AI生成内容(AIGC)的普及带来了前所未有的便利,但也引发了对原创性和查重率的担忧。越来越多的学生、研究人员以及内容创作者开始关注如何有效降低AI痕迹,提升文本的原创性与自然度。而“…...

Android设备Google TTS语音数据包快速安装与验证指南

1. 为什么需要Google TTS语音数据包 很多Android用户可能都遇到过这样的问题:明明手机里安装了Google文字转语音(TTS)引擎,但使用时却提示"语音数据包缺失"。这种情况在开发语音交互应用时尤为常见。我刚开始接触Androi…...

NSSM 实战手册:一键将你的脚本与程序转化为 Windows 后台服务

1. NSSM:Windows后台服务的万能钥匙 第一次在服务器上部署Node.js应用时,我盯着那个黑漆漆的命令行窗口发愁——只要关掉窗口,服务就断了。直到发现了NSSM这个神器,才明白原来把普通程序变成系统服务可以这么简单。NSSM全称Non-Su…...

从游戏到网页:5大3D引擎实战应用场景全解析(UE/Unity/Three.js等)

从游戏到网页:5大3D引擎实战应用场景全解析(UE/Unity/Three.js等) 在数字内容创作领域,3D引擎的选择往往决定了项目的成败。就像木匠需要根据家具类型选择不同工具一样,开发者也需要根据项目需求匹配合适的3D引擎。本文…...

【虚拟样机技术】Adams-Solidworks-Matlab联合仿真进阶实践——基于命令流的自动化建模与参数优化

1. 虚拟样机技术概述 虚拟样机技术是现代工程设计中不可或缺的工具,它通过计算机仿真来模拟物理系统的行为,帮助工程师在产品实际制造前预测其性能。这项技术广泛应用于机械、汽车、航空航天等领域,能够显著缩短开发周期、降低研发成本。 在虚…...

别再纠结选哪个了!手把手教你用Kilo Code一键整合Cline和Roo Code的核心功能

告别选择困难:Kilo Code一站式整合Cline与Roo Code实战指南 每次启动新项目时,你是否也经历过这样的纠结时刻?面对Cline精准的Plan/Act模式心动不已,却又舍不得Roo Code的多角色协作能力。现在,一个更聪明的选择摆在面…...

Halcon实战:5分钟搞定离散点拟合圆(附完整代码与参数详解)

Halcon实战:5分钟掌握离散点拟合圆的精髓与参数调优 第一次接触Halcon的圆拟合功能时,我被它强大的算法和复杂的参数列表弄得晕头转向。直到在工业视觉检测项目中,需要快速定位数百个圆形零件的位置,才真正体会到fit_circle_conto…...

别再只盯着参数了!聊聊数据中心交换机选型时,CLOS、Crossbar这些硬件架构到底该怎么看?

数据中心交换机硬件架构实战指南:从CLOS到Crossbar的智能选型策略 在数据中心网络规划中,工程师们常陷入参数对比的泥潭——背板带宽、端口密度、转发速率这些冰冷数字背后,真正决定设备长期价值的却是鲜少被深入讨论的硬件架构设计。当某金融…...

(aaa-) snap 不走系统代理,也不走终端的代理?:ubuntu官方:snap-store-proxy 的使用方法 (***)

⚠️ 注意:Snap 应用运行在沙箱中,默认不使用系统或终端环境变量(如 http_proxy),因此必须通过 snap set system proxy.* 显式配置 。 ## 官方方法,个人用途时,据说麻烦。 snap-store-proxy sna…...

MATLAB里给二自由度机械臂装上‘智能大脑’:手把手实现模糊PID轨迹跟踪仿真

为二自由度机械臂注入智能:模糊PID控制的MATLAB实战解析 在机器人控制领域,让机械臂精准跟踪预定轨迹一直是个令人着迷的挑战。传统PID控制器虽然结构简单,但在面对复杂非线性系统时往往力不从心。想象一下,如果给机械臂装上能够&…...

DCCRN-E: Enhancing Real-Time Speech Clarity with Phase-Aware Complex Masking

1. 实时语音增强的挑战与DCCRN-E的突破 想象一下你在嘈杂的咖啡厅视频会议时,对方总是要求你重复说话内容;或是智能音箱在厨房油烟机轰鸣时完全听不懂指令——这些正是实时语音增强技术要解决的核心痛点。传统方法往往面临两难选择:要么牺牲处…...

Cadence Allegro 17.4实战指南:高效导出PCB设计中的IPC网表与生产文件

1. 从设计到生产:为什么IPC网表如此重要? 在PCB设计流程中,很多工程师容易忽视生产文件的导出环节,直到工厂反馈"文件不完整"才手忙脚乱。我经历过一次惨痛教训:设计好的六层板因为坐标文件格式错误&#x…...

高通QUPv3安全配置与多协议访问控制解析

1. 高通QUPv3架构与安全隔离基础 在嵌入式系统开发中,硬件资源的安全隔离是确保系统稳定性的关键。高通QUPv3(Qualcomm Universal Peripheral v3)作为第三代通用外设接口控制器,其核心价值在于通过TrustZone技术实现物理硬件资源的…...

【WebRTC】Webrtc-streamer实战:从RTSP到WebRTC的低延迟流媒体转发

1. WebRTC-streamer 是什么? WebRTC-streamer 是一个开源工具,专门用于将传统流媒体协议(如 RTSP、RTMP)转换为 WebRTC 流。它的核心功能是充当一个桥梁,把摄像头、屏幕录制、本地文件等媒体源,通过 WebRTC…...

单相并网逆变器MATLAB仿真:离网仿真与PLL锁相环下的电感电流谐波含量THD分析

单相并网逆变器matlab仿真。 包括离网仿真,PLL锁相环等。 电感电流的谐波含量THD较小,仿真效果较好。搞过单相并网逆变器的都知道,仿真这玩意儿就像炒菜,火候差一点味道就变了。今天咱们直接上干货,在Matlab里搭个能随…...

JavaWeb —— 过滤器 (Filter) 与监听器 (Listener) 全解析(附代码)

过滤器(Filter)和监听器(Listener)是 JavaWeb 三大组件(Servlet、Filter、Listener)中的重要成员,与 Servlet 协同构成 JavaWeb 的基础骨架。过滤器负责拦截请求与响应,实现统一预处…...

JavaWeb ——HttpServletRequest 请求对象(附代码)

HttpServletRequest 是 JavaWeb 三大对象之一,封装了客户端向服务器发送的所有请求数据,是处理前端请求、获取参数、实现请求转发的工具。一、HttpServletRequest 1. 作用当客户端发送 HTTP 请求到 Tomcat 服务器时,Tomcat 会为每一次请求创建…...

COMSOL锂枝晶应力模型:到手即用

comsol锂枝晶应力模型,到手就能用。打开COMSOL看到锂枝晶模型就手痒?先别急着点"计算",咱们得把应力场和电化学揉明白了。模型库里的枝晶生长模块虽然自带基础设置,但想要真实模拟SEI膜破裂和机械变形,得自己加亿点点细…...

深入理解 synchronized:到底锁的是谁?

在 Java 多线程并发编程里,synchronized 是保证线程安全的核心关键字,但很多开发者只知道它能加锁,却不清楚它到底锁的是什么、不同写法锁的范围有何区别。这篇文章就把 synchronized 的锁对象、作用范围、经典测试用例一次性讲透&#xff0c…...

避坑指南:Containerd镜像加速新旧版本配置差异详解

Containerd镜像加速配置全解析:从版本差异到最佳实践 在云原生技术栈中,容器运行时作为基础组件的重要性不言而喻。作为Docker的轻量级替代方案,Containerd凭借其稳定性和高性能逐渐成为Kubernetes生态中的主流选择。然而,在实际生…...

2026-03-22 全国各地响应最快的 BT Tracker 服务器(联通版)

数据来源:https://bt.me88.top 序号Tracker 服务器地域网络响应(毫秒)1http://211.75.205.187:80/announce上海联通192http://211.75.210.221:6969/announce江苏镇江联通223http://93.158.213.92:1337/announce北京联通1284udp://176.99.7.59:6969/announce天津联通…...

2026年03月21日最热门的开源项目(Github)

根据本期榜单的数据分析,可以提取出以下几个关键点: 1. 项目种类与趋势 语言分布: 此榜单中的项目主要采用 JavaScript、TypeScript 和 Python 等语言,显示了这些编程语言在人工智能及相关技术领域的广泛应用。项目类型: 许多项目都集中在人…...

Comsol 模拟电击穿与电树枝现象

comsol 电击穿,电树枝,通过消耗复合材料静电能,形成随机电击穿通道,可根据SEM 照片制定不同的击穿路径,同时考虑晶粒与晶界不同的击穿场强,由于晶界的阻挡作用,击穿强度增加。 晶界面设置不同的…...

基于MATLAB的单相双极性SPWM逆变电路系统设计:探索SVPWM的独特魅力

基于MATLAB的单相双极性SPWM逆变电路系统设计 本设计包括设计报告,仿真程序。 系统优势 通过对比方波逆变器和正弦波逆变器,阐述了SVPWM逆变器在改善输出波形质量方面的优势如下: (1)谐波抑制: 方波逆变器的…...

【手把手教程】阿里云OpenClaw一键部署指南,两步解锁龙虾AI助理!

2026年,开源AI智能体OpenClaw(昵称“龙虾AI”)凭借其“能动手做事”的颠覆性能力,迅速成为技术圈与普通用户热议的焦点。这款以红色龙虾为图标的AI工具,不仅支持文件管理、浏览器自动化、代码编写等本地化操作&#xf…...

3DSlicer实战:从零开始完成冠脉精准分割

1. 为什么选择3DSlicer进行冠脉分割 第一次接触医学影像分析的朋友可能会问:市面上这么多专业软件,为什么偏偏推荐3DSlicer?我刚开始做心脏CT分析时也纠结过这个问题,实测对比过多个工具后,发现3DSlicer有三大不可替代…...