camera.hpp 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. // SuperTux
  2. // Copyright (C) 2018 Ingo Ruhnke <grumbel@gmail.com>
  3. // 2006 Christoph Sommer <christoph.sommer@2006.expires.deltadevelopment.de>
  4. //
  5. // This program is free software: you can redistribute it and/or modify
  6. // it under the terms of the GNU General Public License as published by
  7. // the Free Software Foundation, either version 3 of the License, or
  8. // (at your option) any later version.
  9. //
  10. // This program is distributed in the hope that it will be useful,
  11. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. // GNU General Public License for more details.
  14. //
  15. // You should have received a copy of the GNU General Public License
  16. // along with this program. If not, see <http://www.gnu.org/licenses/>.
  17. #ifndef HEADER_SUPERTUX_WORLDMAP_CAMERA_HPP
  18. #define HEADER_SUPERTUX_WORLDMAP_CAMERA_HPP
  19. #include "math/vector.hpp"
  20. namespace worldmap {
  21. class WorldMapSector;
  22. class Camera
  23. {
  24. public:
  25. explicit Camera(WorldMapSector& worldmap_sector);
  26. void update(float dt_sec);
  27. void pan();
  28. bool is_panning() const { return m_panning; }
  29. Vector get_offset() const { return m_camera_offset; }
  30. private:
  31. Vector get_camera_pos_for_tux() const;
  32. void clamp_camera_position(Vector& c) const;
  33. private:
  34. WorldMapSector& m_worldmap_sector;
  35. Vector m_camera_offset;
  36. /** variables to track panning to a spawn point */
  37. Vector m_pan_startpos;
  38. float m_pan_time_full;
  39. float m_pan_time_remaining;
  40. bool m_panning;
  41. private:
  42. Camera(const Camera&) = delete;
  43. Camera& operator=(const Camera&) = delete;
  44. };
  45. } // namespace worldmap
  46. #endif
  47. /* EOF */