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 width in pixels (e.g. 640*480), 0 means
51 int , GetDepth() const,
52 "Returns the screen's bits per pixel (e.g. 32), 1 is monochrome and 0
53 means unspecified/known", "");
58 "returns true if the object has been initialized", "");
62 %pythoncode { def __nonzero__(self): return self.IsOk() }
64 bool __eq__(const wxVideoMode* other) { return other ? (*self == *other) : false; }
65 bool __ne__(const wxVideoMode* other) { return other ? (*self != *other) : true; }
69 // the screen size in pixels (e.g. 640*480), 0 means unspecified
72 // bits per pixel (e.g. 32), 1 is monochrome and 0 means unspecified/known
75 // refresh frequency in Hz, 0 means unspecified/unknown
82 const wxVideoMode wxDefaultVideoMode;
87 const wxVideoMode wxDefaultVideoMode;
91 //---------------------------------------------------------------------------
97 "Represents a display/monitor attached to the system", "");
103 wxDisplay(size_t index = 0),
104 "Set up a Display instance with the specified display. The displays
105 are numbered from 0 to GetCount() - 1, 0 is always the primary display
106 and the only one which is always supported", "");
111 static size_t , GetCount(),
112 "Return the number of available displays.", "");
116 static int , GetFromPoint(const wxPoint& pt),
117 "Find the display where the given point lies, return wx.NOT_FOUND if it
118 doesn't belong to any display", "");
121 DocStr(GetFromWindow,
122 "Find the display where the given window lies, return wx.NOT_FOUND if
123 it is not shown at all.", "");
124 static int GetFromWindow(wxWindow *window);
129 "Return true if the object was initialized successfully", "");
130 %pythoncode { def __nonzero__(self): return self.IsOk() }
134 wxRect , GetGeometry() const,
135 "Returns the bounding rectangle of the display whose index was passed
136 to the constructor.", "");
140 wxRect , GetClientArea() const,
141 "Get the client area of the display, i.e. without taskbars and such", "");
146 wxString , GetName() const,
147 "Returns the display's name. A name is not available on all platforms.", "");
151 bool , IsPrimary() const,
152 "Returns true if the display is the primary display. The primary
153 display is the one whose index is 0.", "");
159 "GetModes(VideoMode mode=DefaultVideoMode) -> [videoMode...]",
160 "Enumerate all video modes supported by this display matching the given
161 one (in the sense of VideoMode.Match()).
163 As any mode matches the default value of the argument and there is
164 always at least one video mode supported by display, the returned
165 array is only empty for the default value of the argument if this
166 function is not supported at all on this platform.", "");
168 PyObject* GetModes(const wxVideoMode& mode = wxDefaultVideoMode) {
170 PyObject* pyList = NULL;
171 wxArrayVideoModes arr = self->GetModes(mode);
172 wxPyBlock_t blocked = wxPyBeginBlockThreads();
173 pyList = PyList_New(0);
174 for (int i=0; i < arr.GetCount(); i++) {
175 wxVideoMode* m = new wxVideoMode(arr.Item(i));
176 PyObject* pyObj = wxPyConstructObject(m, wxT("wxVideoMode"), true);
177 PyList_Append(pyList, pyObj);
180 wxPyEndBlockThreads(blocked);
183 wxPyRaiseNotImplemented();
188 DocStr(GetCurrentMode,
189 "Get the current video mode.", "");
190 wxVideoMode GetCurrentMode() const {
192 return self->GetCurrentMode();
194 wxPyRaiseNotImplemented();
195 return wxDefaultVideoMode;
202 "Changes the video mode of this display to the mode specified in the
205 If wx.DefaultVideoMode is passed in as the mode parameter, the defined
206 behaviour is that wx.Display will reset the video mode to the default
207 mode used by the display. On Windows, the behavior is normal.
208 However, there are differences on other platforms. On Unix variations
209 using X11 extensions it should behave as defined, but some
210 irregularities may occur.
212 On wxMac passing in wx.DefaultVideoMode as the mode parameter does
213 nothing. This happens because Carbon no longer has access to
214 DMUseScreenPrefs, an undocumented function that changed the video mode
215 to the system default by using the system's 'scrn' resource.
217 Returns True if succeeded, False otherwise", "");
219 bool ChangeMode(const wxVideoMode& mode = wxDefaultVideoMode) {
221 return self->ChangeMode(mode);
223 wxPyRaiseNotImplemented();
232 "Restore the default video mode (just a more readable synonym)", "");
237 wxPyRaiseNotImplemented();
244 //---------------------------------------------------------------------------