💿🐜 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.

142 lines
4.7 KiB

3 years ago
3 years ago
3 years ago
  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. #ifndef ANTKEEPER_SKY_PASS_HPP
  20. #define ANTKEEPER_SKY_PASS_HPP
  21. #include "renderer/render-pass.hpp"
  22. #include "utility/fundamental-types.hpp"
  23. #include "event/event-handler.hpp"
  24. #include "event/input-events.hpp"
  25. #include "animation/tween.hpp"
  26. #include "math/quaternion-type.hpp"
  27. #include "gl/shader-program.hpp"
  28. #include "gl/shader-input.hpp"
  29. #include "gl/vertex-buffer.hpp"
  30. #include "gl/vertex-array.hpp"
  31. #include "gl/texture-2d.hpp"
  32. #include "gl/drawing-mode.hpp"
  33. #include "physics/frame.hpp"
  34. #include "scene/object.hpp"
  35. class resource_manager;
  36. class model;
  37. class material;
  38. /**
  39. *
  40. */
  41. class sky_pass: public render_pass,
  42. public event_handler<mouse_moved_event>
  43. {
  44. public:
  45. sky_pass(gl::rasterizer* rasterizer, const gl::framebuffer* framebuffer, resource_manager* resource_manager);
  46. virtual ~sky_pass();
  47. virtual void render(render_context* context) const final;
  48. void update_tweens();
  49. void set_sky_model(const model* model);
  50. void set_time_tween(const tween<double>* time);
  51. void set_moon_model(const model* model);
  52. void set_stars_model(const model* model);
  53. void set_topocentric_frame(const physics::frame<float>& frame);
  54. void set_sun_position(const float3& position);
  55. void set_sun_color(const float3& color);
  56. void set_sun_angular_radius(float radius);
  57. void set_observer_altitude(float altitude);
  58. void set_scale_heights(float rayleigh, float mie);
  59. void set_scattering_coefficients(const float3& r, const float3& m);
  60. void set_mie_anisotropy(float g);
  61. void set_atmosphere_radii(float inner, float outer);
  62. private:
  63. virtual void handle_event(const mouse_moved_event& event);
  64. gl::shader_program* sky_shader_program;
  65. const gl::shader_input* model_view_projection_input;
  66. const gl::shader_input* mouse_input;
  67. const gl::shader_input* resolution_input;
  68. const gl::shader_input* time_input;
  69. const gl::shader_input* exposure_input;
  70. const gl::shader_input* observer_altitude_input;
  71. const gl::shader_input* sun_direction_input;
  72. const gl::shader_input* sun_color_input;
  73. const gl::shader_input* sun_angular_radius_input;
  74. const gl::shader_input* scale_height_rm_input;
  75. const gl::shader_input* rayleigh_scattering_input;
  76. const gl::shader_input* mie_scattering_input;
  77. const gl::shader_input* mie_anisotropy_input;
  78. const gl::shader_input* atmosphere_radii_input;
  79. gl::shader_program* moon_shader_program;
  80. const gl::shader_input* moon_model_view_projection_input;
  81. const gl::shader_input* moon_normal_model_input;
  82. const gl::shader_input* moon_moon_position_input;
  83. const gl::shader_input* moon_sun_position_input;
  84. const model* sky_model;
  85. const material* sky_material;
  86. const gl::vertex_array* sky_model_vao;
  87. gl::drawing_mode sky_model_drawing_mode;
  88. std::size_t sky_model_start_index;
  89. std::size_t sky_model_index_count;
  90. const model* moon_model;
  91. const material* moon_material;
  92. const gl::vertex_array* moon_model_vao;
  93. gl::drawing_mode moon_model_drawing_mode;
  94. std::size_t moon_model_start_index;
  95. std::size_t moon_model_index_count;
  96. const model* stars_model;
  97. const material* star_material;
  98. const gl::vertex_array* stars_model_vao;
  99. gl::drawing_mode stars_model_drawing_mode;
  100. std::size_t stars_model_start_index;
  101. std::size_t stars_model_index_count;
  102. gl::shader_program* star_shader_program;
  103. const gl::shader_input* star_model_view_input;
  104. const gl::shader_input* star_projection_input;
  105. const gl::shader_input* star_exposure_input;
  106. const gl::shader_input* star_distance_input;
  107. const gl::texture_2d* blue_noise_map;
  108. const gl::texture_2d* sky_gradient;
  109. const gl::texture_2d* sky_gradient2;
  110. float2 mouse_position;
  111. const tween<double>* time_tween;
  112. tween<float> observer_altitude_tween;
  113. tween<float3> sun_position_tween;
  114. tween<float3> sun_color_tween;
  115. tween<float3> topocentric_frame_translation;
  116. tween<math::quaternion<float>> topocentric_frame_rotation;
  117. float sun_angular_radius;
  118. float2 scale_height_rm;
  119. float3 rayleigh_scattering;
  120. float3 mie_scattering;
  121. float2 mie_anisotropy;
  122. float3 atmosphere_radii;
  123. };
  124. #endif // ANTKEEPER_SKY_PASS_HPP