X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/8b9d7133f9520f76f87dd27bffc30235c4933c9f..841f23e18a9d9e3d987b60422c3a220571868337:/samples/splash/splash.cpp?ds=sidebyside diff --git a/samples/splash/splash.cpp b/samples/splash/splash.cpp index cd7c2ad931..9fe6957fe7 100644 --- a/samples/splash/splash.cpp +++ b/samples/splash/splash.cpp @@ -32,6 +32,7 @@ #include "wx/image.h" #include "wx/splash.h" +#include "wx/mediactrl.h" // ---------------------------------------------------------------------------- // resources @@ -43,6 +44,10 @@ #include "../sample.xpm" #endif +// for smartphone, pda and other small screens use resized embedded image +// instead of full colour png dedicated to desktops +#include "mobile.xpm" + // ---------------------------------------------------------------------------- // private classes // ---------------------------------------------------------------------------- @@ -71,6 +76,8 @@ public: void OnQuit(wxCommandEvent& event); void OnAbout(wxCommandEvent& event); + bool m_isPda; + private: // any class wishing to process wxWidgets events must use this macro DECLARE_EVENT_TABLE() @@ -118,19 +125,27 @@ bool MyApp::OnInit() { wxImage::AddHandler(new wxPNGHandler); + // create the main application window + MyFrame *frame = new MyFrame(_T("wxSplashScreen sample application")); + wxBitmap bitmap; - if (bitmap.LoadFile(_T("splash.png"), wxBITMAP_TYPE_PNG)) + + if (frame->m_isPda) + bitmap = wxBitmap(mobile_xpm); + + bool ok = frame->m_isPda + ? bitmap.Ok() + : bitmap.LoadFile(_T("splash.png"), wxBITMAP_TYPE_PNG); + + if (ok) { - wxSplashScreen* splash = new wxSplashScreen(bitmap, + new wxSplashScreen(bitmap, wxSPLASH_CENTRE_ON_SCREEN|wxSPLASH_TIMEOUT, - 6000, NULL, wxID_ANY, wxDefaultPosition, wxDefaultSize, + 6000, frame, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxSIMPLE_BORDER|wxSTAY_ON_TOP); } wxYield(); - // create the main application window - MyFrame *frame = new MyFrame(_T("wxSplashScreen sample application")); - // and show it (the frames, unlike simple controls, are not shown when // created initially) frame->Show(true); @@ -149,6 +164,8 @@ bool MyApp::OnInit() MyFrame::MyFrame(const wxString& title) : wxFrame(NULL, wxID_ANY, title) { + m_isPda = (wxSystemSettings::GetScreenType() <= wxSYS_SCREEN_PDA); + // set the frame icon SetIcon(wxICON(sample)); @@ -158,7 +175,7 @@ MyFrame::MyFrame(const wxString& title) // the "About" item should be in the help menu wxMenu *helpMenu = new wxMenu; - helpMenu->Append(wxID_ABOUT, _T("&About...\tF1"), _T("Show about dialog")); + helpMenu->Append(wxID_ABOUT, _T("&About...\tF1"), _T("Show about frame")); menuFile->Append(wxID_EXIT, _T("E&xit\tAlt-X"), _T("Quit this program")); @@ -189,9 +206,41 @@ void MyFrame::OnQuit(wxCommandEvent& WXUNUSED(event)) void MyFrame::OnAbout(wxCommandEvent& WXUNUSED(event)) { - wxString msg; - msg.Printf( _T("This is the About dialog of the wxSplashScreen sample.\n") - _T("Welcome to %s"), wxVERSION_STRING); + wxBitmap bitmap; + + if (m_isPda) bitmap = wxBitmap(mobile_xpm); + + bool ok = m_isPda + ? bitmap.Ok() + : bitmap.LoadFile(_T("splash.png"), wxBITMAP_TYPE_PNG); - wxMessageBox(msg, _T("About sample"), wxOK | wxICON_INFORMATION, this); + if (ok) + { + wxImage image = bitmap.ConvertToImage(); + // do not scale on already small screens + if (!m_isPda) + image.Rescale( bitmap.GetWidth()/2, bitmap.GetHeight()/2 ); + bitmap = wxBitmap(image); + wxSplashScreen *splash = new wxSplashScreen(bitmap, + wxSPLASH_CENTRE_ON_PARENT | wxSPLASH_NO_TIMEOUT, + 0, this, wxID_ANY, wxDefaultPosition, wxDefaultSize, + wxSIMPLE_BORDER|wxSTAY_ON_TOP); + wxWindow *win = splash->GetSplashWindow(); +#if wxUSE_MEDIACTRL + wxMediaCtrl *media = new wxMediaCtrl( win, wxID_EXIT, _T("press.mpg"), wxPoint(2,2)); + media->Play(); +#else + wxStaticText *text = new wxStaticText( win, + wxID_EXIT, + _T("click somewhere\non image"), + wxPoint(m_isPda ? 0 : 13, + m_isPda ? 0 : 11) + ); + text->SetBackgroundColour(*wxWHITE); + text->SetForegroundColour(*wxBLACK); + wxFont font = text->GetFont(); + font.SetPointSize(2*font.GetPointSize()/3); + text->SetFont(font); +#endif + } }