AffineTransform.h 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  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. [[nodiscard]] float rotation() const;
  45. AffineTransform& scale(float sx, float sy);
  46. AffineTransform& scale(FloatPoint s);
  47. AffineTransform& set_scale(float sx, float sy);
  48. AffineTransform& set_scale(FloatPoint s);
  49. AffineTransform& translate(float tx, float ty);
  50. AffineTransform& translate(FloatPoint t);
  51. AffineTransform& set_translation(float tx, float ty);
  52. AffineTransform& set_translation(FloatPoint t);
  53. AffineTransform& rotate_radians(float);
  54. AffineTransform& skew_radians(float x_radians, float y_radians);
  55. AffineTransform& multiply(AffineTransform const&);
  56. float determinant() const;
  57. Optional<AffineTransform> inverse() const;
  58. private:
  59. float m_values[6] { 0 };
  60. };
  61. }
  62. template<>
  63. struct AK::Formatter<Gfx::AffineTransform> : Formatter<FormatString> {
  64. ErrorOr<void> format(FormatBuilder& builder, Gfx::AffineTransform const& value)
  65. {
  66. return Formatter<FormatString>::format(builder, "[{} {} {} {} {} {}]"sv, value.a(), value.b(), value.c(), value.d(), value.e(), value.f());
  67. }
  68. };