AffineTransform.h 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. /*
  2. * Copyright (c) 2020-2022, Andreas Kling <kling@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/Format.h>
  8. #include <AK/Forward.h>
  9. #include <LibGfx/Forward.h>
  10. namespace Gfx {
  11. class AffineTransform {
  12. public:
  13. AffineTransform()
  14. : m_values { 1, 0, 0, 1, 0, 0 }
  15. {
  16. }
  17. AffineTransform(float a, float b, float c, float d, float e, float f)
  18. : m_values { a, b, c, d, e, f }
  19. {
  20. }
  21. bool is_identity() const;
  22. bool is_identity_or_translation() const;
  23. void map(float unmapped_x, float unmapped_y, float& mapped_x, float& mapped_y) const;
  24. template<typename T>
  25. Point<T> map(Point<T> const&) const;
  26. template<typename T>
  27. Size<T> map(Size<T> const&) const;
  28. template<typename T>
  29. Rect<T> map(Rect<T> const&) const;
  30. Quad<float> map_to_quad(Rect<float> const&) const;
  31. [[nodiscard]] ALWAYS_INLINE float a() const { return m_values[0]; }
  32. [[nodiscard]] ALWAYS_INLINE float b() const { return m_values[1]; }
  33. [[nodiscard]] ALWAYS_INLINE float c() const { return m_values[2]; }
  34. [[nodiscard]] ALWAYS_INLINE float d() const { return m_values[3]; }
  35. [[nodiscard]] ALWAYS_INLINE float e() const { return m_values[4]; }
  36. [[nodiscard]] ALWAYS_INLINE float f() const { return m_values[5]; }
  37. [[nodiscard]] float x_scale() const;
  38. [[nodiscard]] float y_scale() const;
  39. [[nodiscard]] FloatPoint scale() const;
  40. [[nodiscard]] float x_translation() const;
  41. [[nodiscard]] float y_translation() const;
  42. [[nodiscard]] FloatPoint translation() const;
  43. AffineTransform& scale(float sx, float sy);
  44. AffineTransform& scale(FloatPoint const& s);
  45. AffineTransform& set_scale(float sx, float sy);
  46. AffineTransform& set_scale(FloatPoint const& s);
  47. AffineTransform& translate(float tx, float ty);
  48. AffineTransform& translate(FloatPoint const& t);
  49. AffineTransform& set_translation(float tx, float ty);
  50. AffineTransform& set_translation(FloatPoint const& t);
  51. AffineTransform& rotate_radians(float);
  52. AffineTransform& multiply(AffineTransform const&);
  53. Optional<AffineTransform> inverse() const;
  54. private:
  55. float m_values[6] { 0 };
  56. };
  57. }
  58. template<>
  59. struct AK::Formatter<Gfx::AffineTransform> : Formatter<FormatString> {
  60. ErrorOr<void> format(FormatBuilder& builder, Gfx::AffineTransform const& value)
  61. {
  62. return Formatter<FormatString>::format(builder, "[{} {} {} {} {} {}]", value.a(), value.b(), value.c(), value.d(), value.e(), value.f());
  63. }
  64. };