more file loading work

This commit is contained in:
Evan Pratten 2021-09-30 11:35:10 -04:00
parent a2ca2b6827
commit fd7a08dbee
7 changed files with 33 additions and 22 deletions

View File

@ -3,6 +3,5 @@
"clippy",
"raylib",
"renderable"
],
"rust-analyzer.checkOnSave.command": "clippy"
]
}

12
.vscode/tasks.json vendored
View File

@ -10,6 +10,18 @@
"group": "build",
"label": "Rust: Build Code"
},
{
"type": "cargo",
"command": "clippy",
"args": [
"--fix"
],
"problemMatcher": [
"$rustc"
],
"group": "build",
"label": "Rust: Clippy Fix"
},
{
"type": "cargo",
"command": "run",

View File

@ -153,7 +153,7 @@ pub async fn game_begin(game_config: &GameConfig) -> Result<(), Box<dyn std::err
// Get the main state machine
info!("Setting up the scene management state machine");
let mut game_state_machine =
build_screen_state_machine(&context.renderer.borrow_mut(), &raylib_thread).unwrap();
build_screen_state_machine(&mut context.renderer.borrow_mut(), &raylib_thread).unwrap();
game_state_machine
.force_change_state(Scenes::LoadingScreen)
.unwrap();

View File

@ -1,11 +1,8 @@
use chrono::{DateTime, Utc};
use dirty_fsm::{Action, ActionFlag};
use raylib::RaylibThread;
use raylib::{RaylibThread, texture::Texture2D};
use crate::{
context::GameContext,
utilities::{non_ref_raylib::HackedRaylibHandle, render_layer::ScreenSpaceRender},
};
use crate::{context::GameContext, utilities::{datastore::{ResourceLoadError, load_texture_from_internal_data}, non_ref_raylib::HackedRaylibHandle, render_layer::ScreenSpaceRender}};
use super::{Scenes, ScreenError};
use tracing::{debug, info, trace};
@ -16,20 +13,20 @@ const LOADING_SCREEN_DURATION_SECONDS: u8 = 3;
#[derive(Debug)]
pub struct LoadingScreen {
start_timestamp: Option<DateTime<Utc>>,
game_logo_texture: Texture2D
}
impl LoadingScreen {
/// Construct a new `LoadingScreen`
pub fn new(raylib_handle: &HackedRaylibHandle, thread: &RaylibThread) -> Self {
pub fn new(raylib_handle: &mut HackedRaylibHandle, thread: &RaylibThread) -> Result<Self, ResourceLoadError> {
// Load the game logo asset
// TODO: in-memory texture loading
// raylib_handle.load_texture_from_image(, image)
let game_logo = load_texture_from_internal_data(raylib_handle, thread, "logos/game-logo.png")?;
Self {
Ok(Self {
start_timestamp: None,
}
game_logo_texture: game_logo
})
}
}

View File

@ -1,6 +1,6 @@
use dirty_fsm::StateMachine;
use raylib::RaylibThread;
use crate::{context::GameContext, utilities::non_ref_raylib::HackedRaylibHandle};
use crate::{context::GameContext, utilities::{datastore::ResourceLoadError, non_ref_raylib::HackedRaylibHandle}};
use self::{fsm_error_screen::FsmErrorScreen, loading_screen::LoadingScreen};
pub mod fsm_error_screen;
@ -16,16 +16,19 @@ pub enum Scenes {
/// Contains any possible errors thrown while rendering
#[derive(Debug, Error)]
pub enum ScreenError {}
pub enum ScreenError {
#[error(transparent)]
ResourceLoad(#[from] ResourceLoadError)
}
/// Build the state machine for all scenes
pub fn build_screen_state_machine(raylib_handle: &HackedRaylibHandle, thread: &RaylibThread) -> Result<
pub fn build_screen_state_machine(raylib_handle: &mut HackedRaylibHandle, thread: &RaylibThread) -> Result<
// StateMachine<Scenes, ScreenError, RefCell<(NonRefDrawHandle, Rc<RefCell<GameContext>>)>>,
StateMachine<Scenes, ScreenError, GameContext>,
ScreenError,
> {
let mut machine = StateMachine::new();
machine.add_action(Scenes::FsmErrorScreen, FsmErrorScreen::new())?;
machine.add_action(Scenes::LoadingScreen, LoadingScreen::new(raylib_handle, thread))?;
machine.add_action(Scenes::LoadingScreen, LoadingScreen::new(raylib_handle, thread)?)?;
Ok(machine)
}

View File

@ -22,7 +22,7 @@ pub enum ResourceLoadError {
}
pub fn load_texture_from_internal_data(
raylib_handle: &RaylibHandle,
raylib_handle: &mut RaylibHandle,
thread: &RaylibThread,
path: &str,
) -> Result<Texture2D, ResourceLoadError> {
@ -31,14 +31,14 @@ pub fn load_texture_from_internal_data(
// Unpack the raw image data to a real file on the local filesystem so raylib will read it correctly
std::fs::write(
tmp_path,
&tmp_path,
&StaticGameData::get(path)
.ok_or(ResourceLoadError::AssetNotFound(path.to_string()))?
.data,
)?;
// Call through via FFI to re-load the file
let texture = raylib_handle.load_texture(thread, tmp_path.to_str().unwrap()).map_err(|e| ResourceLoadError::Generic(e));
let texture = raylib_handle.load_texture(thread, tmp_path.to_str().unwrap()).map_err(|e| ResourceLoadError::Generic(e))?;
// Close the file
tmp_path.close()?;

View File

@ -8,4 +8,4 @@
# Make sure to check the build status before changing this
# https://rust-lang.github.io/rustup-components-history/
channel = "nightly-2021-09-30"
components = ["clippy", "rustfmt"]
# components = ["clippy", "rustfmt"]