0206-生成最终图像
环境
- Time 2022-11-17
- WSL-Ubuntu 22.04
- Rust 1.65.0
前言
说明
参考:https://raytracing.github.io/books/RayTracingInOneWeekend.html
目标
将之前的所有的内容合并在一起生成一个最终的图像。
vector3.rs
pub fn random(range: Range<f64>) -> Vector3 {
let mut rng = rand::thread_rng();
Vector3 {
x: rng.gen_range(range.clone()),
y: rng.gen_range(range.clone()),
z: rng.gen_range(range),
}
}
生成场景
fn random_scene() -> World {
let mut rng = rand::thread_rng();
let mut world = World::new();
let ground = Rc::new(Lambert::new(Color::new(0.5, 0.5, 0.5)));
let ground = Sphere::new(Point3::new(0.0, -1000.0, 0.0), 1000.0, ground);
world.push(Box::new(ground));
for a in -11..=11 {
for b in -11..=11 {
let choose_mat: f64 = rng.gen();
let center = Point3::new(
(a as f64) + rng.gen_range(0.0..0.9),
0.2,
(b as f64) + rng.gen_range(0.0..0.9),
);
if choose_mat < 0.8 {
let albedo = Color::random(0.0..1.0) * Color::random(0.0..1.0);
let sphere_mat = Rc::new(Lambert::new(albedo));
let sphere = Sphere::new(center, 0.2, sphere_mat);
world.push(Box::new(sphere));
} else if choose_mat < 0.95 {
let albedo = Color::random(0.4..1.0);
let fuzz = rng.gen_range(0.0..0.5);
let sphere_mat = Rc::new(Metal::new(albedo, fuzz));
let sphere = Sphere::new(center, 0.2, sphere_mat);
world.push(Box::new(sphere));
} else {
// Glass
let sphere_mat = Rc::new(Dielectric::new(1.5));
let sphere = Sphere::new(center, 0.2, sphere_mat);
world.push(Box::new(sphere));
}
}
}
let mat1 = Rc::new(Dielectric::new(1.5));
let mat2 = Rc::new(Lambert::new(Color::new(0.4, 0.2, 0.1)));
let mat3 = Rc::new(Metal::new(Color::new(0.7, 0.6, 0.5), 0.0));
let sphere1 = Sphere::new(Point3::new(0.0, 1.0, 0.0), 1.0, mat1);
let sphere2 = Sphere::new(Point3::new(-4.0, 1.0, 0.0), 1.0, mat2);
let sphere3 = Sphere::new(Point3::new(4.0, 1.0, 0.0), 1.0, mat3);
world.push(Box::new(sphere1));
world.push(Box::new(sphere2));
world.push(Box::new(sphere3));
world
}
相机和图像
const RATIO: f64 = 3.0 / 2.0;
const WIDTH: u64 = 1200;
const HEIGHT: u64 = ((WIDTH as f64) / RATIO) as u64;
const SAMPLES_PER_PIXEL: u64 = 500;
const MAX_DEPTH: u64 = 50;
let world = random_scene();
let camera = Camera::new(
Point3::new(13.0, 2.0, 3.0),
Point3::new(0.0, 0.0, 0.0),
Vector3::new(0.0, 1.0, 0.0),
20.0,
RATIO,
0.1,
10.0,
);
效果
总结
生成了最终的图像。在做的过程中,很多的公式和原理弄不清楚。
只能跟着流程往下走,其余的没有弄懂,图形学还是太难了。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探
2020-07-22 【JavaScript】对象构建实践