gpt4 book ai didi

c++ - 如何将实际的 sf::Sprite 对象保存在数组或 vector 中? C++

转载 作者:行者123 更新时间:2023-12-02 10:35:05 25 4
gpt4 key购买 nike

关闭。这个问题需要debugging details .它目前不接受答案。












想改进这个问题?将问题更新为 on-topic对于堆栈溢出。

2年前关闭。




Improve this question




在我的类中(在 some_game_object.h 中),在私有(private)部分,我有以下小代码片段

sf::Sprite some_sprite;
std::vector<sf::Sprite> sprites;

在 .cpp 文件 some_game_object.cpp 我有以下内容
void some_game_object::set_texture(sf::Texture t) {
sprites[0].setTexture(t);
}

但质地从未改变。我无法在另一个函数中更改 Sprite 的位置,并且实际上无法使用纹理绘制 Sprite 。实际访问此 sf::Sprite 对象“some_sprite”并对其进行更改的唯一方法是在 .cpp 文件中直接调用它。将它返回到我的 main.cpp 文件会使返回的对象/引用完全无用,因为它包含移动对象的旧信息。通过 sprites vector 在 some_game_object.cpp 中引用它没有任何作用。使用数组代替 (std::array sprites; sprites[0] = some_sprite) 也是没用的。数据在那里。如果我看 sprites[0]->getTexture().getSize();这是右侧。 sprite 具有初始化坐标,但无法绘制纹理也无法获取最新坐标(当不直接引用 some_sprite 时)。

如何以某种形式或 vector 或数组引用和保存 Sprite ,两者都很好,而不会丢失 ACTUAL 对象?

最佳答案

您有两个主要选择。您可以创建一个动态对象并存储一个指针(最好是智能指针),或者您可以创建一个自动对象并将其移动到容器中。

出于您的目的,存储动态对象的容器可能会更简单。这意味着只要程序运行或删除(手动或通过 RAII 自动删除),您创建的对象就会一直存在。它也只能通过指向它的指针访问,并且不会被复制(只会复制指针)。例如,存储一个指向 sf::Sprite 对象的智能指针 vector :


std::vector<std::shared_ptr<sf::Sprite>> sprites;
auto sprite = std::make_shared<sf::Sprite>(); // <-- Make the new object
sprites.emplace_back(sprite); // <-- Copy its pointer into the vector

...
sprites[0]->setTexture(t); // <-- Modifies the same sprite object since it hasnt been copied

在此示例中,我使用了 std::shared_ptr因为它可以很容易地复制,我不想用 std::move 使示例过于复杂。像 std::unique_ptr 这样的东西需要.但是,如果您想对“拥有” Sprite 对象的容器进行建模,那么您应该使用 std::unique_ptr反而。

关于c++ - 如何将实际的 sf::Sprite 对象保存在数组或 vector 中? C++,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60693899/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com