]> git.localhorst.tv Git - blank.git/blobdiff - src/app/WorldState.cpp
avoid library rand()
[blank.git] / src / app / WorldState.cpp
index b686ab28b058f14608e67b1ee58ef0d9ec587ad4..243b0a1dc519d42ba18d1e6350e60864896480ba 100644 (file)
@@ -1,6 +1,7 @@
 #include "WorldState.hpp"
 
 #include "Environment.hpp"
+#include "TextureIndex.hpp"
 
 #include <SDL.h>
 
@@ -10,13 +11,28 @@ namespace blank {
 WorldState::WorldState(
        Environment &env,
        const Interface::Config &ic,
-       const World::Config &wc
+       const World::Config &wc,
+       const WorldSave &save
 )
 : env(env)
-, world(env.assets, wc)
-, spawner(world)
-, interface(ic, env, world) {
+, block_types()
+, world(block_types, wc, save)
+, chunk_renderer(world, wc.load.load_dist)
+, spawner(world, wc.gen.seed)
+, interface(ic, env, world)
+, preload(env, world.Loader(), chunk_renderer)
+, unload(env, world.Loader()) {
+       TextureIndex tex_index;
+       env.assets.LoadBlockTypes("default", block_types, tex_index);
+       chunk_renderer.LoadTextures(env.assets, tex_index);
+       chunk_renderer.FogDensity(wc.fog_density);
+       // TODO: better solution for initializing HUD
+       interface.SelectNext();
+}
+
 
+void WorldState::OnEnter() {
+       env.state.Push(&preload);
 }
 
 
@@ -40,6 +56,9 @@ void WorldState::Handle(const SDL_Event &event) {
                case SDL_MOUSEWHEEL:
                        interface.Handle(event.wheel);
                        break;
+               case SDL_QUIT:
+                       env.state.Switch(&unload);
+                       break;
                default:
                        break;
        }
@@ -49,8 +68,10 @@ void WorldState::Update(int dt) {
        interface.Update(dt);
        spawner.Update(dt);
        world.Update(dt);
+       chunk_renderer.Rebase(world.Player().ChunkCoords());
+       chunk_renderer.Update(dt);
 
-       glm::mat4 trans = world.Player().Transform(Chunk::Pos(0, 0, 0));
+       glm::mat4 trans = world.Player().Transform(world.Player().ChunkCoords());
        glm::vec3 dir(trans * glm::vec4(0.0f, 0.0f, -1.0f, 0.0f));
        glm::vec3 up(trans * glm::vec4(0.0f, 1.0f, 0.0f, 0.0f));
        env.audio.Position(world.Player().Position());
@@ -60,6 +81,8 @@ void WorldState::Update(int dt) {
 }
 
 void WorldState::Render(Viewport &viewport) {
+       viewport.WorldPosition(world.Player().Transform(world.Player().ChunkCoords()));
+       chunk_renderer.Render(viewport);
        world.Render(viewport);
        interface.Render(viewport);
 }