diff options
author | chai <chaifix@163.com> | 2019-03-12 00:39:26 +0800 |
---|---|---|
committer | chai <chaifix@163.com> | 2019-03-12 00:39:26 +0800 |
commit | 70b82d1981c0de3c7b77670ff8abcfeb26815142 (patch) | |
tree | f69c05bcd204cc3f9bf745be37a2ba5911e52436 /Source/Asura.Engine/Graphics/Image.h | |
parent | c19a282e10f51ddd50d198b903f8fbd5a2238b62 (diff) |
*misc
Diffstat (limited to 'Source/Asura.Engine/Graphics/Image.h')
-rw-r--r-- | Source/Asura.Engine/Graphics/Image.h | 29 |
1 files changed, 19 insertions, 10 deletions
diff --git a/Source/Asura.Engine/Graphics/Image.h b/Source/Asura.Engine/Graphics/Image.h index 7897f74..6d12303 100644 --- a/Source/Asura.Engine/Graphics/Image.h +++ b/Source/Asura.Engine/Graphics/Image.h @@ -1,12 +1,12 @@ #ifndef __ASURA_ENGINE_IMAGE_H__ #define __ASURA_ENGINE_IMAGE_H__ +#include "Math/Vector2.hpp" #include "FileSystem/Reloadable.h" #include "StringMap.hpp" #include "Manager.hpp" #include "Texture.h" #include "Color.h" -#include "Factory.h" #include "ImageData.h" namespace AsuraEngine @@ -20,46 +20,55 @@ namespace AsuraEngine /// ImageͼƬڴȡϷĽһImageڴ桢ԴֻᱣһݣҪ /// imageêλãźתǶȣʹspriteһֻࡣҪǿǵeditorengineʹòͬķװ /// - class Image final : public Drawable, public Scripting::Portable, public Filesystem::Reloadable + class Image ASURA_FINAL + : public Drawable + , public Scripting::Portable + , public Filesystem::Reloadable { public: Image(); + ~Image(); /// /// bufferimageϢmPixelsΪգݡ¹imageʹglTexImage2Dύimage /// ݡ /// - bool Load(const ImageData* data); + bool Load(ImageData* data); uint GetWidth(); uint GetHeight(); + Math::Vector2u GetSize(); /// /// ijһλõ /// Color32 GetPixel(uint x, uint y); - virtual void Render(const RenderTarget* rt, const RenderState& state) override; + void Render(const RenderTarget* rt, const RenderState& state) override; + + void Render(const RenderTarget* rt, const Math::Rectf& quad, const RenderState& state) override; + + private: + + ImageData* mImageData; - virtual void Render(const RenderTarget* rt, const Math::Rectf& quad, const RenderState& state) override; + Math::Vector2u mSize; + + public: //---------------------------------------------------------------------------------------------------------- LUAX_DECL_FACTORY(SimImage); LUAX_DECL_METHOD(l_Load); - LUAX_DECL_METHOD(l_GetPixel); LUAX_DECL_METHOD(l_GetWidth); LUAX_DECL_METHOD(l_GetHeight); + LUAX_DECL_METHOD(l_GetSize); //---------------------------------------------------------------------------------------------------------- - private: - - const ImageData* mImageData; - }; } |