summaryrefslogtreecommitdiff
path: root/Source/Asura.Engine/Graphics/Image.h
diff options
context:
space:
mode:
authorchai <chaifix@163.com>2019-03-12 00:39:26 +0800
committerchai <chaifix@163.com>2019-03-12 00:39:26 +0800
commit70b82d1981c0de3c7b77670ff8abcfeb26815142 (patch)
treef69c05bcd204cc3f9bf745be37a2ba5911e52436 /Source/Asura.Engine/Graphics/Image.h
parentc19a282e10f51ddd50d198b903f8fbd5a2238b62 (diff)
*misc
Diffstat (limited to 'Source/Asura.Engine/Graphics/Image.h')
-rw-r--r--Source/Asura.Engine/Graphics/Image.h29
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;
-
};
}