diff --git a/src/PyTexture.cpp b/src/PyTexture.cpp new file mode 100644 index 0000000..0a16ed9 --- /dev/null +++ b/src/PyTexture.cpp @@ -0,0 +1,20 @@ +#include "PyTexture.h" + +PyTexture::PyTexture(std::string filename, int sprite_w, int sprite_h) +: sprite_width(sprite_w), sprite_height(sprite_h) +{ + // TODO - get image resolution and get sheet width and height + sheet_width = 0; + sheet_height = 0; + source = filename; +} + +sf::Sprite PyTexture::sprite(int index, float x = 0.0, float y = 0.0, float s = 1.0) +{ + int tx = index % sprite_width, ty = index / sprite_height; + auto ir = sf::IntRect(tx * sprite_width, ty * sprite_height, sprite_width, sprite_height); + auto sprite = sf::Sprite(texture, ir); + sprite.setPosition(x, y); + sprite.setScale(s, s); + return sprite; +} diff --git a/src/PyTexture.h b/src/PyTexture.h new file mode 100644 index 0000000..288bbfb --- /dev/null +++ b/src/PyTexture.h @@ -0,0 +1,14 @@ +#pragma once +#include "Common.h" +#include "Python.h" + +class PyTexture +{ +private: + sf::Texture texture; + std::string source; + int sprite_width, sprite_height, sheet_width, sheet_height; +public: + PyTexture(std::string filename, int sprite_w, int sprite_h); + sf::Sprite sprite(int index, float x = 0.0, float y = 0.0, float s = 1.0); +};