1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
use std::sync::Arc;
use crate::core::geometry::{Point2f, Vector2f};
use crate::core::interaction::SurfaceInteraction;
use crate::core::texture::{Texture, TextureMapping2D};
pub struct Checkerboard2DTexture<T> {
pub tex1: Arc<dyn Texture<T> + Send + Sync>,
pub tex2: Arc<dyn Texture<T> + Send + Sync>,
pub mapping: Box<TextureMapping2D>,
}
impl<T: Copy> Checkerboard2DTexture<T> {
pub fn new(
mapping: Box<TextureMapping2D>,
tex1: Arc<dyn Texture<T> + Send + Sync>,
tex2: Arc<dyn Texture<T> + Send + Sync>,
) -> Self {
Checkerboard2DTexture {
tex1,
tex2,
mapping,
}
}
}
impl<T: Copy> Texture<T> for Checkerboard2DTexture<T> {
fn evaluate(&self, si: &SurfaceInteraction) -> T {
let mut dstdx: Vector2f = Vector2f::default();
let mut dstdy: Vector2f = Vector2f::default();
let st: Point2f = self.mapping.map(si, &mut dstdx, &mut dstdy);
if (st.x.floor() as u32 + st.y.floor() as u32) % 2 == 0 {
self.tex1.evaluate(si)
} else {
self.tex2.evaluate(si)
}
}
}