]> git.saurik.com Git - wxWidgets.git/blame - contrib/utils/wxrcedit/splittree.cpp
Various fixes to contrib bakefiles. Regenerated corresponding
[wxWidgets.git] / contrib / utils / wxrcedit / splittree.cpp
CommitLineData
12d9e308
VS
1/////////////////////////////////////////////////////////////////////////////
2// Name: splittree.cpp
3// Purpose: Classes to achieve a remotely-scrolled tree in a splitter
4// window that can be scrolled by a scrolled window higher in the
5// hierarchy
6// Author: Julian Smart
7// Modified by:
8// Created: 8/7/2000
9// RCS-ID: $Id$
10// Copyright: (c) Julian Smart
11// Licence: wxWindows licence
12/////////////////////////////////////////////////////////////////////////////
13
14// ============================================================================
15// declarations
16// ============================================================================
17
18// ----------------------------------------------------------------------------
19// headers
20// ----------------------------------------------------------------------------
c74caa09 21#if defined(__GNUG__) && !defined(__APPLE__)
12d9e308
VS
22 #pragma implementation "splittree.h"
23#endif
24
25// For compilers that support precompilation, includes "wx/wx.h".
26#include "wx/wxprec.h"
27
28#ifdef __BORLANDC__
29 #pragma hdrstop
30#endif
31
32// for all others, include the necessary headers (this file is usually all you
33// need because it includes almost all "standard" wxWindows headers)
34#ifndef WX_PRECOMP
35 #include "wx/wx.h"
36#endif
37
43ef6d9e 38#ifdef __WXMSW__
6495f2dd 39#include <windows.h>
43ef6d9e
VS
40#include "wx/msw/winundef.h"
41#endif
42
6495f2dd
JS
43#include "wx/gizmos/splittree.h"
44#include <math.h>
12d9e308
VS
45
46/*
47 * wxRemotelyScrolledTreeCtrl
48 */
49
50#if USE_GENERIC_TREECTRL
51IMPLEMENT_CLASS(wxRemotelyScrolledTreeCtrl, wxGenericTreeCtrl)
52#else
53IMPLEMENT_CLASS(wxRemotelyScrolledTreeCtrl, wxTreeCtrl)
54#endif
55
56#if USE_GENERIC_TREECTRL
57BEGIN_EVENT_TABLE(wxRemotelyScrolledTreeCtrl, wxGenericTreeCtrl)
58#else
59BEGIN_EVENT_TABLE(wxRemotelyScrolledTreeCtrl, wxTreeCtrl)
60#endif
61 EVT_SIZE(wxRemotelyScrolledTreeCtrl::OnSize)
62 EVT_TREE_ITEM_EXPANDED(-1, wxRemotelyScrolledTreeCtrl::OnExpand)
63 EVT_TREE_ITEM_COLLAPSED(-1, wxRemotelyScrolledTreeCtrl::OnExpand)
64 EVT_SCROLLWIN(wxRemotelyScrolledTreeCtrl::OnScroll)
65END_EVENT_TABLE()
66
67wxRemotelyScrolledTreeCtrl::wxRemotelyScrolledTreeCtrl(wxWindow* parent, wxWindowID id, const wxPoint& pt,
68 const wxSize& sz, long style):
69 wxTreeCtrl(parent, id, pt, sz, style)
70{
71 m_companionWindow = NULL;
72}
73
74wxRemotelyScrolledTreeCtrl::~wxRemotelyScrolledTreeCtrl()
75{
76}
77
78void wxRemotelyScrolledTreeCtrl::HideVScrollbar()
79{
6495f2dd 80#if defined(__WXMSW__) && USE_GENERIC_TREECTRL
12d9e308
VS
81 if (!IsKindOf(CLASSINFO(wxGenericTreeCtrl)))
82 {
83 ::ShowScrollBar((HWND) GetHWND(), SB_VERT, FALSE);
84 }
85 else
86#endif
87 {
88 // Implicit in overriding SetScrollbars
89 }
90}
91
92// Number of pixels per user unit (0 or -1 for no scrollbar)
93// Length of virtual canvas in user units
94// Length of page in user units
95void wxRemotelyScrolledTreeCtrl::SetScrollbars(int pixelsPerUnitX, int pixelsPerUnitY,
96 int noUnitsX, int noUnitsY,
97 int xPos, int yPos,
98 bool noRefresh)
99{
6495f2dd 100#if USE_GENERIC_TREECTRL || !defined(__WXMSW__)
12d9e308
VS
101 if (IsKindOf(CLASSINFO(wxGenericTreeCtrl)))
102 {
103 wxGenericTreeCtrl* win = (wxGenericTreeCtrl*) this;
104 win->wxGenericTreeCtrl::SetScrollbars(pixelsPerUnitX, 0, noUnitsX, 0, xPos, 0, noRefresh);
105
106 wxScrolledWindow* scrolledWindow = GetScrolledWindow();
107 if (scrolledWindow)
108 {
109 scrolledWindow->SetScrollbars(0, pixelsPerUnitY, 0, noUnitsY, 0, yPos, noRefresh);
110 }
111 }
6495f2dd 112#endif
12d9e308
VS
113}
114
115// In case we're using the generic tree control.
116int wxRemotelyScrolledTreeCtrl::GetScrollPos(int orient) const
117{
118 wxScrolledWindow* scrolledWindow = GetScrolledWindow();
119
6495f2dd 120#if USE_GENERIC_TREECTRL || !defined(__WXMSW__)
12d9e308
VS
121 if (IsKindOf(CLASSINFO(wxGenericTreeCtrl)))
122 {
123 wxGenericTreeCtrl* win = (wxGenericTreeCtrl*) this;
124
125 if (orient == wxHORIZONTAL)
126 return win->wxGenericTreeCtrl::GetScrollPos(orient);
127 else
128 {
129 return scrolledWindow->GetScrollPos(orient);
130 }
131 }
6495f2dd 132#endif
12d9e308
VS
133 return 0;
134}
135
136
137// In case we're using the generic tree control.
138// Get the view start
139void wxRemotelyScrolledTreeCtrl::GetViewStart(int *x, int *y) const
140{
141 wxScrolledWindow* scrolledWindow = GetScrolledWindow();
142
6495f2dd 143#if USE_GENERIC_TREECTRL || !defined(__WXMSW__)
12d9e308
VS
144 if (IsKindOf(CLASSINFO(wxGenericTreeCtrl)))
145 {
146
147 wxGenericTreeCtrl* win = (wxGenericTreeCtrl*) this;
148 int x1, y1, x2, y2;
149 win->wxGenericTreeCtrl::GetViewStart(& x1, & y1);
150 * x = x1; * y = y1;
151 if (!scrolledWindow)
152 return;
153
154 scrolledWindow->GetViewStart(& x2, & y2);
155 * y = y2;
156 }
157 else
6495f2dd 158#endif
12d9e308
VS
159 {
160 // x is wrong since the horizontal scrollbar is controlled by the
161 // tree control, but we probably don't need it.
162 scrolledWindow->GetViewStart(x, y);
163 }
164}
165
166// In case we're using the generic tree control.
167void wxRemotelyScrolledTreeCtrl::PrepareDC(wxDC& dc)
168{
6495f2dd 169#if USE_GENERIC_TREECTRL || !defined(__WXMSW__)
12d9e308
VS
170 if (IsKindOf(CLASSINFO(wxGenericTreeCtrl)))
171 {
172 wxScrolledWindow* scrolledWindow = GetScrolledWindow();
173
174 wxGenericTreeCtrl* win = (wxGenericTreeCtrl*) this;
175
176 int startX, startY;
177 GetViewStart(& startX, & startY);
178
179 int xppu1, yppu1, xppu2, yppu2;
180 win->wxGenericTreeCtrl::GetScrollPixelsPerUnit(& xppu1, & yppu1);
181 scrolledWindow->GetScrollPixelsPerUnit(& xppu2, & yppu2);
182
183 dc.SetDeviceOrigin( -startX * xppu1, -startY * yppu2 );
6495f2dd 184 // dc.SetUserScale( win->GetScaleX(), win->GetScaleY() );
12d9e308 185 }
6495f2dd 186#endif
12d9e308
VS
187}
188
189// Scroll to the given line (in scroll units where each unit is
190// the height of an item)
191void wxRemotelyScrolledTreeCtrl::ScrollToLine(int posHoriz, int posVert)
192{
193#ifdef __WXMSW__
6495f2dd 194#if USE_GENERIC_TREECTRL
12d9e308 195 if (!IsKindOf(CLASSINFO(wxGenericTreeCtrl)))
6495f2dd 196#endif
12d9e308
VS
197 {
198 UINT sbCode = SB_THUMBPOSITION;
199 HWND vertScrollBar = 0;
200 MSWDefWindowProc((WXUINT) WM_VSCROLL, MAKELONG(sbCode, posVert), (WXHWND) vertScrollBar);
201 }
6495f2dd 202#if USE_GENERIC_TREECTRL
12d9e308
VS
203 else
204#endif
6495f2dd
JS
205#endif
206#if USE_GENERIC_TREECTRL || !defined(__WXMSW__)
12d9e308
VS
207 {
208 wxGenericTreeCtrl* win = (wxGenericTreeCtrl*) this;
209 win->Refresh();
210 /* Doesn't work yet because scrolling is ignored by Scroll
211 int xppu, yppu;
212 wxScrolledWindow* scrolledWindow = GetScrolledWindow();
213 if (scrolledWindow)
214 {
215 scrolledWindow->GetScrollPixelsPerUnit(& xppu, & yppu);
216 win->Scroll(-1, posVert*yppu);
217 }
218 */
219 }
6495f2dd 220#endif
12d9e308
VS
221}
222
223void wxRemotelyScrolledTreeCtrl::OnSize(wxSizeEvent& event)
224{
225 HideVScrollbar();
226 AdjustRemoteScrollbars();
227 event.Skip();
228}
229
230void wxRemotelyScrolledTreeCtrl::OnExpand(wxTreeEvent& event)
231{
232 AdjustRemoteScrollbars();
233 event.Skip();
234
235 // If we don't have this, we get some bits of lines still remaining
236 if (event.GetEventType() == wxEVT_COMMAND_TREE_ITEM_COLLAPSED)
237 Refresh();
238
239 // Pass on the event
240 if (m_companionWindow)
241 m_companionWindow->GetEventHandler()->ProcessEvent(event);
242}
243
244// Adjust the containing wxScrolledWindow's scrollbars appropriately
245void wxRemotelyScrolledTreeCtrl::AdjustRemoteScrollbars()
246{
6495f2dd 247#if USE_GENERIC_TREECTRL || !defined(__WXMSW__)
12d9e308
VS
248 if (IsKindOf(CLASSINFO(wxGenericTreeCtrl)))
249 {
250 // This is for the generic tree control.
251 // It calls SetScrollbars which has been overridden
252 // to adjust the parent scrolled window vertical
253 // scrollbar.
254 ((wxGenericTreeCtrl*) this)->AdjustMyScrollbars();
255 return;
256 }
257 else
6495f2dd 258#endif
12d9e308
VS
259 {
260 // This is for the wxMSW tree control
261 wxScrolledWindow* scrolledWindow = GetScrolledWindow();
262 if (scrolledWindow)
263 {
264 wxRect itemRect;
265 if (GetBoundingRect(GetRootItem(), itemRect))
266 {
6495f2dd
JS
267 // Actually, the real height seems to be 1 less than reported
268 // (e.g. 16 instead of 16)
269 int itemHeight = itemRect.GetHeight() - 1;
12d9e308
VS
270
271 int w, h;
272 GetClientSize(&w, &h);
273
274 wxRect rect(0, 0, 0, 0);
275 CalcTreeSize(rect);
6495f2dd
JS
276
277 double f = ((double) (rect.GetHeight()) / (double) itemHeight) ;
278 int treeViewHeight = (int) ceil(f);
12d9e308
VS
279
280 int scrollPixelsPerLine = itemHeight;
281 int scrollPos = - (itemRect.y / itemHeight);
282
283 scrolledWindow->SetScrollbars(0, scrollPixelsPerLine, 0, treeViewHeight, 0, scrollPos);
284
285 // Ensure that when a scrollbar becomes hidden or visible,
286 // the contained window sizes are right.
287 // Problem: this is called too early (?)
288 wxSizeEvent event(scrolledWindow->GetSize(), scrolledWindow->GetId());
289 scrolledWindow->GetEventHandler()->ProcessEvent(event);
290 }
291 }
292 }
293}
294
295
296// Calculate the area that contains both rectangles
297static wxRect CombineRectangles(const wxRect& rect1, const wxRect& rect2)
298{
299 wxRect rect;
300
301 int right1 = rect1.GetRight();
302 int bottom1 = rect1.GetBottom();
303 int right2 = rect2.GetRight();
304 int bottom2 = rect2.GetBottom();
305
306 wxPoint topLeft = wxPoint(wxMin(rect1.x, rect2.x), wxMin(rect1.y, rect2.y));
307 wxPoint bottomRight = wxPoint(wxMax(right1, right2), wxMax(bottom1, bottom2));
308
309 rect.x = topLeft.x; rect.y = topLeft.y;
310 rect.SetRight(bottomRight.x);
311 rect.SetBottom(bottomRight.y);
312
313 return rect;
314}
315
316
317// Calculate the tree overall size so we can set the scrollbar
318// correctly
319void wxRemotelyScrolledTreeCtrl::CalcTreeSize(wxRect& rect)
320{
321 CalcTreeSize(GetRootItem(), rect);
322}
323
324void wxRemotelyScrolledTreeCtrl::CalcTreeSize(const wxTreeItemId& id, wxRect& rect)
325{
12d9e308
VS
326 // More efficient implementation would be to find the last item (but how?)
327 // Q: is the bounding rect relative to the top of the virtual tree workspace
328 // or the top of the window? How would we convert?
329 wxRect itemSize;
330 if (GetBoundingRect(id, itemSize))
331 {
332 rect = CombineRectangles(rect, itemSize);
333 }
334
c74caa09 335 void* cookie;
12d9e308 336 wxTreeItemId childId = GetFirstChild(id, cookie);
c74caa09 337 while (childId)
12d9e308
VS
338 {
339 CalcTreeSize(childId, rect);
340 childId = GetNextChild(childId, cookie);
341 }
342}
343
344// Find the scrolled window that contains this control
345wxScrolledWindow* wxRemotelyScrolledTreeCtrl::GetScrolledWindow() const
346{
347 wxWindow* parent = wxWindow::GetParent();
348 while (parent)
349 {
350 if (parent->IsKindOf(CLASSINFO(wxScrolledWindow)))
351 return (wxScrolledWindow*) parent;
352 parent = parent->GetParent();
353 }
354 return NULL;
355}
356
357void wxRemotelyScrolledTreeCtrl::OnScroll(wxScrollWinEvent& event)
358{
359 int orient = event.GetOrientation();
360 if (orient == wxHORIZONTAL)
361 {
362 event.Skip();
363 return;
364 }
365 wxScrolledWindow* scrollWin = GetScrolledWindow();
366 if (!scrollWin)
367 return;
368
369 int x, y;
370 scrollWin->GetViewStart(& x, & y);
371
372 ScrollToLine(-1, y);
373}
374
375/*
376 * wxTreeCompanionWindow
377 *
378 * A window displaying values associated with tree control items.
379 */
380
381IMPLEMENT_CLASS(wxTreeCompanionWindow, wxWindow)
382
383BEGIN_EVENT_TABLE(wxTreeCompanionWindow, wxWindow)
384 EVT_PAINT(wxTreeCompanionWindow::OnPaint)
385 EVT_SCROLLWIN(wxTreeCompanionWindow::OnScroll)
386 EVT_TREE_ITEM_EXPANDED(-1, wxTreeCompanionWindow::OnExpand)
387 EVT_TREE_ITEM_COLLAPSED(-1, wxTreeCompanionWindow::OnExpand)
388END_EVENT_TABLE()
389
390wxTreeCompanionWindow::wxTreeCompanionWindow(wxWindow* parent, wxWindowID id,
391 const wxPoint& pos,
392 const wxSize& sz,
393 long style):
394 wxWindow(parent, id, pos, sz, style)
395{
396 m_treeCtrl = NULL;
397}
398
399void wxTreeCompanionWindow::DrawItem(wxDC& dc, wxTreeItemId id, const wxRect& rect)
400{
401 // TEST CODE
402#if 1
403 if (m_treeCtrl)
404 {
405 wxString text = m_treeCtrl->GetItemText(id);
406 dc.SetTextForeground(* wxBLACK);
407 dc.SetBackgroundMode(wxTRANSPARENT);
408
409 int textW, textH;
410 dc.GetTextExtent(text, & textW, & textH);
411
412 int x = 5;
413 int y = rect.GetY() + wxMax(0, (rect.GetHeight() - textH) / 2);
414
415 dc.DrawText(text, x, y);
416 }
417#endif
418}
419
420void wxTreeCompanionWindow::OnPaint(wxPaintEvent& event)
421{
422 wxPaintDC dc(this);
423
424 if (!m_treeCtrl)
425 return;
426
e1c6c6ae 427 wxPen pen(wxSystemSettings::GetColour(wxSYS_COLOUR_3DLIGHT), 1, wxSOLID);
12d9e308
VS
428 dc.SetPen(pen);
429 dc.SetBrush(* wxTRANSPARENT_BRUSH);
e1c6c6ae 430 wxFont font(wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT));
12d9e308
VS
431 dc.SetFont(font);
432
433 wxSize clientSize = GetClientSize();
434 wxRect itemRect;
435 int cy=0;
436 wxTreeItemId h, lastH;
437 for(h=m_treeCtrl->GetFirstVisibleItem();h;h=m_treeCtrl->GetNextVisible(h))
438 {
439 if (m_treeCtrl->GetBoundingRect(h, itemRect))
440 {
441 cy = itemRect.GetTop();
442 wxRect drawItemRect(0, cy, clientSize.x, itemRect.GetHeight());
443
444 lastH = h;
445
446 // Draw the actual item
447 DrawItem(dc, h, drawItemRect);
448 dc.DrawLine(0, cy, clientSize.x, cy);
449 }
450 }
451 if (lastH.IsOk() && m_treeCtrl->GetBoundingRect(lastH, itemRect))
452 {
453 cy = itemRect.GetBottom();
454 dc.DrawLine(0, cy, clientSize.x, cy);
455 }
456}
457
458void wxTreeCompanionWindow::OnScroll(wxScrollWinEvent& event)
459{
460 int orient = event.GetOrientation();
461 if (orient == wxHORIZONTAL)
462 {
463 event.Skip();
464 return;
465 }
466 if (!m_treeCtrl)
467 return;
468
469 // TODO: scroll the window physically instead of just refreshing.
470 Refresh(TRUE);
471}
472
473void wxTreeCompanionWindow::OnExpand(wxTreeEvent& event)
474{
475 // TODO: something more optimized than simply refresh the whole
476 // window when the tree is expanded/collapsed. Tricky.
477 Refresh();
478}
479
480/*
481 * wxThinSplitterWindow
482 */
483
484IMPLEMENT_CLASS(wxThinSplitterWindow, wxSplitterWindow)
485
486BEGIN_EVENT_TABLE(wxThinSplitterWindow, wxSplitterWindow)
487 EVT_SIZE(wxThinSplitterWindow::OnSize)
488END_EVENT_TABLE()
489
490wxThinSplitterWindow::wxThinSplitterWindow(wxWindow* parent, wxWindowID id,
491 const wxPoint& pos,
492 const wxSize& sz,
493 long style):
494 wxSplitterWindow(parent, id, pos, sz, style)
495{
496}
497
c74caa09
MB
498wxThinSplitterWindow::~wxThinSplitterWindow()
499{
500}
501
12d9e308
VS
502void wxThinSplitterWindow::SizeWindows()
503{
504 // The client size may have changed inbetween
505 // the sizing of the first window and the sizing of
506 // the second. So repeat SizeWindows.
507 wxSplitterWindow::SizeWindows();
508 wxSplitterWindow::SizeWindows();
509}
510
511// Tests for x, y over sash
512bool wxThinSplitterWindow::SashHitTest(int x, int y, int tolerance)
513{
514 return wxSplitterWindow::SashHitTest(x, y, 4);
515}
516
517void wxThinSplitterWindow::DrawSash(wxDC& dc)
518{
c74caa09 519 if ( GetSashPosition() == 0 || !m_windowTwo)
12d9e308
VS
520 return;
521 if (GetWindowStyle() & wxSP_NOSASH)
522 return;
523
524 int w, h;
525 GetClientSize(&w, &h);
526
527 if ( m_splitMode == wxSPLIT_VERTICAL )
528 {
529 dc.SetPen(* m_facePen);
530 dc.SetBrush(* m_faceBrush);
531 int h1 = h-1;
532 int y1 = 0;
533 if ( (GetWindowStyleFlag() & wxSP_BORDER) != wxSP_BORDER && (GetWindowStyleFlag() & wxSP_3DBORDER) != wxSP_3DBORDER )
534 h1 += 1; // Not sure why this is necessary...
535 if ( (GetWindowStyleFlag() & wxSP_3DBORDER) == wxSP_3DBORDER)
536 {
537 y1 = 2; h1 -= 3;
538 }
c74caa09 539 dc.DrawRectangle(GetSashPosition(), y1, GetSashSize(), h1);
12d9e308
VS
540 }
541 else
542 {
543 dc.SetPen(* m_facePen);
544 dc.SetBrush(* m_faceBrush);
545 int w1 = w-1;
546 int x1 = 0;
547 if ( (GetWindowStyleFlag() & wxSP_BORDER) != wxSP_BORDER && (GetWindowStyleFlag() & wxSP_3DBORDER) != wxSP_3DBORDER )
548 w1 ++;
549 if ( (GetWindowStyleFlag() & wxSP_3DBORDER) == wxSP_3DBORDER)
550 {
551 x1 = 2; w1 -= 3;
552 }
c74caa09 553 dc.DrawRectangle(x1, GetSashPosition(), w1, GetSashSize());
12d9e308
VS
554 }
555
556 dc.SetPen(wxNullPen);
557 dc.SetBrush(wxNullBrush);
558}
559
560void wxThinSplitterWindow::OnSize(wxSizeEvent& event)
561{
562 wxSplitterWindow::OnSize(event);
563}
564
565/*
566 * wxSplitterScrolledWindow
567 */
568
569IMPLEMENT_CLASS(wxSplitterScrolledWindow, wxScrolledWindow)
570
571BEGIN_EVENT_TABLE(wxSplitterScrolledWindow, wxScrolledWindow)
572 EVT_SCROLLWIN(wxSplitterScrolledWindow::OnScroll)
573 EVT_SIZE(wxSplitterScrolledWindow::OnSize)
574END_EVENT_TABLE()
575
576wxSplitterScrolledWindow::wxSplitterScrolledWindow(wxWindow* parent, wxWindowID id,
577 const wxPoint& pos,
578 const wxSize& sz,
579 long style):
580 wxScrolledWindow(parent, id, pos, sz, style)
581{
582}
583
584void wxSplitterScrolledWindow::OnSize(wxSizeEvent& event)
585{
586 wxSize sz = GetClientSize();
587 if (GetChildren().First())
588 {
589 ((wxWindow*) GetChildren().First()->Data())->SetSize(0, 0, sz.x, sz.y);
590 }
591}
592
593void wxSplitterScrolledWindow::OnScroll(wxScrollWinEvent& event)
594{
595 // Ensure that events being propagated back up the window hierarchy
596 // don't cause an infinite loop
597 static bool inOnScroll = FALSE;
598 if (inOnScroll)
6495f2dd
JS
599 {
600 event.Skip();
12d9e308 601 return;
6495f2dd 602 }
12d9e308 603 inOnScroll = TRUE;
6495f2dd 604
12d9e308
VS
605 int orient = event.GetOrientation();
606
6495f2dd 607 int nScrollInc = CalcScrollInc(event);
12d9e308
VS
608 if (nScrollInc == 0)
609 {
610 inOnScroll = FALSE;
611 return;
612 }
613
614 if (orient == wxHORIZONTAL)
615 {
616 inOnScroll = FALSE;
617 event.Skip();
618 return;
619#if 0
620 int newPos = m_xScrollPosition + nScrollInc;
621 SetScrollPos(wxHORIZONTAL, newPos, TRUE );
622#endif
623 }
624 else
625 {
626 int newPos = m_yScrollPosition + nScrollInc;
627 SetScrollPos(wxVERTICAL, newPos, TRUE );
628 }
629
630 if (orient == wxHORIZONTAL)
631 {
632 m_xScrollPosition += nScrollInc;
633 }
634 else
635 {
636 m_yScrollPosition += nScrollInc;
637 }
638
639 // Find targets in splitter window and send the event to them
640 wxNode* node = GetChildren().First();
641 while (node)
642 {
643 wxWindow* child = (wxWindow*) node->Data();
644 if (child->IsKindOf(CLASSINFO(wxSplitterWindow)))
645 {
646 wxSplitterWindow* splitter = (wxSplitterWindow*) child;
647 if (splitter->GetWindow1())
648 splitter->GetWindow1()->ProcessEvent(event);
649 if (splitter->GetWindow2())
650 splitter->GetWindow2()->ProcessEvent(event);
651 break;
652 }
653 node = node->Next();
654 }
655
656#ifdef __WXMAC__
657 m_targetWindow->MacUpdateImmediately() ;
658#endif
659
660 inOnScroll = FALSE;
661}
662