|
14 | 14 |
|
15 | 15 | use lambda::{ |
16 | 16 | component::Component, |
| 17 | + events::{ |
| 18 | + EventMask, |
| 19 | + Key, |
| 20 | + VirtualKey, |
| 21 | + WindowEvent, |
| 22 | + }, |
17 | 23 | logging, |
18 | 24 | math::matrix::Matrix, |
19 | 25 | render::{ |
@@ -203,77 +209,73 @@ impl Component<ComponentResult, String> for ReflectiveRoomExample { |
203 | 209 | return Ok(ComponentResult::Success); |
204 | 210 | } |
205 | 211 |
|
206 | | - fn on_event( |
207 | | - &mut self, |
208 | | - event: lambda::events::Events, |
209 | | - ) -> Result<ComponentResult, String> { |
| 212 | + fn event_mask(&self) -> EventMask { |
| 213 | + return EventMask::WINDOW | EventMask::KEYBOARD; |
| 214 | + } |
| 215 | + |
| 216 | + fn on_window_event(&mut self, event: &WindowEvent) -> Result<(), String> { |
| 217 | + match event { |
| 218 | + WindowEvent::Resize { width, height } => { |
| 219 | + self.width = *width; |
| 220 | + self.height = *height; |
| 221 | + } |
| 222 | + _ => {} |
| 223 | + } |
| 224 | + return Ok(()); |
| 225 | + } |
| 226 | + |
| 227 | + fn on_keyboard_event(&mut self, event: &Key) -> Result<(), String> { |
210 | 228 | match event { |
211 | | - lambda::events::Events::Window { event, .. } => match event { |
212 | | - lambda::events::WindowEvent::Resize { width, height } => { |
213 | | - self.width = width; |
214 | | - self.height = height; |
| 229 | + Key::Pressed { |
| 230 | + scan_code: _, |
| 231 | + virtual_key, |
| 232 | + } => match virtual_key { |
| 233 | + Some(VirtualKey::KeyM) => { |
| 234 | + self.msaa_samples = if self.msaa_samples > 1 { 1 } else { 4 }; |
| 235 | + self.needs_rebuild = true; |
| 236 | + logging::info!("Toggled MSAA → {}x (key: M)", self.msaa_samples); |
| 237 | + } |
| 238 | + Some(VirtualKey::KeyS) => { |
| 239 | + self.stencil_enabled = !self.stencil_enabled; |
| 240 | + self.needs_rebuild = true; |
| 241 | + logging::info!("Toggled Stencil → {} (key: S)", self.stencil_enabled); |
| 242 | + } |
| 243 | + Some(VirtualKey::KeyD) => { |
| 244 | + self.depth_test_enabled = !self.depth_test_enabled; |
| 245 | + self.needs_rebuild = true; |
| 246 | + logging::info!( |
| 247 | + "Toggled Depth Test → {} (key: D)", |
| 248 | + self.depth_test_enabled |
| 249 | + ); |
| 250 | + } |
| 251 | + Some(VirtualKey::KeyF) => { |
| 252 | + self.mirror_mode = !self.mirror_mode; |
| 253 | + logging::info!( |
| 254 | + "Toggled Mirror Mode (hide floor overlay) → {} (key: F)", |
| 255 | + self.mirror_mode |
| 256 | + ); |
| 257 | + } |
| 258 | + Some(VirtualKey::KeyI) => { |
| 259 | + self.camera_pitch_turns = |
| 260 | + (self.camera_pitch_turns - 0.01).clamp(0.0, 0.25); |
| 261 | + logging::info!( |
| 262 | + "Camera pitch (turns) → {:.3}", |
| 263 | + self.camera_pitch_turns |
| 264 | + ); |
| 265 | + } |
| 266 | + Some(VirtualKey::KeyK) => { |
| 267 | + self.camera_pitch_turns = |
| 268 | + (self.camera_pitch_turns + 0.01).clamp(0.0, 0.25); |
| 269 | + logging::info!( |
| 270 | + "Camera pitch (turns) → {:.3}", |
| 271 | + self.camera_pitch_turns |
| 272 | + ); |
215 | 273 | } |
216 | | - _ => {} |
217 | | - }, |
218 | | - lambda::events::Events::Keyboard { event, .. } => match event { |
219 | | - lambda::events::Key::Pressed { |
220 | | - scan_code: _, |
221 | | - virtual_key, |
222 | | - } => match virtual_key { |
223 | | - Some(lambda::events::VirtualKey::KeyM) => { |
224 | | - self.msaa_samples = if self.msaa_samples > 1 { 1 } else { 4 }; |
225 | | - self.needs_rebuild = true; |
226 | | - logging::info!("Toggled MSAA → {}x (key: M)", self.msaa_samples); |
227 | | - } |
228 | | - Some(lambda::events::VirtualKey::KeyS) => { |
229 | | - self.stencil_enabled = !self.stencil_enabled; |
230 | | - self.needs_rebuild = true; |
231 | | - logging::info!( |
232 | | - "Toggled Stencil → {} (key: S)", |
233 | | - self.stencil_enabled |
234 | | - ); |
235 | | - } |
236 | | - Some(lambda::events::VirtualKey::KeyD) => { |
237 | | - self.depth_test_enabled = !self.depth_test_enabled; |
238 | | - self.needs_rebuild = true; |
239 | | - logging::info!( |
240 | | - "Toggled Depth Test → {} (key: D)", |
241 | | - self.depth_test_enabled |
242 | | - ); |
243 | | - } |
244 | | - Some(lambda::events::VirtualKey::KeyF) => { |
245 | | - self.mirror_mode = !self.mirror_mode; |
246 | | - logging::info!( |
247 | | - "Toggled Mirror Mode (hide floor overlay) → {} (key: F)", |
248 | | - self.mirror_mode |
249 | | - ); |
250 | | - } |
251 | | - // 'R' previously forced an unmasked reflection; now disabled. |
252 | | - Some(lambda::events::VirtualKey::KeyI) => { |
253 | | - // Pitch camera up (reduce downward angle) |
254 | | - self.camera_pitch_turns = |
255 | | - (self.camera_pitch_turns - 0.01).clamp(0.0, 0.25); |
256 | | - logging::info!( |
257 | | - "Camera pitch (turns) → {:.3}", |
258 | | - self.camera_pitch_turns |
259 | | - ); |
260 | | - } |
261 | | - Some(lambda::events::VirtualKey::KeyK) => { |
262 | | - // Pitch camera down (increase downward angle) |
263 | | - self.camera_pitch_turns = |
264 | | - (self.camera_pitch_turns + 0.01).clamp(0.0, 0.25); |
265 | | - logging::info!( |
266 | | - "Camera pitch (turns) → {:.3}", |
267 | | - self.camera_pitch_turns |
268 | | - ); |
269 | | - } |
270 | | - _ => {} |
271 | | - }, |
272 | 274 | _ => {} |
273 | 275 | }, |
274 | 276 | _ => {} |
275 | 277 | } |
276 | | - return Ok(ComponentResult::Success); |
| 278 | + return Ok(()); |
277 | 279 | } |
278 | 280 |
|
279 | 281 | fn on_update( |
|
0 commit comments