81 lines
2 KiB
C++
81 lines
2 KiB
C++
struct Brick
|
|
{
|
|
bool isActive;
|
|
};
|
|
|
|
class BrickGrid
|
|
{
|
|
private:
|
|
inline static const sf::Color color {100, 200, 250};
|
|
|
|
sf::FloatRect m_border;
|
|
int m_numBrickColumns;
|
|
int m_numBrickRows;
|
|
|
|
std::vector<Brick> m_bricks;
|
|
sf::RectangleShape m_brickShape;
|
|
|
|
int m_numActiveBricks;
|
|
|
|
public:
|
|
BrickGrid() {}
|
|
BrickGrid(sf::FloatRect borders, int numBrickColumns, int numBrickRows) :
|
|
m_border(borders),
|
|
m_numBrickColumns(numBrickColumns),
|
|
m_numBrickRows(numBrickRows),
|
|
m_numActiveBricks(numBrickColumns * numBrickRows)
|
|
{
|
|
m_bricks.resize(m_numBrickColumns * m_numBrickRows, Brick{true});
|
|
m_brickShape.setSize(getBrickSizes());
|
|
m_brickShape.setOutlineColor(sf::Color::Black);
|
|
m_brickShape.setOutlineThickness(0.5);
|
|
m_brickShape.setFillColor(color);
|
|
}
|
|
|
|
sf::FloatRect getBorder() const
|
|
{
|
|
return m_border;
|
|
}
|
|
|
|
sf::Vector2i getGridSizes() const
|
|
{
|
|
return {m_numBrickColumns, m_numBrickRows};
|
|
}
|
|
|
|
sf::Vector2f getBrickSizes() const
|
|
{
|
|
return {m_border.width / m_numBrickColumns, m_border.height / m_numBrickRows};
|
|
}
|
|
|
|
bool isBrickActive(std::pair<int, int> indexes) const
|
|
{
|
|
return m_bricks[indexes.first + indexes.second * m_numBrickColumns].isActive;
|
|
}
|
|
|
|
void deactivateBrick(std::pair<int, int> indexes)
|
|
{
|
|
m_bricks[indexes.first + indexes.second * m_numBrickColumns].isActive = false;
|
|
m_numActiveBricks--;
|
|
}
|
|
|
|
int getNumActiveBricks() const
|
|
{
|
|
return m_numActiveBricks;
|
|
}
|
|
|
|
void draw(sf::RenderWindow& window)
|
|
{
|
|
auto [brickWidth, brickHeight] = getBrickSizes();
|
|
|
|
for (int j = 0; j < m_numBrickRows; ++j)
|
|
{
|
|
for (int i = 0; i < m_numBrickColumns; ++i)
|
|
{
|
|
if (!isBrickActive({i, j}))
|
|
continue;
|
|
m_brickShape.setPosition({m_border.left + i * brickWidth, m_border.top + j * brickHeight});
|
|
window.draw(m_brickShape);
|
|
}
|
|
}
|
|
}
|
|
};
|