aboutsummaryrefslogtreecommitdiff
path: root/include/cru/win/graphics/direct/Image.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'include/cru/win/graphics/direct/Image.hpp')
-rw-r--r--include/cru/win/graphics/direct/Image.hpp16
1 files changed, 11 insertions, 5 deletions
diff --git a/include/cru/win/graphics/direct/Image.hpp b/include/cru/win/graphics/direct/Image.hpp
index 33d848bd..06448621 100644
--- a/include/cru/win/graphics/direct/Image.hpp
+++ b/include/cru/win/graphics/direct/Image.hpp
@@ -6,8 +6,8 @@ namespace cru::platform::graphics::win::direct {
class CRU_WIN_GRAPHICS_DIRECT_API Direct2DImage : public DirectGraphicsResource,
public virtual IImage {
public:
- explicit Direct2DImage(DirectGraphicsFactory* graphics_factory,
- ID2D1Image* d2d_image, bool auto_release);
+ Direct2DImage(DirectGraphicsFactory* graphics_factory,
+ Microsoft::WRL::ComPtr<ID2D1Bitmap1> d2d_bitmap);
CRU_DELETE_COPY(Direct2DImage)
CRU_DELETE_MOVE(Direct2DImage)
@@ -15,11 +15,17 @@ class CRU_WIN_GRAPHICS_DIRECT_API Direct2DImage : public DirectGraphicsResource,
~Direct2DImage() override;
public:
- ID2D1Image* GetD2DImage() const { return d2d_image_; }
+ float GetWidth() override;
+ float GetHeight() override;
+
+ std::unique_ptr<IImage> CreateWithRect(const Rect& rect) override;
+
+ const Microsoft::WRL::ComPtr<ID2D1Bitmap1>& GetD2DBitmap() const {
+ return d2d_bitmap_;
+ }
private:
- ID2D1Image* d2d_image_;
- bool auto_release_;
+ Microsoft::WRL::ComPtr<ID2D1Bitmap1> d2d_bitmap_;
};
} // namespace cru::platform::graphics::win::direct