tags:

views:

111

answers:

1

I have a fairly large application that uses WPF for its user interface. I recently found an unusual defect regarding 3D screensavers. The 3D screensavers 3D FlowerBox,3D Flying Objects,3D Pipes,3D Text causes 1 of my WPF windows to disappear when the screensaver activates. Other screensavers are fine.

My application only encounters this problem on Windows XP.

I have some experience with DirectX. When a 3D screensavers activates, the d3d device context will be switched to exclusive mode. I reckon that WPF has trouble restoring the device context when the device switches back to cooperative mode (hence why its only affecting windows XP)

Has anyone seen such a scenario occur before ? Is there a remedy for the problem ?

Windows XP SP3, DirectX 9.0c, .NET 3.5

A: 

Not that exact one, but I have definitely seen strange problems with WPF and Windows XP, especially. The easy thing to say would be that you should try to move to Windows 7 ASAP, but then I would just be a jerk.

First off, check your video device driver. We've had a lot of problems with WPF on XP when an old graphics cards' device drivers are used. Update it to the latest version. That could take care of it.

If that doesn't work, and if you can, try swapping the video card for a different brand. That, too may work (though highly undesirable).

Third -- is your window semi-transparent or non-rectangular? If you switch your WPF app to be a regular, rectangular, boring, ugly Windows XP window, we've found that a lot of these quirks went away when we stopped getting fancy with our main windows. My guess is that it has something to do with the fact that XP has no desktop window manager. But then again I don't really know.

I know this is all very unsatisfying. We've had stuff like this happen to us on XP. I'm praying for our IT department to be able to move us to 7 this year...

Dave Markle
Thanks for the reply. The window which disappears is transparent and non-rectangular. The windows which dont disappear is rectangular and solid. I am now trying to tap into the messageloop and find the messages that indicate a screensaver has been activated. I will try InvalidateVisual when the screensaver has closed. My application runs primarily on windows 2008 server or windows 7, but we have some old diehard customers which love windows XP.
Andrew Keith
Yeah, you may want to consider degrading the app to just show that window in an ugly boring window for your XP customers. You could tell them that it "works" for them, but if they want the full experience, to upgrade to Windows 7. Painful.
Dave Markle
I solved the problem by removing transparency for windows XP users. I reckon its time for them to upgrade anyway.
Andrew Keith