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

Author Topic: Debugging a text problem - 'invisible' text  (Read 14589 times)

0 Members and 4 Guests are viewing this topic.

Laurent

  • Administrator
  • Hero Member
  • *****
  • Posts: 32498
    • View Profile
    • SFML's website
    • Email
Re: Debugging a text problem - 'invisible' text
« Reply #15 on: November 19, 2012, 09:01:10 pm »
Quote
GDebugger shows the glyphmap as invisible, as well as the saved image.

It's freetype.
Ah, ok.

But a simple code works, so we still don't know if:
- your code contains an undefined behaviour that somehow messes up the font's texture
- your code contains something unusual that exhibits a bug in FreeType

Until you succeed to reproduce it with a simple example, you can't send a bug report to anyone.
Laurent Gomila - SFML developer

Qix

  • Full Member
  • ***
  • Posts: 139
  • I am Qix!
    • View Profile
    • Natoga Technologies
Re: Debugging a text problem - 'invisible' text
« Reply #16 on: November 19, 2012, 09:40:12 pm »
Laurent, check the link I posted earlier. It's a simple example. The bug originally manifested in the full program, but the small-scale worked fine. Then after updating/building from source the small scale stopped working as well.

Already submitted a bug report, as suggested by the people in IRC.
« Last Edit: November 19, 2012, 09:58:38 pm by Qix »
~ Qix
Creator of Rippl Studio
Code: [Select]
<danharibo> iostream: I don't do enough drugs to think that's a good idea.

Laurent

  • Administrator
  • Hero Member
  • *****
  • Posts: 32498
    • View Profile
    • SFML's website
    • Email
Re: Debugging a text problem - 'invisible' text
« Reply #17 on: November 19, 2012, 10:41:57 pm »
Quote
Laurent, check the link I posted earlier. It's a simple example. The bug originally manifested in the full program, but the small-scale worked fine. Then after updating/building from source the small scale stopped working as well.
Sorry, I totally missed it.

But if it works with some graphics cards, how could it be FreeType? FreeType doesn't use the graphics card at all, it only generates pixels, and SFML copies them to a texture and draws them with OpenGL.
Laurent Gomila - SFML developer

Qix

  • Full Member
  • ***
  • Posts: 139
  • I am Qix!
    • View Profile
    • Natoga Technologies
Re: Debugging a text problem - 'invisible' text
« Reply #18 on: November 19, 2012, 10:58:03 pm »
There is an ATI card where it works. I don't know, I'm so confused as to why it's working on some and not others - I knew that freetype loads the pixel data and that's it; has nothing to do with the graphics card.

Which is why this is so confusing. I would copy the build onto multiple computers and some would work and some wouldn't. All up to date graphics drivers. The loaded texture would be transparent on some and work on the others. Images worked on all of them, however.

I'm trying to build with the trace/error macros enabled on freetype (as they suggested in the bug report I sent off over there) - however, the entire library is a mess and it is requiring a ton of hacks just to get them to work.
~ Qix
Creator of Rippl Studio
Code: [Select]
<danharibo> iostream: I don't do enough drugs to think that's a good idea.

Laurent

  • Administrator
  • Hero Member
  • *****
  • Posts: 32498
    • View Profile
    • SFML's website
    • Email
Re: Debugging a text problem - 'invisible' text
« Reply #19 on: November 19, 2012, 11:09:48 pm »
Quote
I'm trying to build with the trace/error macros enabled on freetype
Don't bother with that, just save the glyphs bitmaps directly to a file (before they are copied to the texture) and you'll see that they are all generated correctly.

At line 474 of Font.cpp, insert something that creates a sf::Image from &m_pixelBuffer[0], w, and h, and save it to a file (a different one for each call).

Trust me, this is most likely a driver bug, there were a lot of similar problems with AMD drivers recently. Look at which version of the driver the working computers use, and try the same version on yours.
Laurent Gomila - SFML developer

Qix

  • Full Member
  • ***
  • Posts: 139
  • I am Qix!
    • View Profile
    • Natoga Technologies
Re: Debugging a text problem - 'invisible' text
« Reply #20 on: November 19, 2012, 11:18:08 pm »
I will do that now.

Trust me, this is most likely a driver bug, there were a lot of similar problems with AMD drivers recently. Look at which version of the driver the working computers use, and try the same version on yours.

I did ;) There was another thread I think I mentioned earlier that said to upgrade to the .12 beta catalyst drivers. I did that; no beans.
~ Qix
Creator of Rippl Studio
Code: [Select]
<danharibo> iostream: I don't do enough drugs to think that's a good idea.

Laurent

  • Administrator
  • Hero Member
  • *****
  • Posts: 32498
    • View Profile
    • SFML's website
    • Email
Re: Debugging a text problem - 'invisible' text
« Reply #21 on: November 19, 2012, 11:29:02 pm »
I was more thinking about an older version of the driver.
Laurent Gomila - SFML developer

Qix

  • Full Member
  • ***
  • Posts: 139
  • I am Qix!
    • View Profile
    • Natoga Technologies
Re: Debugging a text problem - 'invisible' text
« Reply #22 on: November 19, 2012, 11:32:37 pm »
I did what you said to do (put that image save in loadGlyph) and just to make sure I set a breakpoint. It never gets called.

Scratch that, I realize why it's not. I'll post back with the images in a sec.
« Last Edit: November 19, 2012, 11:40:06 pm by Qix »
~ Qix
Creator of Rippl Studio
Code: [Select]
<danharibo> iostream: I don't do enough drugs to think that's a good idea.

Qix

  • Full Member
  • ***
  • Posts: 139
  • I am Qix!
    • View Profile
    • Natoga Technologies
Re: Debugging a text problem - 'invisible' text
« Reply #23 on: November 19, 2012, 11:59:52 pm »
The sizes are right, the images are still transparent.

        // Write the pixels to the texture
        unsigned int x = glyph.textureRect.left + padding;
        unsigned int y = glyph.textureRect.top + padding;
        unsigned int w = glyph.textureRect.width - 2 * padding;
        unsigned int h = glyph.textureRect.height - 2 * padding;
               
                // DEBUG
                sf::Image img;
                img.create(w, h, &m_pixelBuffer[0]);
                std::stringstream ss;
                ss << "dbg_pxlbuf_save_" << _saveCount << ".png";
                if(!img.saveToFile(ss.str().c_str()))
                        printf("WARNING: Could not save debug pixel buffer to file\n");
                ++_saveCount;

        page.texture.update(&m_pixelBuffer[0], w, h, x, y);
 

[attachment deleted by admin]
~ Qix
Creator of Rippl Studio
Code: [Select]
<danharibo> iostream: I don't do enough drugs to think that's a good idea.

Qix

  • Full Member
  • ***
  • Posts: 139
  • I am Qix!
    • View Profile
    • Natoga Technologies
Re: Debugging a text problem - 'invisible' text
« Reply #24 on: November 20, 2012, 12:26:11 am »
Raw pixel data for those is attached. I'm not sure of the format of the raws so photoshop is just spitting out garbage, but maybe they can be of use.

This is a file being opened and writing &m_pixelBuffer[0] (with size = m_pixelBuffer.size()).

[attachment deleted by admin]
« Last Edit: November 20, 2012, 12:28:10 am by Qix »
~ Qix
Creator of Rippl Studio
Code: [Select]
<danharibo> iostream: I don't do enough drugs to think that's a good idea.

Laurent

  • Administrator
  • Hero Member
  • *****
  • Posts: 32498
    • View Profile
    • SFML's website
    • Email
Re: Debugging a text problem - 'invisible' text
« Reply #25 on: November 20, 2012, 07:58:42 am »
Quote
The sizes are right, the images are still transparent.
Hmm? Did you use the image preview of Windows explorer to watch them? ;D
They are perfectly fine, I can see that the glyphs are 'T, 'e', s', and 't'.
Laurent Gomila - SFML developer

Qix

  • Full Member
  • ***
  • Posts: 139
  • I am Qix!
    • View Profile
    • Natoga Technologies
Re: Debugging a text problem - 'invisible' text
« Reply #26 on: November 20, 2012, 10:19:36 pm »
Yes laurent... Then why can't I see them?

EDIT: FFS screen brightness was too high. Alright, so it's not freetype.

If images load in fine, why aren't these working? No matter the background color, they won't display. Lua is reporting their bounds to be fine, so it's not a polygon thing as far as I can tell. Further, there aren't any incorrect things in sf::Text such as the vertices being defined backwards... Images work, so should Text >.>
« Last Edit: November 20, 2012, 10:28:23 pm by Qix »
~ Qix
Creator of Rippl Studio
Code: [Select]
<danharibo> iostream: I don't do enough drugs to think that's a good idea.

Laurent

  • Administrator
  • Hero Member
  • *****
  • Posts: 32498
    • View Profile
    • SFML's website
    • Email
Re: Debugging a text problem - 'invisible' text
« Reply #27 on: November 20, 2012, 10:28:54 pm »
Driver issue :P
Laurent Gomila - SFML developer

Qix

  • Full Member
  • ***
  • Posts: 139
  • I am Qix!
    • View Profile
    • Natoga Technologies
Re: Debugging a text problem - 'invisible' text
« Reply #28 on: November 20, 2012, 10:33:29 pm »
Driver issue :P

But that makes no sense if images can be loaded/displayed just fine. Aren't image textures the SAME THING as text textures?
« Last Edit: November 20, 2012, 10:36:12 pm by Qix »
~ Qix
Creator of Rippl Studio
Code: [Select]
<danharibo> iostream: I don't do enough drugs to think that's a good idea.

Laurent

  • Administrator
  • Hero Member
  • *****
  • Posts: 32498
    • View Profile
    • SFML's website
    • Email
Re: Debugging a text problem - 'invisible' text
« Reply #29 on: November 20, 2012, 10:41:43 pm »
They are. But the context in which they are used is different. And it's enough to exhibit a strange driver bug. Don't try to understand, there's nothing to understand. Graphics driver bugs are mystical, don't expect something obvious such as "texturing is broken", it's much more subtle.
Laurent Gomila - SFML developer