DOMQuad.h 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  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. JS_DECLARE_ALLOCATOR(DOMQuad);
  23. public:
  24. static JS::NonnullGCPtr<DOMQuad> construct_impl(JS::Realm&, DOMPointInit const& p1, DOMPointInit const& p2, DOMPointInit const& p3, DOMPointInit const& p4);
  25. virtual ~DOMQuad() override;
  26. static JS::NonnullGCPtr<DOMQuad> from_rect(JS::VM&, DOMRectInit const&);
  27. static JS::NonnullGCPtr<DOMQuad> from_quad(JS::VM&, DOMQuadInit const&);
  28. JS::NonnullGCPtr<DOMPoint> p1() const { return m_p1; }
  29. JS::NonnullGCPtr<DOMPoint> p2() const { return m_p2; }
  30. JS::NonnullGCPtr<DOMPoint> p3() const { return m_p3; }
  31. JS::NonnullGCPtr<DOMPoint> p4() const { return m_p4; }
  32. JS::NonnullGCPtr<DOMRect> get_bounds() const;
  33. private:
  34. DOMQuad(JS::Realm&, DOMPointInit const& p1, DOMPointInit const& p2, DOMPointInit const& p3, DOMPointInit const& p4);
  35. virtual void initialize(JS::Realm&) override;
  36. virtual void visit_edges(Cell::Visitor&) override;
  37. JS::NonnullGCPtr<DOMPoint> m_p1;
  38. JS::NonnullGCPtr<DOMPoint> m_p2;
  39. JS::NonnullGCPtr<DOMPoint> m_p3;
  40. JS::NonnullGCPtr<DOMPoint> m_p4;
  41. };
  42. }