1 /////////////////////////////////////////////////////////////////////////////
2 // Name: generic/tbarsmpl.cpp
3 // Purpose: wxToolBarSimple
4 // Author: Julian Smart
5 // Modified by: VZ on 14.12.99 during wxToolBarSimple reorganization
8 // Copyright: (c) Julian Smart and Markus Holzem
9 // Licence: wxWindows license
10 /////////////////////////////////////////////////////////////////////////////
12 // ============================================================================
14 // ============================================================================
16 // ----------------------------------------------------------------------------
18 // ----------------------------------------------------------------------------
21 #pragma implementation "tbarsmpl.h"
24 // For compilers that support precompilation, includes "wx.h".
25 #include "wx/wxprec.h"
31 #if wxUSE_TOOLBAR_SIMPLE
34 #include "wx/settings.h"
35 #include "wx/window.h"
36 #include "wx/dcclient.h"
37 #include "wx/dcmemory.h"
40 #include "wx/tbarsmpl.h"
42 // ----------------------------------------------------------------------------
44 // ----------------------------------------------------------------------------
46 class WXDLLEXPORT wxToolBarToolSimple
: public wxToolBarToolBase
49 wxToolBarToolSimple(wxToolBarSimple
*tbar
,
51 const wxBitmap
& bitmap1
,
52 const wxBitmap
& bitmap2
,
55 const wxString
& shortHelpString
,
56 const wxString
& longHelpString
)
57 : wxToolBarToolBase(tbar
, id
, bitmap1
, bitmap2
, toggle
,
58 clientData
, shortHelpString
, longHelpString
)
62 wxToolBarToolSimple(wxToolBarSimple
*tbar
, wxControl
*control
)
63 : wxToolBarToolBase(tbar
, control
)
67 void SetSize(const wxSize
& size
)
73 wxCoord
GetWidth() const { return m_width
; }
74 wxCoord
GetHeight() const { return m_height
; }
82 // ----------------------------------------------------------------------------
84 // ----------------------------------------------------------------------------
86 IMPLEMENT_DYNAMIC_CLASS(wxToolBarSimple
, wxToolBarBase
)
88 #if !wxUSE_TOOLBAR_NATIVE || defined(__WXUNIVERSAL__)
89 #include "wx/toolbar.h"
91 IMPLEMENT_DYNAMIC_CLASS(wxToolBar
, wxToolBarSimple
)
94 BEGIN_EVENT_TABLE(wxToolBarSimple
, wxToolBarBase
)
95 EVT_SIZE(wxToolBarSimple::OnSize
)
96 EVT_SCROLL(wxToolBarSimple::OnScroll
)
97 EVT_PAINT(wxToolBarSimple::OnPaint
)
98 EVT_KILL_FOCUS(wxToolBarSimple::OnKillFocus
)
99 EVT_MOUSE_EVENTS(wxToolBarSimple::OnMouseEvent
)
102 // ============================================================================
104 // ============================================================================
106 // ----------------------------------------------------------------------------
107 // tool bar tools creation
108 // ----------------------------------------------------------------------------
110 wxToolBarToolBase
*wxToolBarSimple::CreateTool(int id
,
111 const wxBitmap
& bitmap1
,
112 const wxBitmap
& bitmap2
,
114 wxObject
*clientData
,
115 const wxString
& shortHelpString
,
116 const wxString
& longHelpString
)
118 return new wxToolBarToolSimple(this, id
, bitmap1
, bitmap2
, toggle
,
119 clientData
, shortHelpString
, longHelpString
);
122 wxToolBarToolBase
*wxToolBarSimple::CreateTool(wxControl
*control
)
124 return new wxToolBarToolSimple(this, control
);
127 // ----------------------------------------------------------------------------
128 // wxToolBarSimple creation
129 // ----------------------------------------------------------------------------
131 void wxToolBarSimple::Init()
133 m_currentRowsOrColumns
= 0;
148 m_toolSeparation
= 5;
151 m_defaultHeight
= 15;
153 m_xScrollPixelsPerLine
= 1;
154 m_yScrollPixelsPerLine
= 1;
155 m_xScrollingEnabled
= FALSE
;
156 m_yScrollingEnabled
= FALSE
;
157 m_xScrollPosition
= 0;
158 m_yScrollPosition
= 0;
161 m_xScrollLinesPerPage
= 0;
162 m_yScrollLinesPerPage
= 0;
165 wxToolBarToolBase
*wxToolBarSimple::AddTool(int id
,
166 const wxBitmap
& bitmap
,
167 const wxBitmap
& pushedBitmap
,
171 wxObject
*clientData
,
172 const wxString
& helpString1
,
173 const wxString
& helpString2
)
175 // rememeber the position for DoInsertTool()
179 return wxToolBarBase::AddTool(id
, bitmap
, pushedBitmap
, toggle
,
180 xPos
, yPos
, clientData
,
181 helpString1
, helpString2
);
184 bool wxToolBarSimple::DoInsertTool(size_t WXUNUSED(pos
),
185 wxToolBarToolBase
*toolBase
)
187 wxToolBarToolSimple
*tool
= (wxToolBarToolSimple
*)toolBase
;
189 wxCHECK_MSG( !tool
->IsControl(), FALSE
,
190 _T("generic wxToolBarSimple doesn't support controls") );
193 if ( tool
->m_x
== -1 )
194 tool
->m_x
= m_xMargin
;
197 if ( tool
->m_y
== -1 )
198 tool
->m_y
= m_yMargin
;
200 tool
->SetSize(GetToolSize());
202 if ( tool
->IsButton() )
204 // Calculate reasonable max size in case Layout() not called
205 if ((tool
->m_x
+ tool
->GetBitmap1().GetWidth() + m_xMargin
) > m_maxWidth
)
206 m_maxWidth
= (wxCoord
)((tool
->m_x
+ tool
->GetWidth() + m_xMargin
));
208 if ((tool
->m_y
+ tool
->GetBitmap1().GetHeight() + m_yMargin
) > m_maxHeight
)
209 m_maxHeight
= (wxCoord
)((tool
->m_y
+ tool
->GetHeight() + m_yMargin
));
215 bool wxToolBarSimple::DoDeleteTool(size_t WXUNUSED(pos
),
216 wxToolBarToolBase
*tool
)
218 // VZ: didn't test whether it works, but why not...
226 bool wxToolBarSimple::Create(wxWindow
*parent
,
231 const wxString
& name
)
233 if ( !wxWindow::Create(parent
, id
, pos
, size
, style
, name
) )
236 // Set it to grey (or other 3D face colour)
237 wxSystemSettings settings
;
238 SetBackgroundColour(settings
.GetSystemColour(wxSYS_COLOUR_3DFACE
));
240 if ( GetWindowStyleFlag() & wxTB_VERTICAL
)
245 m_maxRows
= 32000; // a lot
254 m_maxCols
= 32000; // a lot
257 SetCursor(*wxSTANDARD_CURSOR
);
262 wxToolBarSimple::~wxToolBarSimple()
266 bool wxToolBarSimple::Realize()
268 m_currentRowsOrColumns
= 0;
274 int maxToolWidth
= 0;
275 int maxToolHeight
= 0;
277 // Find the maximum tool width and height
278 wxToolBarToolsList::Node
*node
= m_tools
.GetFirst();
281 wxToolBarToolSimple
*tool
= (wxToolBarToolSimple
*)node
->GetData();
282 if ( tool
->GetWidth() > maxToolWidth
)
283 maxToolWidth
= tool
->GetWidth();
284 if (tool
->GetHeight() > maxToolHeight
)
285 maxToolHeight
= tool
->GetHeight();
287 node
= node
->GetNext();
290 int separatorSize
= m_toolSeparation
;
292 node
= m_tools
.GetFirst();
295 wxToolBarToolSimple
*tool
= (wxToolBarToolSimple
*)node
->GetData();
296 if ( tool
->IsSeparator() )
298 if ( GetWindowStyleFlag() & wxTB_HORIZONTAL
)
300 if (m_currentRowsOrColumns
>= m_maxCols
)
301 m_lastY
+= separatorSize
;
303 m_lastX
+= separatorSize
;
307 if (m_currentRowsOrColumns
>= m_maxRows
)
308 m_lastX
+= separatorSize
;
310 m_lastY
+= separatorSize
;
313 else if ( tool
->IsButton() )
315 if ( GetWindowStyleFlag() & wxTB_HORIZONTAL
)
317 if (m_currentRowsOrColumns
>= m_maxCols
)
319 m_currentRowsOrColumns
= 0;
321 m_lastY
+= maxToolHeight
+ m_toolPacking
;
323 tool
->m_x
= (wxCoord
)(m_lastX
+ (maxToolWidth
- tool
->GetWidth())/2.0);
324 tool
->m_y
= (wxCoord
)(m_lastY
+ (maxToolHeight
- tool
->GetHeight())/2.0);
326 m_lastX
+= maxToolWidth
+ m_toolPacking
;
330 if (m_currentRowsOrColumns
>= m_maxRows
)
332 m_currentRowsOrColumns
= 0;
333 m_lastX
+= (maxToolWidth
+ m_toolPacking
);
336 tool
->m_x
= (wxCoord
)(m_lastX
+ (maxToolWidth
- tool
->GetWidth())/2.0);
337 tool
->m_y
= (wxCoord
)(m_lastY
+ (maxToolHeight
- tool
->GetHeight())/2.0);
339 m_lastY
+= maxToolHeight
+ m_toolPacking
;
341 m_currentRowsOrColumns
++;
345 // TODO: support the controls
348 if (m_lastX
> m_maxWidth
)
349 m_maxWidth
= m_lastX
;
350 if (m_lastY
> m_maxHeight
)
351 m_maxHeight
= m_lastY
;
353 node
= node
->GetNext();
356 if ( GetWindowStyleFlag() & wxTB_HORIZONTAL
)
357 m_maxWidth
+= maxToolWidth
;
359 m_maxHeight
+= maxToolHeight
;
361 m_maxWidth
+= m_xMargin
;
362 m_maxHeight
+= m_yMargin
;
367 // ----------------------------------------------------------------------------
369 // ----------------------------------------------------------------------------
371 void wxToolBarSimple::OnPaint (wxPaintEvent
& WXUNUSED(event
))
376 static int count
= 0;
377 // Prevent reentry of OnPaint which would cause wxMemoryDC errors.
382 for ( wxToolBarToolsList::Node
*node
= m_tools
.GetFirst();
384 node
= node
->GetNext() )
386 wxToolBarToolBase
*tool
= node
->GetData();
387 if ( tool
->IsButton() )
394 void wxToolBarSimple::OnSize (wxSizeEvent
& WXUNUSED(event
))
396 #if wxUSE_CONSTRAINTS
404 void wxToolBarSimple::OnKillFocus(wxFocusEvent
& WXUNUSED(event
))
406 OnMouseEnter(m_pressedTool
= m_currentTool
= -1);
409 void wxToolBarSimple::OnMouseEvent(wxMouseEvent
& event
)
412 event
.GetPosition(&x
, &y
);
413 wxToolBarToolSimple
*tool
= (wxToolBarToolSimple
*)FindToolForPosition(x
, y
);
415 if (event
.LeftDown())
426 if (m_currentTool
> -1)
428 if (event
.LeftIsDown())
429 SpringUpButton(m_currentTool
);
436 if (!event
.IsButton())
438 if ( tool
->GetId() != m_currentTool
)
440 // If the left button is kept down and moved over buttons,
441 // press those buttons.
442 if ( event
.LeftIsDown() && tool
->IsEnabled() )
444 SpringUpButton(m_currentTool
);
446 if ( tool
->CanBeToggled() )
454 m_currentTool
= tool
->GetId();
455 OnMouseEnter(m_currentTool
);
460 // Left button pressed.
461 if ( event
.LeftDown() && tool
->IsEnabled() )
463 if ( tool
->CanBeToggled() )
470 else if (event
.RightDown())
472 OnRightClick(tool
->GetId(), x
, y
);
475 // Left Button Released. Only this action confirms selection.
476 // If the button is enabled and it is not a toggle tool and it is
477 // in the pressed state, then raise the button and call OnLeftClick.
479 if ( event
.LeftUp() && tool
->IsEnabled() )
481 // Pass the OnLeftClick event to tool
482 if ( !OnLeftClick(tool
->GetId(), tool
->IsToggled()) &&
483 tool
->CanBeToggled() )
485 // If it was a toggle, and OnLeftClick says No Toggle allowed,
486 // then change it back
494 // ----------------------------------------------------------------------------
496 // ----------------------------------------------------------------------------
498 void wxToolBarSimple::DrawTool(wxToolBarToolBase
*tool
)
504 void wxToolBarSimple::DrawTool(wxDC
& dc
, wxToolBarToolBase
*toolBase
)
506 wxToolBarToolSimple
*tool
= (wxToolBarToolSimple
*)toolBase
;
511 wxPen
dark_grey_pen(wxColour( 85,85,85 ), 1, wxSOLID
);
512 wxPen
white_pen(wxT("WHITE"), 1, wxSOLID
);
513 wxPen
black_pen(wxT("BLACK"), 1, wxSOLID
);
515 wxBitmap bitmap
= tool
->GetBitmap();
521 if (bitmap
.GetPalette())
522 memDC
.SetPalette(*bitmap
.GetPalette());
524 #endif // wxUSE_PALETTE
526 int ax
= (int)tool
->m_x
,
528 bx
= (int)(tool
->m_x
+tool
->GetWidth()),
529 by
= (int)(tool
->m_y
+tool
->GetHeight());
531 memDC
.SelectObject(bitmap
);
532 if (m_windowStyle
& wxTB_3DBUTTONS
)
534 dc
.SetClippingRegion(ax
, ay
, (bx
-ax
+1), (by
-ay
+1));
535 dc
.Blit((ax
+1), (ay
+1), (bx
-ax
-2), (by
-ay
-2), &memDC
, 0, 0);
536 wxPen
* old_pen
= & dc
.GetPen();
537 dc
.SetPen( white_pen
);
538 dc
.DrawLine(ax
,(by
-1),ax
,ay
);
539 dc
.DrawLine(ax
,ay
,(bx
-1),ay
);
540 dc
.SetPen( dark_grey_pen
);
541 dc
.DrawLine((bx
-1),(ay
+1),(bx
-1),(by
-1));
542 dc
.DrawLine((bx
-1),(by
-1),(ax
+1),(by
-1));
543 dc
.SetPen( black_pen
);
544 dc
.DrawLine(bx
,ay
,bx
,by
);
545 dc
.DrawLine(bx
,by
,ax
,by
);
546 dc
.SetPen( *old_pen
);
547 dc
.DestroyClippingRegion();
548 // Select bitmap out of the DC
552 dc
.Blit(tool
->m_x
, tool
->m_y
,
553 bitmap
.GetWidth(), bitmap
.GetHeight(),
556 memDC
.SelectObject(wxNullBitmap
);
560 memDC
.SetPalette(wxNullPalette
);
562 #endif // wxUSE_PALETTE
564 // No second bitmap, so draw a thick line around bitmap, or invert if mono
565 else if ( tool
->IsToggled() )
567 bool drawBorder
= FALSE
;
568 #ifdef __X__ // X doesn't invert properly on colour
569 drawBorder
= wxColourDisplay();
570 #else // Inversion works fine under Windows
576 memDC
.SelectObject(tool
->GetBitmap1());
577 dc
.Blit(tool
->m_x
, tool
->m_y
, tool
->GetWidth(), tool
->GetHeight(),
578 &memDC
, 0, 0, wxSRC_INVERT
);
579 memDC
.SelectObject(wxNullBitmap
);
583 bitmap
= tool
->GetBitmap1();
585 if (m_windowStyle
& wxTB_3DBUTTONS
)
587 int ax
= (int)tool
->m_x
,
589 bx
= (int)(tool
->m_x
+tool
->GetWidth()),
590 by
= (int)(tool
->m_y
+tool
->GetHeight());
592 memDC
.SelectObject(bitmap
);
593 dc
.SetClippingRegion(ax
, ay
, (bx
-ax
+1), (by
-ay
+1));
594 dc
.Blit((ax
+2), (ay
+2), (bx
-ax
-2), (by
-ay
-2), &memDC
, 0, 0);
595 wxPen
* old_pen
= & dc
.GetPen();
596 dc
.SetPen( black_pen
);
597 dc
.DrawLine(ax
,(by
-1),ax
,ay
);
598 dc
.DrawLine(ax
,ay
,(bx
-1),ay
);
599 dc
.SetPen( dark_grey_pen
);
600 dc
.DrawLine((ax
+1),(by
-2),(ax
+1),(ay
+1));
601 dc
.DrawLine((ax
+1),(ay
+1),(bx
-2),(ay
+1));
602 dc
.SetPen( white_pen
);
603 dc
.DrawLine(bx
,ay
,bx
,by
);
604 dc
.DrawLine(bx
,by
,ax
,by
);
605 dc
.SetPen( *old_pen
);
606 dc
.DestroyClippingRegion();
607 memDC
.SelectObject(wxNullBitmap
);
611 wxCoord x
= tool
->m_x
;
612 wxCoord y
= tool
->m_y
;
613 wxCoord w
= bitmap
.GetWidth();
614 wxCoord h
= bitmap
.GetHeight();
615 wxPen
thick_black_pen(wxT("BLACK"), 3, wxSOLID
);
617 memDC
.SelectObject(bitmap
);
618 dc
.SetClippingRegion(tool
->m_x
, tool
->m_y
, w
, h
);
619 dc
.Blit(tool
->m_x
, tool
->m_y
, w
, h
,
621 dc
.SetPen(thick_black_pen
);
622 dc
.SetBrush(*wxTRANSPARENT_BRUSH
);
623 dc
.DrawRectangle(x
, y
, w
-1, h
-1);
624 dc
.DestroyClippingRegion();
625 memDC
.SelectObject(wxNullBitmap
);
631 // ----------------------------------------------------------------------------
633 // ----------------------------------------------------------------------------
635 void wxToolBarSimple::SetRows(int nRows
)
637 wxCHECK_RET( nRows
!= 0, _T("max number of rows must be > 0") );
639 m_maxCols
= (GetToolsCount() + nRows
- 1) / nRows
;
645 wxToolBarToolBase
*wxToolBarSimple::FindToolForPosition(wxCoord x
,
648 wxToolBarToolsList::Node
*node
= m_tools
.GetFirst();
651 wxToolBarToolSimple
*tool
= (wxToolBarToolSimple
*)node
->GetData();
652 if ((x
>= tool
->m_x
) && (y
>= tool
->m_y
) &&
653 (x
<= (tool
->m_x
+ tool
->GetWidth())) &&
654 (y
<= (tool
->m_y
+ tool
->GetHeight())))
659 node
= node
->GetNext();
662 return (wxToolBarToolBase
*)NULL
;
665 // ----------------------------------------------------------------------------
666 // tool state change handlers
667 // ----------------------------------------------------------------------------
669 void wxToolBarSimple::DoEnableTool(wxToolBarToolBase
*tool
,
670 bool WXUNUSED(enable
))
675 void wxToolBarSimple::DoToggleTool(wxToolBarToolBase
*tool
,
676 bool WXUNUSED(toggle
))
681 void wxToolBarSimple::DoSetToggle(wxToolBarToolBase
* WXUNUSED(tool
),
682 bool WXUNUSED(toggle
))
687 // Okay, so we've left the tool we're in ... we must check if the tool we're
688 // leaving was a 'sprung push button' and if so, spring it back to the up
690 void wxToolBarSimple::SpringUpButton(int id
)
692 wxToolBarToolBase
*tool
= FindById(id
);
694 if ( tool
&& tool
->CanBeToggled() )
696 if (tool
->IsToggled())
703 // ----------------------------------------------------------------------------
704 // scrolling implementation
705 // ----------------------------------------------------------------------------
708 * pixelsPerUnitX/pixelsPerUnitY: number of pixels per unit (e.g. pixels per text line)
709 * noUnitsX/noUnitsY: : no. units per scrollbar
711 void wxToolBarSimple::SetScrollbars (int pixelsPerUnitX
, int pixelsPerUnitY
,
712 int noUnitsX
, int noUnitsY
,
715 m_xScrollPixelsPerLine
= pixelsPerUnitX
;
716 m_yScrollPixelsPerLine
= pixelsPerUnitY
;
717 m_xScrollLines
= noUnitsX
;
718 m_yScrollLines
= noUnitsY
;
723 // Recalculate scroll bar range and position
724 if (m_xScrollLines
> 0)
726 m_xScrollPosition
= xPos
;
727 SetScrollPos (wxHORIZONTAL
, m_xScrollPosition
, TRUE
);
731 SetScrollbar(wxHORIZONTAL
, 0, 0, 0, FALSE
);
732 m_xScrollPosition
= 0;
735 if (m_yScrollLines
> 0)
737 m_yScrollPosition
= yPos
;
738 SetScrollPos (wxVERTICAL
, m_yScrollPosition
, TRUE
);
742 SetScrollbar(wxVERTICAL
, 0, 0, 0, FALSE
);
743 m_yScrollPosition
= 0;
748 #if 0 //def __WXMSW__
749 ::UpdateWindow ((HWND
) GetHWND());
753 void wxToolBarSimple::OnScroll(wxScrollEvent
& event
)
755 int orient
= event
.GetOrientation();
757 int nScrollInc
= CalcScrollInc(event
);
761 if (orient
== wxHORIZONTAL
)
763 int newPos
= m_xScrollPosition
+ nScrollInc
;
764 SetScrollPos(wxHORIZONTAL
, newPos
, TRUE
);
768 int newPos
= m_yScrollPosition
+ nScrollInc
;
769 SetScrollPos(wxVERTICAL
, newPos
, TRUE
);
772 if (orient
== wxHORIZONTAL
)
774 if (m_xScrollingEnabled
)
775 ScrollWindow(-m_xScrollPixelsPerLine
* nScrollInc
, 0, NULL
);
781 if (m_yScrollingEnabled
)
782 ScrollWindow(0, -m_yScrollPixelsPerLine
* nScrollInc
, NULL
);
787 if (orient
== wxHORIZONTAL
)
789 m_xScrollPosition
+= nScrollInc
;
793 m_yScrollPosition
+= nScrollInc
;
798 int wxToolBarSimple::CalcScrollInc(wxScrollEvent
& event
)
800 int pos
= event
.GetPosition();
801 int orient
= event
.GetOrientation();
804 if (event
.GetEventType() == wxEVT_SCROLL_TOP
)
806 if (orient
== wxHORIZONTAL
)
807 nScrollInc
= - m_xScrollPosition
;
809 nScrollInc
= - m_yScrollPosition
;
811 if (event
.GetEventType() == wxEVT_SCROLL_BOTTOM
)
813 if (orient
== wxHORIZONTAL
)
814 nScrollInc
= m_xScrollLines
- m_xScrollPosition
;
816 nScrollInc
= m_yScrollLines
- m_yScrollPosition
;
818 if (event
.GetEventType() == wxEVT_SCROLL_LINEUP
)
822 if (event
.GetEventType() == wxEVT_SCROLL_LINEDOWN
)
826 if (event
.GetEventType() == wxEVT_SCROLL_PAGEUP
)
828 if (orient
== wxHORIZONTAL
)
829 nScrollInc
= -GetScrollPageSize(wxHORIZONTAL
);
831 nScrollInc
= -GetScrollPageSize(wxVERTICAL
);
833 if (event
.GetEventType() == wxEVT_SCROLL_PAGEDOWN
)
835 if (orient
== wxHORIZONTAL
)
836 nScrollInc
= GetScrollPageSize(wxHORIZONTAL
);
838 nScrollInc
= GetScrollPageSize(wxVERTICAL
);
840 if ((event
.GetEventType() == wxEVT_SCROLL_THUMBTRACK
) ||
841 (event
.GetEventType() == wxEVT_SCROLL_THUMBRELEASE
))
843 if (orient
== wxHORIZONTAL
)
844 nScrollInc
= pos
- m_xScrollPosition
;
846 nScrollInc
= pos
- m_yScrollPosition
;
849 if (orient
== wxHORIZONTAL
)
852 GetClientSize(&w
, &h
);
854 int nMaxWidth
= m_xScrollLines
*m_xScrollPixelsPerLine
;
855 int noPositions
= (int) ( ((nMaxWidth
- w
)/(float)m_xScrollPixelsPerLine
) + 0.5 );
859 if ( (m_xScrollPosition
+ nScrollInc
) < 0 )
860 nScrollInc
= -m_xScrollPosition
; // As -ve as we can go
861 else if ( (m_xScrollPosition
+ nScrollInc
) > noPositions
)
862 nScrollInc
= noPositions
- m_xScrollPosition
; // As +ve as we can go
869 GetClientSize(&w
, &h
);
871 int nMaxHeight
= m_yScrollLines
*m_yScrollPixelsPerLine
;
872 int noPositions
= (int) ( ((nMaxHeight
- h
)/(float)m_yScrollPixelsPerLine
) + 0.5 );
876 if ( (m_yScrollPosition
+ nScrollInc
) < 0 )
877 nScrollInc
= -m_yScrollPosition
; // As -ve as we can go
878 else if ( (m_yScrollPosition
+ nScrollInc
) > noPositions
)
879 nScrollInc
= noPositions
- m_yScrollPosition
; // As +ve as we can go
885 // Adjust the scrollbars - new version.
886 void wxToolBarSimple::AdjustScrollbars()
889 GetClientSize(&w
, &h
);
891 // Recalculate scroll bar range and position
892 if (m_xScrollLines
> 0)
894 int nMaxWidth
= m_xScrollLines
*m_xScrollPixelsPerLine
;
895 int newRange
= (int) ( ((nMaxWidth
)/(float)m_xScrollPixelsPerLine
) + 0.5 );
899 m_xScrollPosition
= wxMin(newRange
, m_xScrollPosition
);
901 // Calculate page size i.e. number of scroll units you get on the
902 // current client window
903 int noPagePositions
= (int) ( (w
/(float)m_xScrollPixelsPerLine
) + 0.5 );
904 if (noPagePositions
< 1)
907 SetScrollbar(wxHORIZONTAL
, m_xScrollPosition
, noPagePositions
, newRange
);
908 SetScrollPageSize(wxHORIZONTAL
, noPagePositions
);
910 if (m_yScrollLines
> 0)
912 int nMaxHeight
= m_yScrollLines
*m_yScrollPixelsPerLine
;
913 int newRange
= (int) ( ((nMaxHeight
)/(float)m_yScrollPixelsPerLine
) + 0.5 );
917 m_yScrollPosition
= wxMin(newRange
, m_yScrollPosition
);
919 // Calculate page size i.e. number of scroll units you get on the
920 // current client window
921 int noPagePositions
= (int) ( (h
/(float)m_yScrollPixelsPerLine
) + 0.5 );
922 if (noPagePositions
< 1)
925 SetScrollbar(wxVERTICAL
, m_yScrollPosition
, noPagePositions
, newRange
);
926 SetScrollPageSize(wxVERTICAL
, noPagePositions
);
930 // Prepare the DC by translating it according to the current scroll position
931 void wxToolBarSimple::PrepareDC(wxDC
& dc
)
933 dc
.SetDeviceOrigin(- m_xScrollPosition
* m_xScrollPixelsPerLine
, - m_yScrollPosition
* m_yScrollPixelsPerLine
);
936 void wxToolBarSimple::GetScrollPixelsPerUnit (int *x_unit
, int *y_unit
) const
938 *x_unit
= m_xScrollPixelsPerLine
;
939 *y_unit
= m_yScrollPixelsPerLine
;
942 int wxToolBarSimple::GetScrollPageSize(int orient
) const
944 if ( orient
== wxHORIZONTAL
)
945 return m_xScrollLinesPerPage
;
947 return m_yScrollLinesPerPage
;
950 void wxToolBarSimple::SetScrollPageSize(int orient
, int pageSize
)
952 if ( orient
== wxHORIZONTAL
)
953 m_xScrollLinesPerPage
= pageSize
;
955 m_yScrollLinesPerPage
= pageSize
;
959 * Scroll to given position (scroll position, not pixel position)
961 void wxToolBarSimple::Scroll (int x_pos
, int y_pos
)
964 ViewStart (&old_x
, &old_y
);
965 if (((x_pos
== -1) || (x_pos
== old_x
)) && ((y_pos
== -1) || (y_pos
== old_y
)))
970 m_xScrollPosition
= x_pos
;
971 SetScrollPos (wxHORIZONTAL
, x_pos
, TRUE
);
975 m_yScrollPosition
= y_pos
;
976 SetScrollPos (wxVERTICAL
, y_pos
, TRUE
);
980 #if 0 //def __WXMSW__
981 UpdateWindow ((HWND
) GetHWND());
985 void wxToolBarSimple::EnableScrolling (bool x_scroll
, bool y_scroll
)
987 m_xScrollingEnabled
= x_scroll
;
988 m_yScrollingEnabled
= y_scroll
;
991 void wxToolBarSimple::GetVirtualSize (int *x
, int *y
) const
993 *x
= m_xScrollPixelsPerLine
* m_xScrollLines
;
994 *y
= m_yScrollPixelsPerLine
* m_yScrollLines
;
997 // Where the current view starts from
998 void wxToolBarSimple::ViewStart (int *x
, int *y
) const
1000 *x
= m_xScrollPosition
;
1001 *y
= m_yScrollPosition
;
1004 #endif // wxUSE_TOOLBAR_SIMPLE