aboutsummaryrefslogtreecommitdiffstats
path: root/include/components/texture.hpp
diff options
context:
space:
mode:
authorClyne Sullivan <clyne@bitgloo.com>2024-08-05 15:47:55 -0400
committerClyne Sullivan <clyne@bitgloo.com>2024-08-05 15:47:55 -0400
commit456ef376530fc4644732d499c862f1413b9987d9 (patch)
treeab28615220d16a9c32b6b1dab6ad4313b43ac0fb /include/components/texture.hpp
parent66991ce9b81f4af3c095d38fa2187837d94e5469 (diff)
level solid; basic collision/gravity
Diffstat (limited to 'include/components/texture.hpp')
-rw-r--r--include/components/texture.hpp12
1 files changed, 9 insertions, 3 deletions
diff --git a/include/components/texture.hpp b/include/components/texture.hpp
index f4d414e..14253f1 100644
--- a/include/components/texture.hpp
+++ b/include/components/texture.hpp
@@ -1,6 +1,7 @@
#ifndef COMPONENTS_TEXTURE_HPP
#define COMPONENTS_TEXTURE_HPP
+#include "components/point.hpp"
#include "window.hpp"
class Texture
@@ -8,6 +9,8 @@ class Texture
public:
Texture(const char *path) {
tex = sdl2LoadTexture(path);
+ if (tex)
+ SDL_QueryTexture(tex, nullptr, nullptr, &w, &h);
}
~Texture() {
@@ -18,15 +21,18 @@ public:
void operator()(SDL_Renderer *rend, Point p) const noexcept {
const int x = static_cast<int>(p.x);
const int y = static_cast<int>(p.y);
- SDL_Rect rect {x, y, 0, 0};
+ SDL_Rect rect {x, y, w, h};
- /* TODO err check */
- SDL_QueryTexture(tex, nullptr, nullptr, &rect.w, &rect.h);
SDL_RenderCopy(rend, tex, nullptr, &rect);
}
+ Point dim() const noexcept {
+ return Point {static_cast<float>(w), static_cast<float>(h)};
+ }
+
private:
SDL_Texture *tex;
+ int w, h;
};
#endif // COMPONENTS_TEXTURE_HPP