#include "wx/dcclient.h"
-//-----------------------------------------------------------------------------
-// classes
-//-----------------------------------------------------------------------------
-
-class wxScreenDC;
-
//-----------------------------------------------------------------------------
// wxScreenDC
//-----------------------------------------------------------------------------
-class wxScreenDC: public wxPaintDC
+#if wxUSE_NEW_DC
+class WXDLLIMPEXP_CORE wxGTKScreenImplDC : public wxGTKWindowImplDC
+#else
+#define wxGTKScreenImplDC wxScreenDC
+class WXDLLIMPEXP_CORE wxScreenDC : public wxWindowDC
+#endif
{
- DECLARE_DYNAMIC_CLASS(wxScreenDC)
-
public:
- wxScreenDC();
- ~wxScreenDC();
- static bool StartDrawingOnTop( wxWindow *window );
- static bool StartDrawingOnTop( wxRect *rect = (wxRect *) NULL );
- static bool EndDrawingOnTop();
+#if wxUSE_NEW_DC
+ wxGTKScreenImplDC( wxScreenDC *owner );
+#else
+ wxScreenDC();
+#endif
- // implementation
+ ~wxGTKScreenImplDC();
- static GdkWindow *sm_overlayWindow;
- static int sm_overlayWindowX;
- static int sm_overlayWindowY;
-};
+ static bool StartDrawingOnTop(wxWindow * WXUNUSED(window))
+ { return true; }
+ static bool StartDrawingOnTop(wxRect * WXUNUSED(rect) = NULL)
+ { return true; }
+ static bool EndDrawingOnTop() { return true; }
-#endif
- // __GTKDCSCREENH__
+protected:
+ virtual void DoGetSize(int *width, int *height) const;
+
+ void Init();
+
+private:
+ DECLARE_ABSTRACT_CLASS(wxGTKScreenImplDC)
+};
+
+#endif // __GTKDCSCREENH__