Compare commits
2 Commits
d8ad450553
...
71985a6c34
| Author | SHA1 | Date | |
|---|---|---|---|
| 71985a6c34 | |||
| b4b214ebf7 |
@@ -6,27 +6,28 @@
|
|||||||
"camera": {
|
"camera": {
|
||||||
"anti_alias_rate": 2,
|
"anti_alias_rate": 2,
|
||||||
"fov": 50.0,
|
"fov": 50.0,
|
||||||
"look_from": [-2, 4, 5],
|
"look_from": [-3, 4, 10],
|
||||||
"look_at": [-2, 0.0, 0.0],
|
"look_at": [-3, 0.0, -10.0],
|
||||||
"vup": [0.0, 1.0, 0.0], "defocus_angle": 0, "focus_dist": 15.68
|
"vup": [0.0, 1.0, 0.0],
|
||||||
|
"defocus_angle": 0,
|
||||||
|
"focus_dist": 15.68
|
||||||
},
|
},
|
||||||
"materials": [
|
"materials": [
|
||||||
{ "type": "lambertian", "albedo": [0.2, 0.2, 0.2], "prob": 0.8 },
|
{ "type": "lambertian", "albedo": [0.2, 0.2, 0.2], "prob": 0.8 },
|
||||||
{ "type": "lambertian", "albedo": [0.9, 0.9, 0.0], "prob": 1.0, "fuzz": 0.1 },
|
|
||||||
{ "type": "dielectric", "refraction_index": 1.5},
|
|
||||||
{ "type": "normal"},
|
|
||||||
{"type": "texture", "source": "./textures/earthmap1k.png"},
|
{"type": "texture", "source": "./textures/earthmap1k.png"},
|
||||||
{"type": "texture", "source": "./textures/yellow.png"}
|
{"type": "texture", "source": "./textures/bluegrid.png"}
|
||||||
],
|
],
|
||||||
"objects": [
|
"objects": [
|
||||||
{ "type": "sphere", "center": [0.0, 0.0, -1.2], "radius": 0.9, "material": 5},
|
{ "type": "sphere", "center": [0.0, 0.0, -1.2], "radius": 0.9, "material": 2},
|
||||||
{ "type": "sphere", "center": [-2, 0, -1], "radius": 0.8, "material": 4},
|
{ "type": "sphere", "center": [-2, 0, -1], "radius": 0.8, "material": 1},
|
||||||
{ "type": "triangle", "p1": [0, 0, -4], "p2": [4, 0, -4], "p3": [2, 2, -4], "material": 5},
|
{ "type": "triangle", "p1": [0, 0, -4], "p2": [4, 0, -4], "p3": [2, 2, -4], "material": 2},
|
||||||
{ "type": "triangle", "p1": [-2, 2, -4], "p2": [2, 2, -4], "p3": [0, 4, -4], "material": 4},
|
{ "type": "triangle", "p1": [-2, 2, -4], "p2": [2, 2, -4], "p3": [0, 4, -4], "material": 1},
|
||||||
{ "type": "quad", "p1": [-20, -1, -20], "p2": [20, -1, -20], "p3": [20, 20, -20], "p4": [-20, 20, -20], "material": 0},
|
{ "type": "quad", "p1": [-20, -1, -20], "p2": [20, -1, -20], "p3": [20, 20, -20], "p4": [-20, 20, -20], "material": 0},
|
||||||
{ "type": "quad", "p1": [-20, -1, 20], "p2": [-20, -1, -20], "p3": [-20, 20, -20], "p4": [-20, 20, 20], "material": 0},
|
{ "type": "quad", "p1": [-20, -1, 20], "p2": [-20, -1, -20], "p3": [-20, 20, -20], "p4": [-20, 20, 20], "material": 0},
|
||||||
{ "type": "quad", "p1": [-20, -1, 20], "p2": [20, -1, 20], "p3": [20, -1, -20], "p4": [-20, -1, -20], "material": 0},
|
{ "type": "quad", "p1": [-20, -1, 20], "p2": [20, -1, 20], "p3": [20, -1, -20], "p4": [-20, -1, -20], "material": 0},
|
||||||
{ "type": "quad", "p1": [20, -1, 20], "p2": [20, -1, -20], "p3": [20, 20, -20], "p4": [20, 20, 20], "material": 0}
|
{ "type": "quad", "p1": [20, -1, 20], "p2": [20, -1, -20], "p3": [20, 20, -20], "p4": [20, 20, 20], "material": 0},
|
||||||
|
{ "type": "quad", "p1": [-4, 3, -4], "p2": [-1, 3, -4], "p3": [-1, 6, -4], "p4": [-4, 6, -4], "material": 1},
|
||||||
|
{ "type": "quad", "p1": [-8, 3, -4], "p2": [-5, 3, -4], "p3": [-5, 6, -4], "p4": [-8, 6, -4], "material": 2}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
use image::{DynamicImage, ImageReader};
|
use image::{DynamicImage, ImageReader};
|
||||||
use log::info;
|
use log::trace;
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
objects::{hit::Hit, materials::traits::Material},
|
objects::{hit::Hit, materials::traits::Material},
|
||||||
@@ -18,8 +18,15 @@ pub struct Texture {
|
|||||||
impl Texture {
|
impl Texture {
|
||||||
pub fn new(texture: &str) -> Self {
|
pub fn new(texture: &str) -> Self {
|
||||||
let img = ImageReader::open(texture).unwrap().decode().unwrap(); // FIXME: unwraps
|
let img = ImageReader::open(texture).unwrap().decode().unwrap(); // FIXME: unwraps
|
||||||
info!("{} * {} = {} bytes", img.width(), img.height(), img.as_bytes().len());
|
trace!(
|
||||||
let stride = match img.color() { // TODO: support other types of image
|
"texture '{}' is {} by {} pixels, with {} bytes total",
|
||||||
|
texture,
|
||||||
|
img.width(),
|
||||||
|
img.height(),
|
||||||
|
img.as_bytes().len()
|
||||||
|
);
|
||||||
|
let stride = match img.color() {
|
||||||
|
// TODO: support other types of image
|
||||||
image::ColorType::L8 => todo!(),
|
image::ColorType::L8 => todo!(),
|
||||||
image::ColorType::La8 => todo!(),
|
image::ColorType::La8 => todo!(),
|
||||||
image::ColorType::Rgb8 => 3,
|
image::ColorType::Rgb8 => 3,
|
||||||
@@ -48,10 +55,14 @@ impl Texture {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn _at(&self, u: f32, v: f32) -> Vec3 {
|
fn _at(&self, u: f32, v: f32) -> Vec3 {
|
||||||
let b = self.source.as_bytes();
|
let b = self.source.as_bytes();
|
||||||
let idx = self._idx(u, v);
|
let idx = self._idx(u, v);
|
||||||
|
|
||||||
Vec3::from_u8(b[self.stride * idx], b[self.stride * idx + 2], b[self.stride * idx + 1])
|
Vec3::from_u8(
|
||||||
|
b[self.stride * idx],
|
||||||
|
b[self.stride * idx + 2],
|
||||||
|
b[self.stride * idx + 1],
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -57,9 +57,10 @@ impl Debug for Quad {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// FIXME: texture mapping does not work properly for quads
|
||||||
impl Hittable for Quad {
|
impl Hittable for Quad {
|
||||||
fn hit(&self, r: &Ray) -> Option<Hit> {
|
fn hit(&self, r: &Ray) -> Option<Hit> {
|
||||||
Quad::hit(
|
let hit = Quad::hit(
|
||||||
self.p1,
|
self.p1,
|
||||||
self.p2,
|
self.p2,
|
||||||
self.p3,
|
self.p3,
|
||||||
@@ -67,7 +68,9 @@ impl Hittable for Quad {
|
|||||||
self.material.clone(),
|
self.material.clone(),
|
||||||
self.normal,
|
self.normal,
|
||||||
r,
|
r,
|
||||||
)
|
);
|
||||||
|
|
||||||
|
return hit
|
||||||
}
|
}
|
||||||
|
|
||||||
fn to_uv(&self, point: &Vec3) -> Vec3 {
|
fn to_uv(&self, point: &Vec3) -> Vec3 {
|
||||||
|
|||||||
Reference in New Issue
Block a user