在 SFML 中不使用动态内存时显示白色纹理代替实际纹理

White texture showing in place of actual texture when not using dynamic memory in SFML

本文关键字:纹理 白色 显示 内存 SFML 动态      更新时间:2023-10-16

我有一个Armor类,它存储了一个纹理和一个要绘制到屏幕上的精灵,如下所示:

Armor.h

class Armor 
{
public:
Armor(const std::string& armorName);
void draw(sf::RenderWindow& window);
~Armor();
private:
sf::Texture armorTexture;
sf::Sprite armorSprite;
int numOfArmor;
};

Armor.cpp

#include "Armor.h"
Armor::Armor(const std::string& armorName)
{
armorTexture.loadFromFile(armorName);
armorSprite.setTexture(armorTexture);
numOfArmor = 0;
}

void Armor::draw(sf::RenderWindow& window)
{
window.draw(armorSprite);
}
Armor::~Armor()
{
}

我还有一个名为Application的对象,它将Armor的实例存储在地图中,如下所示:

Application.h

class Application
{
public:
Application();
void start();
~Application();
private:
sf::RenderWindow window;
std::map<std::string, Armor> armorMap;
std::map<std::string, Armor>::iterator armorIter;
};

Application.cpp

#include "Application.h"
Application::Application()
{
window.create(sf::VideoMode(640, 480), "SFML Application", sf::Style::Close);
window.setFramerateLimit(120);
std::string armorName;
std::ifstream file("Armors.txt");
while (file >> armorName)
armorMap.emplace(armorName, Armor(armorName + "Armor.png"));
file.close();
armorIter = armorMap.begin();
}
void Application::start()
{
while (window.isOpen())
{
sf::Event evnt;
while (window.pollEvent(evnt))
{
if (evnt.type == sf::Event::Closed)
window.close();
}
window.clear();
while (armorIter != armorMap.end())
{
armorIter->second.draw(window);
armorIter++;
}
armorIter = armorMap.begin();
window.display();
}
}
Application::~Application()
{
}

每当我构建对象时,屏幕上都会出现白色纹理,我发现这被称为白色纹理问题。我很困惑,因为我确信我的纹理没有被破坏,所以我决定将地图更改为std::map<std::string, Armor*> armorMap,这解决了我所有的问题!为什么在地图中存储指向Armor类型的对象的指针会起作用,而不是我最初的方式?

当你将你的盔甲物品存储到地图中时,你正在复制它,它的纹理和它的精灵。

精灵已将您的纹理存储为指向被销毁的原始纹理对象的指针(请参阅 https://www.sfml-dev.org/documentation/2.5.0/classsf_1_1Sprite.php#a3729c88d88ac38c19317c18e87242560(。

无论如何,在地图中存储指针都会给你带来更好的性能,因为你会避免不必要的纹理副本。您可能应该使用std::shared_ptr<Armour>而不是原始指针,除非您真的知道自己在做什么。