git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@36360
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
- Native wxCheckListBox implementation.
- All wxTopLevelWindows resizes accordingly to SIP visibility.
- ::wxGetUserName() implemented.
- Native wxCheckListBox implementation.
- All wxTopLevelWindows resizes accordingly to SIP visibility.
- ::wxGetUserName() implemented.
+- wxDisplay enumeration support.
#undef wxUSE_DRAG_AND_DROP
#define wxUSE_DRAG_AND_DROP 0
#undef wxUSE_DRAG_AND_DROP
#define wxUSE_DRAG_AND_DROP 0
-#undef wxUSE_DYNAMIC_LOADER
-#define wxUSE_DYNAMIC_LOADER 0
-
#undef wxUSE_FSVOLUME
#define wxUSE_FSVOLUME 0
#undef wxUSE_FSVOLUME
#define wxUSE_FSVOLUME 0
#error "To compile this sample you must build the library with wxUSE_DISPLAY set to 1"
#endif
#error "To compile this sample you must build the library with wxUSE_DISPLAY set to 1"
#endif
-#include "wx/notebook.h"
+#include "wx/bookctrl.h"
wxString VideoModeToText(const wxVideoMode& mode);
// GUI controls
wxString VideoModeToText(const wxVideoMode& mode);
// GUI controls
- wxNotebook *m_notebook;
// any class wishing to process wxWidgets events must use this macro
DECLARE_EVENT_TABLE()
// any class wishing to process wxWidgets events must use this macro
DECLARE_EVENT_TABLE()
- Display_Quit = 1,
-
- Display_FromPoint,
+ Display_FromPoint = wxID_HIGHEST + 1,
Display_FullScreen,
// controls
Display_FullScreen,
// controls
- Display_ChangeMode = 1000,
Display_ResetMode,
Display_CurrentMode,
Display_ResetMode,
Display_CurrentMode,
// it is important for the id corresponding to the "About" command to have
// this standard value as otherwise it won't be handled properly under Mac
// (where it is special and put into the "Apple" menu)
// it is important for the id corresponding to the "About" command to have
// this standard value as otherwise it won't be handled properly under Mac
// (where it is special and put into the "Apple" menu)
+ Display_Quit = wxID_EXIT,
Display_About = wxID_ABOUT
};
Display_About = wxID_ABOUT
};
wxPanel *panel = new wxPanel(this, wxID_ANY);
wxPanel *panel = new wxPanel(this, wxID_ANY);
- m_notebook = new wxNotebook(panel, wxID_ANY);
+ m_book = new wxBookCtrl(panel, wxID_ANY);
const size_t count = wxDisplay::GetCount();
for ( size_t nDpy = 0; nDpy < count; nDpy++ )
{
wxDisplay display(nDpy);
const size_t count = wxDisplay::GetCount();
for ( size_t nDpy = 0; nDpy < count; nDpy++ )
{
wxDisplay display(nDpy);
- wxWindow *page = new wxPanel(m_notebook, wxID_ANY);
+ wxWindow *page = new wxPanel(m_book, wxID_ANY);
// create 2 column flex grid sizer with growable 2nd column
wxFlexGridSizer *sizer = new wxFlexGridSizer(2, 10, 20);
// create 2 column flex grid sizer with growable 2nd column
wxFlexGridSizer *sizer = new wxFlexGridSizer(2, 10, 20);
0, wxALL | wxCENTRE, 5);
page->SetSizer(sizerTop);
0, wxALL | wxCENTRE, 5);
page->SetSizer(sizerTop);
- m_notebook->AddPage(page,
- wxString::Format(_T("Display %lu"),
- (unsigned long)nDpy));
+ m_book->AddPage(page,
+ wxString::Format(_T("Display %lu"),
+ (unsigned long)nDpy));
}
wxBoxSizer *sizer = new wxBoxSizer(wxHORIZONTAL);
}
wxBoxSizer *sizer = new wxBoxSizer(wxHORIZONTAL);
- sizer->Add(m_notebook, 1, wxEXPAND);
+ sizer->Add(m_book, 1, wxEXPAND);
panel->SetSizer(sizer);
sizer->Fit(this);
sizer->SetSizeHints(this);
panel->SetSizer(sizer);
sizer->Fit(this);
sizer->SetSizeHints(this);
void MyFrame::OnChangeMode(wxCommandEvent& event)
{
void MyFrame::OnChangeMode(wxCommandEvent& event)
{
- wxDisplay dpy(m_notebook->GetSelection());
+ wxDisplay dpy(m_book->GetSelection());
// you wouldn't write this in real code, would you?
if ( !dpy.ChangeMode(((MyVideoModeClientData *)
// you wouldn't write this in real code, would you?
if ( !dpy.ChangeMode(((MyVideoModeClientData *)
void MyFrame::OnResetMode(wxCommandEvent& WXUNUSED(event))
{
void MyFrame::OnResetMode(wxCommandEvent& WXUNUSED(event))
{
- wxDisplay dpy(m_notebook->GetSelection());
+ wxDisplay dpy(m_book->GetSelection());
void MyFrame::OnDisplayChanged(wxDisplayChangedEvent& event)
{
// update the current mode text
void MyFrame::OnDisplayChanged(wxDisplayChangedEvent& event)
{
// update the current mode text
- for ( size_t n = 0; n < m_notebook->GetPageCount(); n++ )
+ for ( size_t n = 0; n < m_book->GetPageCount(); n++ )
- wxStaticText *label = wxDynamicCast(m_notebook->GetPage(n)->
+ wxStaticText *label = wxDynamicCast(m_book->GetPage(n)->
FindWindow(Display_CurrentMode),
wxStaticText);
if ( label )
FindWindow(Display_CurrentMode),
wxStaticText);
if ( label )
/////////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////////
+// Name: src/msw/display.cpp
// Purpose: MSW Implementation of wxDisplay class
// Author: Royce Mitchell III
// Modified by: VZ (resolutions enumeration/change support, DirectDraw, ...)
// Purpose: MSW Implementation of wxDisplay class
// Author: Royce Mitchell III
// Modified by: VZ (resolutions enumeration/change support, DirectDraw, ...)
-// Ryan Norton (IsPrimary override)
+// Ryan Norton (IsPrimary override)
// Created: 06/21/02
// RCS-ID: $Id$
// Copyright: (c) wxWidgets team
// Created: 06/21/02
// RCS-ID: $Id$
// Copyright: (c) wxWidgets team
// with mingw32, we must include windows.h first and it doesn't hurt with other
// compilers
// with mingw32, we must include windows.h first and it doesn't hurt with other
// compilers
+#include "wx/msw/wrapwin.h"
+#ifndef __WXWINCE__
+ #include <multimon.h>
+#endif // !__WXWINCE__
#ifdef _MSC_VER
#pragma warning(default:4706)
#ifdef _MSC_VER
#pragma warning(default:4706)
dm.dmDisplayFrequency > 1 ? dm.dmDisplayFrequency : 0);
}
dm.dmDisplayFrequency > 1 ? dm.dmDisplayFrequency : 0);
}
// emulation of ChangeDisplaySettingsEx() for Win95
LONG WINAPI ChangeDisplaySettingsExForWin95(LPCTSTR WXUNUSED(lpszDeviceName),
LPDEVMODE lpDevMode,
// emulation of ChangeDisplaySettingsEx() for Win95
LONG WINAPI ChangeDisplaySettingsExForWin95(LPCTSTR WXUNUSED(lpszDeviceName),
LPDEVMODE lpDevMode,
{
return ::ChangeDisplaySettings(lpDevMode, dwFlags);
}
{
return ::ChangeDisplaySettings(lpDevMode, dwFlags);
}
// ----------------------------------------------------------------------------
// wxDisplayModule
// ----------------------------------------------------------------------------
// wxDisplayModule
//RN: FIXME: This is wrong - the display info array should reload after every call
//to GetCount() - otherwise it will not be accurate.
//The user can change the number of displays in display properties/settings
//RN: FIXME: This is wrong - the display info array should reload after every call
//to GetCount() - otherwise it will not be accurate.
//The user can change the number of displays in display properties/settings
- //after GetCount or similar is called and really mess this up...
+ //after GetCount or similar is called and really mess this up...
//wxASSERT_MSG( gs_displays->GetCount() == (size_t)::GetSystemMetrics(SM_CMONITORS),
// _T("So how many displays does this system have?") );
//wxASSERT_MSG( gs_displays->GetCount() == (size_t)::GetSystemMetrics(SM_CMONITORS),
// _T("So how many displays does this system have?") );
+#ifdef __WXWINCE__
+ flags = 0;
+#else // !__WXWINCE__
+#endif // __WXWINCE__/!__WXWINCE__
}
//else: huh, no user32.dll??
}
//else: huh, no user32.dll??
if ( !pfnChangeDisplaySettingsEx )
{
// we must be under Win95 and so there is no multiple monitors
// support anyhow
pfnChangeDisplaySettingsEx = ChangeDisplaySettingsExForWin95;
}
if ( !pfnChangeDisplaySettingsEx )
{
// we must be under Win95 and so there is no multiple monitors
// support anyhow
pfnChangeDisplaySettingsEx = ChangeDisplaySettingsExForWin95;
}