So, I have a minimap, which looks like this at the moment:
data:image/s3,"s3://crabby-images/bd95a/bd95a5b01fccbf99cdb20933968e39bb5e94ccf6" alt=""
It's made out of three other images; the level itself, the mask defining which part of it should draw, and the border.
data:image/s3,"s3://crabby-images/2ef5a/2ef5a21617bfc5feccc428350ecfe0fd47b743fb" alt=""
data:image/s3,"s3://crabby-images/239a5/239a5a25782546124387d24f5ab01ae50f8af2e9" alt=""
Currently it's being drawn inside of a render texture every time it changes, the result of which is then used to draw the minimap itself. The drawing looks something like this:
void UI::drawMap(sf::RenderTarget& target, const sf::IntRect& pos, bool redraw) const
{
if (redraw)
{
tex.clear(sf::Color::Transparent);
sf::Sprite mask(mapMask);
tex.draw(mask, sf::RenderStates(sf::BlendAdd));
sf::Sprite mini(levelTexture, pos);
mini.setScale(175.f/pos.width, 175.f/pos.height);
tex.draw(mini, sf::RenderStates(sf::BlendMultiply));
tex.display();
}
sf::Sprite map(tex.getTexture());
map.setPosition(target.getView().getSize().x - tex.getSize().x - 12.f, 12.f);
target.draw(map);
}
This works for now. Though seeing as I have done similar things inside of OpenGL applications without having to use a render texture, I'd rather change the rendering into something that is a bit friendlier to computers that don't take them so well.
Like the laptop I'm developing it on. (Right now, around 8-12ms is spent redrawing the minimap every time it changes. And more ui parts that need blending in a way like this are coming)