]>
Commit | Line | Data |
---|---|---|
1 | ///////////////////////////////////////////////////////////////////////////// | |
2 | // Name: splash.cpp | |
3 | // Purpose: wxSplashScreen class | |
4 | // Author: Julian Smart | |
5 | // Modified by: | |
6 | // Created: 28/6/2000 | |
7 | // RCS-ID: $Id$ | |
8 | // Copyright: (c) Julian Smart | |
9 | // Licence: wxWindows licence | |
10 | ///////////////////////////////////////////////////////////////////////////// | |
11 | ||
12 | #ifdef __GNUG__ | |
13 | #pragma implementation "splash.h" | |
14 | #endif | |
15 | ||
16 | // For compilers that support precompilation, includes "wx/wx.h". | |
17 | #include "wx/wxprec.h" | |
18 | ||
19 | #ifdef __BORLANDC__ | |
20 | #pragma hdrstop | |
21 | #endif | |
22 | ||
23 | #if wxUSE_SPLASH | |
24 | ||
25 | #ifndef WX_PRECOMP | |
26 | #include "wx/dcmemory.h" | |
27 | #endif | |
28 | ||
29 | #include "wx/splash.h" | |
30 | ||
31 | /* | |
32 | * wxSplashScreen | |
33 | */ | |
34 | ||
35 | #define wxSPLASH_TIMER_ID 9999 | |
36 | ||
37 | IMPLEMENT_DYNAMIC_CLASS(wxSplashScreen, wxFrame); | |
38 | ||
39 | BEGIN_EVENT_TABLE(wxSplashScreen, wxFrame) | |
40 | EVT_TIMER(wxSPLASH_TIMER_ID, wxSplashScreen::OnNotify) | |
41 | EVT_CLOSE(wxSplashScreen::OnCloseWindow) | |
42 | END_EVENT_TABLE() | |
43 | ||
44 | /* Note that unless we pass a non-default size to the frame, SetClientSize | |
45 | * won't work properly under Windows, and the splash screen frame is sized | |
46 | * slightly too small. | |
47 | */ | |
48 | ||
49 | wxSplashScreen::wxSplashScreen(const wxBitmap& bitmap, long splashStyle, int milliseconds, wxWindow* parent, wxWindowID id, const wxPoint& pos, const wxSize& size, long style): | |
50 | wxFrame(parent, id, wxEmptyString, wxPoint(0, 0), wxSize(100, 100), style) | |
51 | { | |
52 | m_window = NULL; | |
53 | m_splashStyle = splashStyle; | |
54 | m_milliseconds = milliseconds; | |
55 | ||
56 | m_window = new wxSplashScreenWindow(bitmap, this, -1, pos, size, wxNO_BORDER); | |
57 | ||
58 | SetClientSize(bitmap.GetWidth(), bitmap.GetHeight()); | |
59 | ||
60 | if (m_splashStyle & wxSPLASH_CENTRE_ON_PARENT) | |
61 | CentreOnParent(); | |
62 | else if (m_splashStyle & wxSPLASH_CENTRE_ON_SCREEN) | |
63 | CentreOnScreen(); | |
64 | ||
65 | if (m_splashStyle & wxSPLASH_TIMEOUT) | |
66 | { | |
67 | m_timer.SetOwner(this, wxSPLASH_TIMER_ID); | |
68 | m_timer.Start(milliseconds, TRUE); | |
69 | } | |
70 | ||
71 | Show(TRUE); | |
72 | m_window->SetFocus(); | |
73 | #ifdef __WXMSW__ | |
74 | Update(); // Without this, you see a blank screen for an instant | |
75 | #else | |
76 | wxYieldIfNeeded(); // Should eliminate this | |
77 | #endif | |
78 | } | |
79 | ||
80 | wxSplashScreen::~wxSplashScreen() | |
81 | { | |
82 | m_timer.Stop(); | |
83 | } | |
84 | ||
85 | void wxSplashScreen::OnNotify(wxTimerEvent& WXUNUSED(event)) | |
86 | { | |
87 | Close(TRUE); | |
88 | } | |
89 | ||
90 | void wxSplashScreen::OnCloseWindow(wxCloseEvent& WXUNUSED(event)) | |
91 | { | |
92 | m_timer.Stop(); | |
93 | this->Destroy(); | |
94 | } | |
95 | ||
96 | /* | |
97 | * wxSplashScreenWindow | |
98 | */ | |
99 | ||
100 | BEGIN_EVENT_TABLE(wxSplashScreenWindow, wxWindow) | |
101 | //EVT_PAINT(wxSplashScreenWindow::OnPaint) | |
102 | EVT_ERASE_BACKGROUND(wxSplashScreenWindow::OnEraseBackground) | |
103 | EVT_CHAR(wxSplashScreenWindow::OnChar) | |
104 | EVT_MOUSE_EVENTS(wxSplashScreenWindow::OnMouseEvent) | |
105 | END_EVENT_TABLE() | |
106 | ||
107 | wxSplashScreenWindow::wxSplashScreenWindow(const wxBitmap& bitmap, wxWindow* parent, wxWindowID id, const wxPoint& pos, const wxSize& size, long style): | |
108 | wxWindow(parent, id, pos, size, style) | |
109 | { | |
110 | m_bitmap = bitmap; | |
111 | ||
112 | #ifndef __WXGTK__ | |
113 | bool hiColour = (wxDisplayDepth() >= 16) ; | |
114 | ||
115 | if (bitmap.GetPalette() && !hiColour) | |
116 | { | |
117 | SetPalette(* bitmap.GetPalette()); | |
118 | } | |
119 | #endif | |
120 | ||
121 | } | |
122 | ||
123 | void wxSplashScreenWindow::OnPaint(wxPaintEvent& WXUNUSED(event)) | |
124 | { | |
125 | wxPaintDC dc(this); | |
126 | if (m_bitmap.Ok()) | |
127 | dc.DrawBitmap(m_bitmap, 0, 0); | |
128 | } | |
129 | ||
130 | // VZ: why don't we do it under wxGTK? | |
131 | #if !defined(__WXGTK__) && wxUSE_PALETTE | |
132 | #define USE_PALETTE_IN_SPLASH | |
133 | #endif | |
134 | ||
135 | static void wxDrawSplashBitmap(wxDC& dc, const wxBitmap& bitmap, int WXUNUSED(x), int WXUNUSED(y)) | |
136 | { | |
137 | wxMemoryDC dcMem; | |
138 | ||
139 | #ifdef USE_PALETTE_IN_SPLASH | |
140 | bool hiColour = (wxDisplayDepth() >= 16) ; | |
141 | ||
142 | if (bitmap.GetPalette() && !hiColour) | |
143 | { | |
144 | dcMem.SetPalette(* bitmap.GetPalette()); | |
145 | } | |
146 | #endif // USE_PALETTE_IN_SPLASH | |
147 | ||
148 | dcMem.SelectObject(bitmap); | |
149 | dc.Blit(0, 0, bitmap.GetWidth(), bitmap.GetHeight(), & dcMem, 0, 0); | |
150 | dcMem.SelectObject(wxNullBitmap); | |
151 | ||
152 | #ifdef USE_PALETTE_IN_SPLASH | |
153 | if (bitmap.GetPalette() && !hiColour) | |
154 | { | |
155 | dcMem.SetPalette(wxNullPalette); | |
156 | } | |
157 | #endif // USE_PALETTE_IN_SPLASH | |
158 | } | |
159 | ||
160 | void wxSplashScreenWindow::OnEraseBackground(wxEraseEvent& event) | |
161 | { | |
162 | if (event.GetDC()) | |
163 | { | |
164 | if (m_bitmap.Ok()) | |
165 | { | |
166 | wxDrawSplashBitmap(* event.GetDC(), m_bitmap, 0, 0); | |
167 | } | |
168 | } | |
169 | else | |
170 | { | |
171 | wxClientDC dc(this); | |
172 | if (m_bitmap.Ok()) | |
173 | { | |
174 | wxDrawSplashBitmap(dc, m_bitmap, 0, 0); | |
175 | } | |
176 | } | |
177 | } | |
178 | ||
179 | void wxSplashScreenWindow::OnMouseEvent(wxMouseEvent& event) | |
180 | { | |
181 | if (event.LeftDown() || event.RightDown()) | |
182 | GetParent()->Close(TRUE); | |
183 | } | |
184 | ||
185 | void wxSplashScreenWindow::OnChar(wxKeyEvent& WXUNUSED(event)) | |
186 | { | |
187 | GetParent()->Close(TRUE); | |
188 | } | |
189 | ||
190 | #endif // wxUSE_SPLASH |