💿🐜 Antkeeper source code https://antkeeper.com
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

131 lines
4.8 KiB

  1. /*
  2. * Copyright (C) 2021 Christopher J. Howard
  3. *
  4. * This file is part of Antkeeper source code.
  5. *
  6. * Antkeeper source code is free software: you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation, either version 3 of the License, or
  9. * (at your option) any later version.
  10. *
  11. * Antkeeper source code is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with Antkeeper source code. If not, see <http://www.gnu.org/licenses/>.
  18. */
  19. #include "game/states/nuptial-flight.hpp"
  20. #include "entity/archetype.hpp"
  21. #include "entity/systems/astronomy.hpp"
  22. #include "entity/systems/orbit.hpp"
  23. #include "entity/systems/control.hpp"
  24. #include "entity/systems/camera.hpp"
  25. #include "entity/components/observer.hpp"
  26. #include "entity/components/camera-follow.hpp"
  27. #include "entity/components/transform.hpp"
  28. #include "entity/components/terrain.hpp"
  29. #include "renderer/material-property.hpp"
  30. #include "animation/screen-transition.hpp"
  31. #include "animation/ease.hpp"
  32. #include "resources/config-file.hpp"
  33. #include "resources/resource-manager.hpp"
  34. namespace game {
  35. namespace state {
  36. namespace nuptial_flight {
  37. void enter(game::context* ctx)
  38. {
  39. // Switch to surface camera
  40. ctx->underground_camera->set_active(false);
  41. ctx->surface_camera->set_active(true);
  42. // Find planet EID by name
  43. entity::id planet_eid = entt::null;
  44. if (auto it = ctx->named_entities.find("planet"); it != ctx->named_entities.end())
  45. {
  46. planet_eid = it->second;
  47. }
  48. // Remove terrain component from planet (if any)
  49. if (ctx->entity_registry->has<entity::component::terrain>(planet_eid))
  50. ctx->entity_registry->remove<entity::component::terrain>(planet_eid);
  51. // Enable clouds in sky pass
  52. ctx->surface_sky_pass->set_clouds_model(ctx->resource_manager->load<model>("cloud-plane.mdl"));
  53. // Create observer
  54. auto observer_eid = ctx->entity_registry->create();
  55. {
  56. entity::component::observer observer;
  57. observer.reference_body_eid = planet_eid;
  58. observer.elevation = 2000.0;
  59. observer.latitude = 0.0;
  60. observer.longitude = 0.0;
  61. observer.camera = ctx->surface_camera;
  62. ctx->entity_registry->assign<entity::component::observer>(observer_eid, observer);
  63. // Set reference location of astronomy system
  64. ctx->astronomy_system->set_reference_body(planet_eid);
  65. ctx->astronomy_system->set_observer_location(double3{observer.elevation, observer.latitude, observer.longitude});
  66. }
  67. // Create wing
  68. entity::archetype* ant_forewing_archetype = ctx->resource_manager->load<entity::archetype>("ant-forewing.ent");
  69. auto forewing_eid = ctx->entity_registry->create();
  70. //ant_forewing_archetype->assign(*ctx->entity_registry, forewing_eid);
  71. // Create eye
  72. entity::archetype* ant_round_eye_archetype = ctx->resource_manager->load<entity::archetype>("ant-round-eye.ent");
  73. auto ant_round_eye_eid = ctx->entity_registry->create();
  74. ant_round_eye_archetype->assign(*ctx->entity_registry, ant_round_eye_eid);
  75. // Create green orb ring
  76. entity::archetype* orb_ring_archetype = ctx->resource_manager->load<entity::archetype>("orb-ring.ent");
  77. auto orb_ring_eid = ctx->entity_registry->create();
  78. //orb_ring_archetype->assign(*ctx->entity_registry, orb_ring_eid);
  79. // Create camera focal point
  80. {
  81. entity::component::transform focal_point_transform;
  82. focal_point_transform.local = math::identity_transform<float>;
  83. focal_point_transform.warp = true;
  84. ctx->entity_registry->assign_or_replace<entity::component::transform>(ctx->focal_point_entity, focal_point_transform);
  85. entity::component::camera_follow focal_point_follow;
  86. ctx->entity_registry->assign_or_replace<entity::component::camera_follow>(ctx->focal_point_entity, focal_point_follow);
  87. }
  88. // Setup camera
  89. ctx->surface_camera->look_at({0, 0, 1}, {0, 0, 0}, {0, 1, 0});
  90. ctx->surface_camera->set_exposure(-14.5f);
  91. ctx->camera_system->set_camera(ctx->surface_camera);
  92. entity::system::control* control_system = ctx->control_system;
  93. control_system->update(0.0, 0.0);
  94. ctx->surface_scene->update_tweens();
  95. // Pause motion of celestial objects
  96. ctx->astronomy_system->set_time_scale(0.0);
  97. ctx->orbit_system->set_time_scale(0.0);
  98. // Start fade in from white
  99. ctx->fade_transition_color->set_value({1, 1, 1});
  100. ctx->fade_transition->transition(2.0f, true, ease<float>::in_quad);
  101. }
  102. void exit(game::context* ctx)
  103. {
  104. // Resume motion of celestial objects
  105. const double time_scale = ctx->config->get<double>("time_scale");
  106. ctx->astronomy_system->set_time_scale(time_scale);
  107. ctx->orbit_system->set_time_scale(time_scale);
  108. }
  109. } // namespace nuptial_flight
  110. } // namespace state
  111. } // namespace game