Merge pull request #26 from Ewpratten/darkness

Make the world dark, using an image now!
This commit is contained in:
Evan Pratten 2021-04-25 09:34:27 -04:00 committed by GitHub
commit 43c60c6dfc
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 38 additions and 17 deletions

BIN
assets/img/map/darkness.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 50 KiB

View File

@ -32,7 +32,7 @@ pub struct Flashlight {
impl Flashlight { impl Flashlight {
pub fn lvl1() -> Self { pub fn lvl1() -> Self {
Self { Self {
radius: 120.0 radius: 0.25
} }
} }
} }

View File

@ -104,27 +104,41 @@ impl InGameScreen {
// Get the window center // Get the window center
let win_height = draw_handle.get_screen_height(); let win_height = draw_handle.get_screen_height();
let win_width = draw_handle.get_screen_width(); let win_width = draw_handle.get_screen_width();
let window_center = Vector2 {
x: (win_width as f32 / 2.0),
y: (win_height as f32 / 2.0),
};
// Calculate the occusion radius based on depth // Calculate the occusion radius based on depth
let radius = (win_width as f32 let radius = (1.0
* (1.0 - (game_core.player.calculate_depth_percent(&game_core.world) * 1.3).clamp(0.0, 1.0))
- (game_core.player.calculate_depth_percent(&game_core.world) * 1.3)
.clamp(0.0, 1.0)))
.max(min_radius); .max(min_radius);
// Determine width and height scales
// This is clamped to make the rendering logic below easier by removing the need to overdraw
let width_scale = (5.0 * radius).max(0.5);
let height_scale = (5.0 * radius).max(0.5);
// Get the base sizes of everything
let texture_width = game_core.resources.darkness_overlay.width as f32;
let texture_height = game_core.resources.darkness_overlay.height as f32;
let texture_width_scaled = texture_width * width_scale;
let texture_height_scaled = texture_height * height_scale;
// Render the overlay // Render the overlay
draw_handle.draw_ring( draw_handle.draw_texture_pro(
window_center, &game_core.resources.darkness_overlay,
radius, Rectangle {
win_width as f32, x: 0.0,
0, y: 0.0,
360, width: texture_width,
128, height: texture_height,
Color::BLACK, },
Rectangle {
x: (win_width as f32 - texture_width_scaled) / 2.0,
y: (win_height as f32 - texture_height_scaled) / 2.0,
width: texture_width_scaled,
height: texture_height_scaled,
},
Vector2 { x: 0.0, y: 0.0 },
0.0,
Color::WHITE,
); );
} }
} }

View File

@ -24,6 +24,9 @@ pub struct GlobalResources {
// Enemies // Enemies
pub jellyfish_animation_regular: FrameAnimationWrapper, pub jellyfish_animation_regular: FrameAnimationWrapper,
pub jellyfish_animation_attack: FrameAnimationWrapper, pub jellyfish_animation_attack: FrameAnimationWrapper,
// Darkness layer
pub darkness_overlay: Texture2D
} }
impl GlobalResources { impl GlobalResources {
@ -95,6 +98,10 @@ impl GlobalResources {
15, 15,
4, 4,
), ),
darkness_overlay: raylib.load_texture_from_image(
&thread,
&Image::load_image("./assets/img/map/darkness.png")?,
)?,
}) })
} }
} }