AffineTransform.h 2.5 KB

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