aboutsummaryrefslogtreecommitdiff
path: root/include/cru/win
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2022-05-07 20:53:57 +0800
committerGitHub <noreply@github.com>2022-05-07 20:53:57 +0800
commitee5aa17e44cb36b386e89032cab96caf87b5b524 (patch)
treea7cef6c60f55e3870900016e0f1a4efe578efbf0 /include/cru/win
parent5bc684dcc1d121bf6e02d0800174c7977c72d101 (diff)
parentcb850a6d6d13fc5b2c0cdd8773e368e23252c459 (diff)
downloadcru-ee5aa17e44cb36b386e89032cab96caf87b5b524.tar.gz
cru-ee5aa17e44cb36b386e89032cab96caf87b5b524.tar.bz2
cru-ee5aa17e44cb36b386e89032cab96caf87b5b524.zip
Merge pull request #54 from crupest/create-image
Diffstat (limited to 'include/cru/win')
-rw-r--r--include/cru/win/graphics/direct/Image.h2
-rw-r--r--include/cru/win/graphics/direct/ImageFactory.h2
-rw-r--r--include/cru/win/graphics/direct/Painter.h11
3 files changed, 12 insertions, 3 deletions
diff --git a/include/cru/win/graphics/direct/Image.h b/include/cru/win/graphics/direct/Image.h
index 0b51f350..bcf2386b 100644
--- a/include/cru/win/graphics/direct/Image.h
+++ b/include/cru/win/graphics/direct/Image.h
@@ -20,6 +20,8 @@ class CRU_WIN_GRAPHICS_DIRECT_API Direct2DImage : public DirectGraphicsResource,
std::unique_ptr<IImage> CreateWithRect(const Rect& rect) override;
+ std::unique_ptr<IPainter> CreatePainter() override;
+
const Microsoft::WRL::ComPtr<ID2D1Bitmap1>& GetD2DBitmap() const {
return d2d_bitmap_;
}
diff --git a/include/cru/win/graphics/direct/ImageFactory.h b/include/cru/win/graphics/direct/ImageFactory.h
index 34d363b0..923e682f 100644
--- a/include/cru/win/graphics/direct/ImageFactory.h
+++ b/include/cru/win/graphics/direct/ImageFactory.h
@@ -19,6 +19,8 @@ class CRU_WIN_GRAPHICS_DIRECT_API WinImageFactory
public:
std::unique_ptr<IImage> DecodeFromStream(io::Stream* stream) override;
+ std::unique_ptr<IImage> CreateBitmap(int width, int height) override;
+
private:
DirectGraphicsFactory* graphics_factory_;
diff --git a/include/cru/win/graphics/direct/Painter.h b/include/cru/win/graphics/direct/Painter.h
index b1795395..da89ba5d 100644
--- a/include/cru/win/graphics/direct/Painter.h
+++ b/include/cru/win/graphics/direct/Painter.h
@@ -2,6 +2,7 @@
#include "ComResource.h"
#include "Resource.h"
+#include "cru/common/Base.h"
#include "cru/platform/graphics/Painter.h"
#include <vector>
@@ -11,13 +12,15 @@ class CRU_WIN_GRAPHICS_DIRECT_API D2DDeviceContextPainter
: public DirectResource,
public virtual IPainter,
public virtual IComResource<ID2D1DeviceContext1> {
+ CRU_DEFINE_CLASS_LOG_TAG(u"D2DDeviceContextPainter")
public:
- explicit D2DDeviceContextPainter(ID2D1DeviceContext1* device_context);
+ explicit D2DDeviceContextPainter(ID2D1DeviceContext1* device_context,
+ bool release = false);
CRU_DELETE_COPY(D2DDeviceContextPainter)
CRU_DELETE_MOVE(D2DDeviceContextPainter)
- ~D2DDeviceContextPainter() override = default;
+ ~D2DDeviceContextPainter() override;
public:
ID2D1DeviceContext1* GetComInterface() const override {
@@ -57,7 +60,7 @@ class CRU_WIN_GRAPHICS_DIRECT_API D2DDeviceContextPainter
void EndDraw() override final;
protected:
- virtual void DoEndDraw() = 0;
+ virtual void DoEndDraw() {}
private:
bool IsValid() { return is_drawing_; }
@@ -71,5 +74,7 @@ class CRU_WIN_GRAPHICS_DIRECT_API D2DDeviceContextPainter
drawing_state_stack_;
bool is_drawing_ = true;
+
+ bool release_;
};
} // namespace cru::platform::graphics::win::direct