DOMQuad.h 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. /*
  2. * Copyright (c) 2023, Bastiaan van der Plaat <bastiaan.v.d.plaat@gmail.com>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <LibWeb/Bindings/PlatformObject.h>
  8. #include <LibWeb/Geometry/DOMPoint.h>
  9. #include <LibWeb/Geometry/DOMRect.h>
  10. #include <LibWeb/Geometry/DOMRectReadOnly.h>
  11. namespace Web::Geometry {
  12. // https://drafts.fxtf.org/geometry/#dictdef-domquadinit
  13. struct DOMQuadInit {
  14. DOMPointInit p1;
  15. DOMPointInit p2;
  16. DOMPointInit p3;
  17. DOMPointInit p4;
  18. };
  19. // https://drafts.fxtf.org/geometry/#domquad
  20. class DOMQuad : public Bindings::PlatformObject {
  21. WEB_PLATFORM_OBJECT(DOMQuad, Bindings::PlatformObject);
  22. public:
  23. static JS::NonnullGCPtr<DOMQuad> construct_impl(JS::Realm&, DOMPointInit const& p1, DOMPointInit const& p2, DOMPointInit const& p3, DOMPointInit const& p4);
  24. virtual ~DOMQuad() override;
  25. static JS::NonnullGCPtr<DOMQuad> from_rect(JS::VM&, DOMRectInit const&);
  26. static JS::NonnullGCPtr<DOMQuad> from_quad(JS::VM&, DOMQuadInit const&);
  27. JS::NonnullGCPtr<DOMPoint> p1() const { return m_p1; }
  28. JS::NonnullGCPtr<DOMPoint> p2() const { return m_p2; }
  29. JS::NonnullGCPtr<DOMPoint> p3() const { return m_p3; }
  30. JS::NonnullGCPtr<DOMPoint> p4() const { return m_p4; }
  31. JS::NonnullGCPtr<DOMRect> get_bounds() const;
  32. private:
  33. DOMQuad(JS::Realm&, DOMPointInit const& p1, DOMPointInit const& p2, DOMPointInit const& p3, DOMPointInit const& p4);
  34. virtual void initialize(JS::Realm&) override;
  35. virtual void visit_edges(Cell::Visitor&) override;
  36. JS::NonnullGCPtr<DOMPoint> m_p1;
  37. JS::NonnullGCPtr<DOMPoint> m_p2;
  38. JS::NonnullGCPtr<DOMPoint> m_p3;
  39. JS::NonnullGCPtr<DOMPoint> m_p4;
  40. };
  41. }