Welcome, Guest. Please login or register. Did you miss your activation email?

Author Topic: [SOLVED] texture from an image -> white sprite  (Read 3636 times)

0 Members and 2 Guests are viewing this topic.

Geheim

  • Full Member
  • ***
  • Posts: 201
    • View Profile
    • Email
[SOLVED] texture from an image -> white sprite
« on: September 14, 2013, 10:36:10 pm »
Hey guys,
I try to load a texture from an image, set it to a sprite and draw it on the screen.
The image gets created and the colors are set "by hand", however the sprite always is white, no matter which color I set.

blockImage.create(BLOCK_SIZE, BLOCK_SIZE);
for(size_t x = 0; x != BLOCK_SIZE; ++x)
        for(size_t y = 0; y != BLOCK_SIZE; ++y)
                blockImage.setPixel(x, y, sf::Color::Blue);
blockTexture.loadFromImage(blockImage);
block.setTexture(blockTexture);

blockImage, blockTexture and block (the sprite) are members of a class and this class is stored in a std::vector in another one (maybe it has something to do with it)

I tried to print out blockImage.getPixel(0, 0).b after I set it to blue, but I get no number, so I think I make something wrong with the image, but what is it?
Thanks and Greetings ;)
« Last Edit: September 15, 2013, 09:48:19 am by Geheim »
Failing to succeed does not mean failing to progress!

eXpl0it3r

  • SFML Team
  • Hero Member
  • *****
  • Posts: 11034
    • View Profile
    • development blog
    • Email
AW: texture from an image -> white sprite
« Reply #1 on: September 14, 2013, 10:57:53 pm »
My guess is that your texture runs out of scope before it gets drawn to the screen. But without a minimal and complete example we can only guess.
Official FAQ: https://www.sfml-dev.org/faq.php
Official Discord Server: https://discord.gg/nr4X7Fh
——————————————————————
Dev Blog: https://duerrenberger.dev/blog/

Geheim

  • Full Member
  • ***
  • Posts: 201
    • View Profile
    • Email
Re: texture from an image -> white sprite
« Reply #2 on: September 14, 2013, 11:11:32 pm »
Yes this was my first guess too, but afaik member variables are global for the class and don't get destroyed until the destructor gets called?

Here is the code that pruduces the behaviour for me: http://pastebin.com/WLqWnWue
Failing to succeed does not mean failing to progress!

Ixrec

  • Hero Member
  • *****
  • Posts: 1241
    • View Profile
    • Email
Re: texture from an image -> white sprite
« Reply #3 on: September 14, 2013, 11:35:08 pm »
I *think* you can fix this by using a vector of pointers to blocks instead of just a vector of blocks, though it's been a while since I had to debug texture scope so I may be wrong.

Geheim

  • Full Member
  • ***
  • Posts: 201
    • View Profile
    • Email
Re: texture from an image -> white sprite
« Reply #4 on: September 14, 2013, 11:40:45 pm »
Yes this does work, but can you explain why? I don't see a reason why just a normal vector shouldn't work too  :o
Failing to succeed does not mean failing to progress!

Ixrec

  • Hero Member
  • *****
  • Posts: 1241
    • View Profile
    • Email
Re: texture from an image -> white sprite
« Reply #5 on: September 15, 2013, 12:09:56 am »
Basically, the STL containers may move around the stuff inside them at any time.  I only learned about this when I found that gcc complained when I put const objects inside STL containers since it knew that was unsafe (VC++ allowed it for some reason).  Whether and when they actually do it is implementation-dependent.  So if you put pointers in there instead, the pointers will get moved around instead of the objects they point to.

You might be able to get the same effect by using pointers to Texture/Image/etc inside the Block class, but I do not fully understand the scope rules involved.  I just know adding more indirection/pointers tends to solve this kind of problem.

Geheim

  • Full Member
  • ***
  • Posts: 201
    • View Profile
    • Email
Re: texture from an image -> white sprite
« Reply #6 on: September 15, 2013, 12:20:12 am »
Hmm I still don't understand it, but thanks :)

You might be able to get the same effect by using pointers to Texture/Image/etc inside the Block class

Nope, I tried this, thats why it doesn't make sence to me  :-\
Failing to succeed does not mean failing to progress!

eXpl0it3r

  • SFML Team
  • Hero Member
  • *****
  • Posts: 11034
    • View Profile
    • development blog
    • Email
AW: texture from an image -> white sprite
« Reply #7 on: September 15, 2013, 01:25:18 am »
The issue here is that sf::Sprite keeps a reference to the texture, thus when copying the texture or moving its location, the reference will get invalid and the sprite shows white.
There are two ways to fix it.
1) Set the texture after your done copying.
2) Don't make/allow copies of the texture after you've set it.

What goes wrong in your code:
- When you push_back an object a copy will be made. With C++11 you can use emplace_back to prevent that.
- At "any" time you call push_back on a vector all its content might get moved. A different design for textures handling with e.g. a ResourceHolder that uses a std::map.
Official FAQ: https://www.sfml-dev.org/faq.php
Official Discord Server: https://discord.gg/nr4X7Fh
——————————————————————
Dev Blog: https://duerrenberger.dev/blog/

Geheim

  • Full Member
  • ***
  • Posts: 201
    • View Profile
    • Email
Re: texture from an image -> white sprite
« Reply #8 on: September 15, 2013, 09:48:07 am »
Alright this makes sence now. Thanks for the explanation!
Failing to succeed does not mean failing to progress!