1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: SWIG interface for wxVideoMode and wxDisplay
9 // Copyright: (c) 2004 by Total Control Software
10 // Licence: wxWindows license
11 /////////////////////////////////////////////////////////////////////////////
16 //---------------------------------------------------------------------------
19 #include <wx/display.h>
23 //---------------------------------------------------------------------------
28 "A simple struct containing video mode parameters for a display", "");
32 wxVideoMode(int width = 0, int height = 0, int depth = 0, int freq = 0);
36 bool , Matches(const wxVideoMode& other) const,
37 "Returns True if this mode matches the other one in the sense that all
38 non-zero fields of the other mode have the same value in this
39 one (except for refresh which is allowed to have a greater value)", "");
42 int , GetWidth() const,
43 "Returns the screen width in pixels (e.g. 640*480), 0 means unspecified", "");
46 int , GetHeight() const,
47 "Returns the screen height in pixels (e.g. 640*480), 0 means unspecified", "");
50 int , GetDepth() const,
51 "Returns the screen's bits per pixel (e.g. 32), 1 is monochrome and 0
52 means unspecified/known", "");
57 "returns true if the object has been initialized", "");
60 %pythoncode { def __nonzero__(self): return self.IsOk() }
62 bool __eq__(const wxVideoMode* other) { return other ? (*self == *other) : false; }
63 bool __ne__(const wxVideoMode* other) { return other ? (*self != *other) : true; }
67 // the screen size in pixels (e.g. 640*480), 0 means unspecified
70 // bits per pixel (e.g. 32), 1 is monochrome and 0 means unspecified/known
73 // refresh frequency in Hz, 0 means unspecified/unknown
80 const wxVideoMode wxDefaultVideoMode;
85 const wxVideoMode wxDefaultVideoMode;
89 //---------------------------------------------------------------------------
94 "Represents a display/monitor attached to the system", "");
99 wxDisplay(size_t index = 0),
100 "Set up a Display instance with the specified display. The displays
101 are numbered from 0 to GetCount() - 1, 0 is always the primary display
102 and the only one which is always supported", "");
107 static size_t , GetCount(),
108 "Return the number of available displays.", "");
111 static int , GetFromPoint(const wxPoint& pt),
112 "Find the display where the given point lies, return wx.NOT_FOUND if it
113 doesn't belong to any display", "");
115 DocStr(GetFromWindow,
116 "Find the display where the given window lies, return wx.NOT_FOUND if
117 it is not shown at all.", "");
119 static int GetFromWindow(wxWindow *window);
124 "Return true if the object was initialized successfully", "");
125 %pythoncode { def __nonzero__(self): return self.IsOk() }
128 wxRect , GetGeometry() const,
129 "Returns the bounding rectangle of the display whose index was passed
130 to the constructor.", "");
133 wxRect , GetClientArea() const,
134 "Returns the bounding rectangle the client area of the display,
135 i.e., without taskbars and such.", "");
138 wxString , GetName() const,
139 "Returns the display's name. A name is not available on all platforms.", "");
142 bool , IsPrimary() const,
143 "Returns True if the display is the primary display. The primary
144 display is the one whose index is 0.", "");
150 "GetModes(VideoMode mode=DefaultVideoMode) -> [videoMode...]",
151 "Enumerate all video modes supported by this display matching the given
152 one (in the sense of VideoMode.Match()).
154 As any mode matches the default value of the argument and there is
155 always at least one video mode supported by display, the returned
156 array is only empty for the default value of the argument if this
157 function is not supported at all on this platform.", "");
159 PyObject* GetModes(const wxVideoMode& mode = wxDefaultVideoMode)
162 PyObject* pyList = NULL;
163 wxArrayVideoModes arr = self->GetModes(mode);
164 wxPyBlock_t blocked = wxPyBeginBlockThreads();
165 pyList = PyList_New(0);
166 for (size_t i=0; i < arr.GetCount(); i++)
168 wxVideoMode* m = new wxVideoMode(arr.Item(i));
169 PyObject* pyObj = wxPyConstructObject(m, wxT("wxVideoMode"), true);
170 PyList_Append(pyList, pyObj);
173 wxPyEndBlockThreads(blocked);
176 wxPyRaiseNotImplemented();
181 DocStr(GetCurrentMode,
182 "Get the current video mode.", "");
183 wxVideoMode GetCurrentMode() const
186 return self->GetCurrentMode();
188 wxPyRaiseNotImplemented();
189 return wxDefaultVideoMode;
196 "Changes the video mode of this display to the mode specified in the
199 If wx.DefaultVideoMode is passed in as the mode parameter, the defined
200 behaviour is that wx.Display will reset the video mode to the default
201 mode used by the display. On Windows, the behavior is normal.
202 However, there are differences on other platforms. On Unix variations
203 using X11 extensions it should behave as defined, but some
204 irregularities may occur.
206 On wxMac passing in wx.DefaultVideoMode as the mode parameter does
207 nothing. This happens because Carbon no longer has access to
208 DMUseScreenPrefs, an undocumented function that changed the video mode
209 to the system default by using the system's 'scrn' resource.
211 Returns True if succeeded, False otherwise", "");
213 bool ChangeMode(const wxVideoMode& mode = wxDefaultVideoMode)
216 return self->ChangeMode(mode);
218 wxPyRaiseNotImplemented();
226 "Restore the default video mode (just a more readable synonym)", "");
232 wxPyRaiseNotImplemented();
238 %property(ClientArea, GetClientArea, doc="See `GetClientArea`");
239 %property(CurrentMode, GetCurrentMode, doc="See `GetCurrentMode`");
240 %property(Geometry, GetGeometry, doc="See `GetGeometry`");
241 %property(Modes, GetModes, doc="See `GetModes`");
242 %property(Name, GetName, doc="See `GetName`");
246 //---------------------------------------------------------------------------