diff options
Diffstat (limited to 'Userland')
-rw-r--r-- | Userland/Libraries/LibWeb/Forward.h | 1 | ||||
-rw-r--r-- | Userland/Libraries/LibWeb/HTML/Canvas/CanvasImageData.h | 4 | ||||
-rw-r--r-- | Userland/Libraries/LibWeb/HTML/CanvasRenderingContext2D.cpp | 8 | ||||
-rw-r--r-- | Userland/Libraries/LibWeb/HTML/CanvasRenderingContext2D.h | 4 | ||||
-rw-r--r-- | Userland/Libraries/LibWeb/HTML/ImageData.cpp | 30 | ||||
-rw-r--r-- | Userland/Libraries/LibWeb/HTML/ImageData.h | 25 | ||||
-rw-r--r-- | Userland/Libraries/LibWeb/idl_files.cmake | 2 |
7 files changed, 41 insertions, 33 deletions
diff --git a/Userland/Libraries/LibWeb/Forward.h b/Userland/Libraries/LibWeb/Forward.h index 439c8335c4..dff2c3eea8 100644 --- a/Userland/Libraries/LibWeb/Forward.h +++ b/Userland/Libraries/LibWeb/Forward.h @@ -461,7 +461,6 @@ class FileWrapper; class HeadersWrapper; class HeadersIteratorWrapper; class IdleDeadlineWrapper; -class ImageDataWrapper; class IntersectionObserverWrapper; class LocationObject; class OptionConstructor; diff --git a/Userland/Libraries/LibWeb/HTML/Canvas/CanvasImageData.h b/Userland/Libraries/LibWeb/HTML/Canvas/CanvasImageData.h index 28c182f1f4..ba5f69ed5f 100644 --- a/Userland/Libraries/LibWeb/HTML/Canvas/CanvasImageData.h +++ b/Userland/Libraries/LibWeb/HTML/Canvas/CanvasImageData.h @@ -15,8 +15,8 @@ class CanvasImageData { public: virtual ~CanvasImageData() = default; - virtual RefPtr<ImageData> create_image_data(int width, int height) const = 0; - virtual DOM::ExceptionOr<RefPtr<ImageData>> get_image_data(int x, int y, int width, int height) const = 0; + virtual JS::GCPtr<ImageData> create_image_data(int width, int height) const = 0; + virtual DOM::ExceptionOr<JS::GCPtr<ImageData>> get_image_data(int x, int y, int width, int height) const = 0; virtual void put_image_data(ImageData const&, float x, float y) = 0; protected: diff --git a/Userland/Libraries/LibWeb/HTML/CanvasRenderingContext2D.cpp b/Userland/Libraries/LibWeb/HTML/CanvasRenderingContext2D.cpp index 5c923a6fe9..5136a4c997 100644 --- a/Userland/Libraries/LibWeb/HTML/CanvasRenderingContext2D.cpp +++ b/Userland/Libraries/LibWeb/HTML/CanvasRenderingContext2D.cpp @@ -317,13 +317,13 @@ void CanvasRenderingContext2D::fill(Path2D& path, String const& fill_rule) return fill_internal(transformed_path, fill_rule); } -RefPtr<ImageData> CanvasRenderingContext2D::create_image_data(int width, int height) const +JS::GCPtr<ImageData> CanvasRenderingContext2D::create_image_data(int width, int height) const { - return ImageData::create_with_size(vm(), width, height); + return ImageData::create_with_size(global_object(), width, height); } // https://html.spec.whatwg.org/multipage/canvas.html#dom-context-2d-getimagedata -DOM::ExceptionOr<RefPtr<ImageData>> CanvasRenderingContext2D::get_image_data(int x, int y, int width, int height) const +DOM::ExceptionOr<JS::GCPtr<ImageData>> CanvasRenderingContext2D::get_image_data(int x, int y, int width, int height) const { // 1. If either the sw or sh arguments are zero, then throw an "IndexSizeError" DOMException. if (width == 0 || height == 0) @@ -335,7 +335,7 @@ DOM::ExceptionOr<RefPtr<ImageData>> CanvasRenderingContext2D::get_image_data(int // 3. Let imageData be a new ImageData object. // 4. Initialize imageData given sw, sh, settings set to settings, and defaultColorSpace set to this's color space. - auto image_data = ImageData::create_with_size(vm(), width, height); + auto image_data = ImageData::create_with_size(global_object(), width, height); // NOTE: We don't attempt to create the underlying bitmap here; if it doesn't exist, it's like copying only transparent black pixels (which is a no-op). if (!canvas_element().bitmap()) diff --git a/Userland/Libraries/LibWeb/HTML/CanvasRenderingContext2D.h b/Userland/Libraries/LibWeb/HTML/CanvasRenderingContext2D.h index 8cb2e56a1d..8c5e7987ea 100644 --- a/Userland/Libraries/LibWeb/HTML/CanvasRenderingContext2D.h +++ b/Userland/Libraries/LibWeb/HTML/CanvasRenderingContext2D.h @@ -70,8 +70,8 @@ public: virtual void fill(String const& fill_rule) override; virtual void fill(Path2D& path, String const& fill_rule) override; - virtual RefPtr<ImageData> create_image_data(int width, int height) const override; - virtual DOM::ExceptionOr<RefPtr<ImageData>> get_image_data(int x, int y, int width, int height) const override; + virtual JS::GCPtr<ImageData> create_image_data(int width, int height) const override; + virtual DOM::ExceptionOr<JS::GCPtr<ImageData>> get_image_data(int x, int y, int width, int height) const override; virtual void put_image_data(ImageData const&, float x, float y) override; virtual void reset_to_default_state() override; diff --git a/Userland/Libraries/LibWeb/HTML/ImageData.cpp b/Userland/Libraries/LibWeb/HTML/ImageData.cpp index 7bdadd7aee..e70c40b18a 100644 --- a/Userland/Libraries/LibWeb/HTML/ImageData.cpp +++ b/Userland/Libraries/LibWeb/HTML/ImageData.cpp @@ -1,18 +1,20 @@ /* - * Copyright (c) 2020, Andreas Kling <kling@serenityos.org> + * Copyright (c) 2020-2022, Andreas Kling <kling@serenityos.org> * * SPDX-License-Identifier: BSD-2-Clause */ #include <LibGfx/Bitmap.h> #include <LibJS/Runtime/TypedArray.h> +#include <LibWeb/Bindings/ImageDataPrototype.h> #include <LibWeb/HTML/ImageData.h> +#include <LibWeb/HTML/Window.h> namespace Web::HTML { -RefPtr<ImageData> ImageData::create_with_size(JS::VM& vm, int width, int height) +JS::GCPtr<ImageData> ImageData::create_with_size(HTML::Window& window, int width, int height) { - auto& realm = *vm.current_realm(); + auto& realm = window.realm(); if (width <= 0 || height <= 0) return nullptr; @@ -23,24 +25,30 @@ RefPtr<ImageData> ImageData::create_with_size(JS::VM& vm, int width, int height) auto data_or_error = JS::Uint8ClampedArray::create(realm, width * height * 4); if (data_or_error.is_error()) return nullptr; - auto* data = data_or_error.release_value(); - - auto data_handle = JS::make_handle(data); + auto data = JS::NonnullGCPtr<JS::Uint8ClampedArray>(*data_or_error.release_value()); auto bitmap_or_error = Gfx::Bitmap::try_create_wrapper(Gfx::BitmapFormat::RGBA8888, Gfx::IntSize(width, height), 1, width * sizeof(u32), data->data().data()); if (bitmap_or_error.is_error()) return nullptr; - return adopt_ref(*new ImageData(bitmap_or_error.release_value(), move(data_handle))); + return realm.heap().allocate<ImageData>(realm, window, bitmap_or_error.release_value(), move(data)); } -ImageData::ImageData(NonnullRefPtr<Gfx::Bitmap> bitmap, JS::Handle<JS::Uint8ClampedArray> data) - : m_bitmap(move(bitmap)) +ImageData::ImageData(HTML::Window& window, NonnullRefPtr<Gfx::Bitmap> bitmap, JS::NonnullGCPtr<JS::Uint8ClampedArray> data) + : PlatformObject(window.realm()) + , m_bitmap(move(bitmap)) , m_data(move(data)) { + set_prototype(&window.ensure_web_prototype<Bindings::ImageDataPrototype>("ImageData")); } ImageData::~ImageData() = default; +void ImageData::visit_edges(Cell::Visitor& visitor) +{ + Base::visit_edges(visitor); + visitor.visit(m_data.ptr()); +} + unsigned ImageData::width() const { return m_bitmap->width(); @@ -53,12 +61,12 @@ unsigned ImageData::height() const JS::Uint8ClampedArray* ImageData::data() { - return m_data.cell(); + return m_data; } const JS::Uint8ClampedArray* ImageData::data() const { - return m_data.cell(); + return m_data; } } diff --git a/Userland/Libraries/LibWeb/HTML/ImageData.h b/Userland/Libraries/LibWeb/HTML/ImageData.h index 58896aca1c..b93333774c 100644 --- a/Userland/Libraries/LibWeb/HTML/ImageData.h +++ b/Userland/Libraries/LibWeb/HTML/ImageData.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 2020, Andreas Kling <kling@serenityos.org> + * Copyright (c) 2020-2022, Andreas Kling <kling@serenityos.org> * * SPDX-License-Identifier: BSD-2-Clause */ @@ -7,20 +7,17 @@ #pragma once #include <LibGfx/Forward.h> -#include <LibJS/Heap/Handle.h> -#include <LibWeb/Bindings/Wrappable.h> +#include <LibWeb/Bindings/PlatformObject.h> namespace Web::HTML { -class ImageData - : public RefCounted<ImageData> - , public Bindings::Wrappable { -public: - using WrapperType = Bindings::ImageDataWrapper; +class ImageData final : public Bindings::PlatformObject { + WEB_PLATFORM_OBJECT(ImageData, Bindings::PlatformObject); - static RefPtr<ImageData> create_with_size(JS::VM&, int width, int height); +public: + static JS::GCPtr<ImageData> create_with_size(HTML::Window&, int width, int height); - ~ImageData(); + virtual ~ImageData() override; unsigned width() const; unsigned height() const; @@ -32,10 +29,14 @@ public: const JS::Uint8ClampedArray* data() const; private: - explicit ImageData(NonnullRefPtr<Gfx::Bitmap>, JS::Handle<JS::Uint8ClampedArray>); + explicit ImageData(HTML::Window&, NonnullRefPtr<Gfx::Bitmap>, JS::NonnullGCPtr<JS::Uint8ClampedArray>); + + virtual void visit_edges(Cell::Visitor&) override; NonnullRefPtr<Gfx::Bitmap> m_bitmap; - JS::Handle<JS::Uint8ClampedArray> m_data; + JS::NonnullGCPtr<JS::Uint8ClampedArray> m_data; }; } + +WRAPPER_HACK(ImageData, Web::HTML) diff --git a/Userland/Libraries/LibWeb/idl_files.cmake b/Userland/Libraries/LibWeb/idl_files.cmake index 71c487e08a..17643b5fba 100644 --- a/Userland/Libraries/LibWeb/idl_files.cmake +++ b/Userland/Libraries/LibWeb/idl_files.cmake @@ -140,7 +140,7 @@ libweb_js_wrapper(HTML/HTMLTrackElement NO_INSTANCE) libweb_js_wrapper(HTML/HTMLUListElement NO_INSTANCE) libweb_js_wrapper(HTML/HTMLUnknownElement NO_INSTANCE) libweb_js_wrapper(HTML/HTMLVideoElement NO_INSTANCE) -libweb_js_wrapper(HTML/ImageData) +libweb_js_wrapper(HTML/ImageData NO_INSTANCE) libweb_js_wrapper(HTML/MessageChannel NO_INSTANCE) libweb_js_wrapper(HTML/MessageEvent NO_INSTANCE) libweb_js_wrapper(HTML/MessagePort NO_INSTANCE) |