VRAM textures blacking out? Whaaaaat
Blitz3D Forums/Blitz3D Programming/VRAM textures blacking out? Whaaaaat
| ||
Alright, so. I'm guessing this is a DX issue as usual, but I'd like to be sure, and know if there's anything I can do to prevent it. Thanks to my beta testers, I discovered recently that when a texture is loaded with flag 256 to store in VRAM for fast access, it blacks out if the player alt+tabs out of the game while it's in fullscreen. The textures are still THERE, and they're perfectly usable and able to be drawn to; it's just that all their existing pixel data has been "zeroed." Have some code: The above program is entirely self-contained. Here's what happens when I run it: The cube on the left, with the red cross, is painted with a normal texture stored in RAM (or wherever Blitz puts textures by default). The cube on the right, with the green ovoid star, is given a flag 256 texture stored in VRAM. The textures' flags are otherwise identical, 16 and 32 to lock prevent their UV from wrapping around. Now here's what happens after alt+tabbing out of the program, and back in again: So, obviously, there are ways to SOLVE this, especially since the textures can still be used and draw to. For my own reasons, however, I would like to know first WHY this happens, and if there is a simple way to prevent it happening at all. Last edited 2011 Last edited 2011 Last edited 2011 |
| ||
It's probably because your forcing the texture to stay in VRAM and VRAM is being wiped, or unallocated. Everything you load in blitz, is also stored in RAM, according to my tests I did a while back. |
| ||
Thing is, VRAM storage is necessary if you're going to draw to a texture from time to time, at least if you want it happening in realtime. There are a few textures in my game that get drawn to in this way, and WHEN they're drawn to it's fine, but I need them to NOT black out if the player alt-tabs. |
| ||
This has always been the case with Blitz3D for as long as I remember. As far as I know there is nothing you can do about it - a problem which rules Blitz3D games out of getting on most portals, as they normally insist that the game continues to work after alt/tab. As a long shot, that FastExt thing people keep going on about might help. It seems to solve every other Blitz3D shortfall. |
| ||
You could redesign your game so that all of your texture fit into one of two clearly-separated groups: static textures, which are considered "safe", and dynamic textures, used for drawing and copying (I have the feeling that this clear separation was intended or at least expected by Mark, hence the bug). Most dynamic textures will be being updated every frame, so this bug should hopefully not be noticeable. In those cases where a texture is updated sometimes-but-not-often, consider having two; a VRAM texture to use while the texture is in the process of changing, and a regular texture to copy the frozen buffer to once the image has stopped moving. Assuming that while the image is changing it will be immune to Alt+Tab (simply by virtue of being refilled next frame), this should solve most of the problem if it's not a major speed hit to occasionally do a CopyRect to a non-VRAM texture - if this only happens every few seconds and you have tweening enabled, the player won't notice. You'd need to have some kind of extra state flags attached to your game props to signify which texture is in use and when to change them... shouldn't be too complicated. |
| ||
Not sure if the BufferDirty command is at all useful here, think its really for 2D images stored in system RAM. You can probably use the GraphicsLost command tho to reload the engine when this happens. |
| ||
Alright, good to know it's just there, period; Yasha's solution is more or less what I was thinking of doing, so I'll just go ahead and fiddle it in. I'm mildly surprised about the Alt+Tab business, tbh; I always game in fullscreen, and had to learn the hard way not to Alt+Tab out of it since about half of my games from Valve themselves would crash if I did so. I believe L4D was one of 'em. Might have just been an issue with my graphics drivers though, I dunno. Anyway, thanks for clearing this up, guys! |
| ||
Quite a lot of games don't like alt-tab even in this day and age. Source games will eventually have problems, sometimes a solid or tiled purple stage on certain shaders, sometimes crashes. Test Drive Unlimited 2 will randomly stall on a blackscreen (sometimes recovering after 30 seconds). And so on. Last edited 2011 |
| ||
Yeah, that's what I've experienced... Still, quality control is quality control. Honestly I'm mildly disgusted with myself for trying to brush off the Alt+Tab business without looking into other, clever (or more laborious) solutions; "good enough" should never be good enough! |