566d84a7c3
manage their own scrollbars with the help of a sizer or other user clues (SetVirtualSizeHints) without the need for an ancillary container. Added SetSizerAndFit convenience method. SetSizer now enables/disables AutoLayout automagically. Logic bugfix for scrollsub sample. Syntax bugfix in parser.y. Compiler warning fix in textctrl.cpp. Modified Files: docs/latex/wx/scrolwin.tex docs/latex/wx/sizer.tex docs/latex/wx/window.tex include/wx/scrolwin.h include/wx/sizer.h include/wx/window.h include/wx/generic/scrolwin.h include/wx/gtk/scrolwin.h samples/scrollsub/scrollsub.cpp src/common/parser.y src/common/sizer.cpp src/common/wincmn.cpp src/generic/scrlwing.cpp src/gtk/scrolwin.cpp src/msw/textctrl.cpp git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@15210 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
410 lines
15 KiB
TeX
410 lines
15 KiB
TeX
\section{\class{wxScrolledWindow}}\label{wxscrolledwindow}
|
|
|
|
The wxScrolledWindow class manages scrolling for its client area, transforming
|
|
the coordinates according to the scrollbar positions, and setting the
|
|
scroll positions, thumb sizes and ranges according to the area in view.
|
|
|
|
As with all windows, an application can draw onto a wxScrolledWindow using a \helpref{device context}{dcoverview}.
|
|
|
|
You have the option of handling the OnPaint handler
|
|
or overriding the \helpref{OnDraw}{wxscrolledwindowondraw} function, which is passed
|
|
a pre-scrolled device context (prepared by \helpref{PrepareDC}{wxscrolledwindowpreparedc}).
|
|
|
|
If you don't wish to calculate your own scrolling, you must call PrepareDC when not drawing from
|
|
within OnDraw, to set the device origin for the device context according to the current
|
|
scroll position.
|
|
|
|
A wxScrolledWindow will normally scroll itself and therefore its child windows as well. It
|
|
might however be desired to scroll a different window than itself: e.g. when designing a
|
|
spreadsheet, you will normally only have to scroll the (usually white) cell area, whereas the
|
|
(usually grey) label area will scroll very differently. For this special purpose, you can
|
|
call \helpref{SetTargetWindow}{wxscrolledwindowsettargetwindow} which means that pressing
|
|
the scrollbars will scroll a different window.
|
|
|
|
Note that the underlying system knows nothing about scrolling coordinates, so that all system
|
|
functions (mouse events, expose events, refresh calls etc) as well as the position of subwindows
|
|
are relative to the "physical" origin of the scrolled window. If the user insert a child window at
|
|
position (10,10) and scrolls the window down 100 pixels (moving the child window out of the visible
|
|
area), the child window will report a position of (10,-90).
|
|
|
|
|
|
\wxheading{Derived from}
|
|
|
|
\helpref{wxPanel}{wxpanel}\\
|
|
\helpref{wxWindow}{wxwindow}\\
|
|
\helpref{wxEvtHandler}{wxevthandler}\\
|
|
\helpref{wxObject}{wxobject}
|
|
|
|
\wxheading{Include files}
|
|
|
|
<wx/scrolwin.h>
|
|
|
|
\wxheading{Window styles}
|
|
|
|
\twocolwidtha{5cm}
|
|
\begin{twocollist}\itemsep=0pt
|
|
\twocolitem{\windowstyle{wxRETAINED}}{Uses a backing pixmap to speed refreshes. Motif only.}
|
|
\end{twocollist}
|
|
|
|
See also \helpref{window styles overview}{windowstyles}.
|
|
|
|
\wxheading{Remarks}
|
|
|
|
Use wxScrolledWindow for applications where the user scrolls by a fixed amount, and
|
|
where a `page' can be interpreted to be the current visible portion of the window. For
|
|
more sophisticated applications, use the wxScrolledWindow implementation as a guide
|
|
to build your own scroll behaviour.
|
|
|
|
\wxheading{See also}
|
|
|
|
\helpref{wxScrollBar}{wxscrollbar}, \helpref{wxClientDC}{wxclientdc}, \helpref{wxPaintDC}{wxpaintdc}
|
|
|
|
\latexignore{\rtfignore{\wxheading{Members}}}
|
|
|
|
\membersection{wxScrolledWindow::wxScrolledWindow}\label{wxscrolledwindowconstr}
|
|
|
|
\func{}{wxScrolledWindow}{\void}
|
|
|
|
Default constructor.
|
|
|
|
\func{}{wxScrolledWindow}{\param{wxWindow*}{ parent}, \param{wxWindowID }{id = -1},\rtfsp
|
|
\param{const wxPoint\& }{pos = wxDefaultPosition}, \param{const wxSize\& }{size = wxDefaultSize},\rtfsp
|
|
\param{long}{ style = wxHSCROLL \pipe wxVSCROLL}, \param{const wxString\& }{name = ``scrolledWindow"}}
|
|
|
|
Constructor.
|
|
|
|
\wxheading{Parameters}
|
|
|
|
\docparam{parent}{Parent window.}
|
|
|
|
\docparam{id}{Window identifier. A value of -1 indicates a default value.}
|
|
|
|
\docparam{pos}{Window position. If a position of (-1, -1) is specified then a default position
|
|
is chosen.}
|
|
|
|
\docparam{size}{Window size. If a size of (-1, -1) is specified then the window is sized
|
|
appropriately.}
|
|
|
|
\docparam{style}{Window style. See \helpref{wxScrolledWindow}{wxscrolledwindow}.}
|
|
|
|
\docparam{name}{Window name.}
|
|
|
|
\wxheading{Remarks}
|
|
|
|
The window is initially created without visible scrollbars.
|
|
Call \helpref{wxScrolledWindow::SetScrollbars}{wxscrolledwindowsetscrollbars} to
|
|
specify how big the virtual window size should be.
|
|
|
|
\membersection{wxScrolledWindow::\destruct{wxScrolledWindow}}
|
|
|
|
\func{}{\destruct{wxScrolledWindow}}{\void}
|
|
|
|
Destructor.
|
|
|
|
\membersection{wxScrolledWindow::CalcScrolledPosition}\label{wxscrolledwindowcalcscrolledposition}
|
|
|
|
\constfunc{void}{CalcScrolledPosition}{
|
|
\param{int }{x},
|
|
\param{int }{y},
|
|
\param{int *}{xx}
|
|
\param{int *}{yy}}
|
|
|
|
Translates the logical coordinates to the device ones. For example, if a window is
|
|
scrolled 10 pixels to the bottom, the device coordinates of the origin are (0, 0)
|
|
(as always), but the logical coordinates are (0, 10) and so the call to
|
|
CalcScrolledPosition(0, 10, \&xx, \&yy) will return 0 in yy.
|
|
|
|
\wxheading{See also}
|
|
|
|
\helpref{CalcUnscrolledPosition}{wxscrolledwindowcalcunscrolledposition}
|
|
|
|
\pythonnote{The wxPython version of this methods accepts only two
|
|
parameters and returns xx and yy as a tuple of values.}
|
|
|
|
\perlnote{In wxPerl this method takes two parameters and returns a
|
|
2-element list {\tt ( xx, yy )}.}
|
|
|
|
\membersection{wxScrolledWindow::CalcUnscrolledPosition}\label{wxscrolledwindowcalcunscrolledposition}
|
|
|
|
\constfunc{void}{CalcUnscrolledPosition}{
|
|
\param{int }{x},
|
|
\param{int }{y},
|
|
\param{int *}{xx}
|
|
\param{int *}{yy}}
|
|
|
|
Translates the device coordinates to the logical ones. For example, if a window is
|
|
scrolled 10 pixels to the bottom, the device coordinates of the origin are (0, 0)
|
|
(as always), but the logical coordinates are (0, 10) and so the call to
|
|
CalcUnscrolledPosition(0, 0, \&xx, \&yy) will return 10 in yy.
|
|
|
|
\wxheading{See also}
|
|
|
|
\helpref{CalcScrolledPosition}{wxscrolledwindowcalcscrolledposition}
|
|
|
|
\pythonnote{The wxPython version of this methods accepts only two
|
|
parameters and returns xx and yy as a tuple of values.}
|
|
|
|
\perlnote{In wxPerl this method takes two parameters and returns a
|
|
2-element list {\tt ( xx, yy )}.}
|
|
|
|
\membersection{wxScrolledWindow::Create}\label{wxscrolledwindowcreate}
|
|
|
|
\func{bool}{Create}{\param{wxWindow*}{ parent}, \param{wxWindowID }{id = -1},\rtfsp
|
|
\param{const wxPoint\& }{pos = wxDefaultPosition}, \param{const wxSize\& }{size = wxDefaultSize},\rtfsp
|
|
\param{long}{ style = wxHSCROLL \pipe wxVSCROLL}, \param{const wxString\& }{name = ``scrolledWindow"}}
|
|
|
|
Creates the window for two-step construction. Derived classes
|
|
should call or replace this function. See \helpref{wxScrolledWindow::wxScrolledWindow}{wxscrolledwindowconstr}\rtfsp
|
|
for details.
|
|
|
|
\membersection{wxScrolledWindow::EnableScrolling}\label{wxscrolledwindowenablescrolling}
|
|
|
|
\func{void}{EnableScrolling}{\param{const bool}{ xScrolling}, \param{const bool}{ yScrolling}}
|
|
|
|
Enable or disable physical scrolling in the given direction. Physical
|
|
scrolling is the physical transfer of bits up or down the
|
|
screen when a scroll event occurs. If the application scrolls by a
|
|
variable amount (e.g. if there are different font sizes) then physical
|
|
scrolling will not work, and you should switch it off. Note that you
|
|
will have to reposition child windows yourself, if physical scrolling
|
|
is disabled.
|
|
|
|
\wxheading{Parameters}
|
|
|
|
\docparam{xScrolling}{If TRUE, enables physical scrolling in the x direction.}
|
|
|
|
\docparam{yScrolling}{If TRUE, enables physical scrolling in the y direction.}
|
|
|
|
\wxheading{Remarks}
|
|
|
|
Physical scrolling may not be available on all platforms. Where it is available, it is enabled
|
|
by default.
|
|
|
|
\membersection{wxScrolledWindow::GetScrollPixelsPerUnit}\label{wxscrolledwindowgetscrollpixelsperunit}
|
|
|
|
\constfunc{void}{GetScrollPixelsPerUnit}{\param{int* }{xUnit}, \param{int* }{yUnit}}
|
|
|
|
Get the number of pixels per scroll unit (line), in each direction, as set
|
|
by \helpref{wxScrolledWindow::SetScrollbars}{wxscrolledwindowsetscrollbars}. A value of zero indicates no
|
|
scrolling in that direction.
|
|
|
|
\wxheading{Parameters}
|
|
|
|
\docparam{xUnit}{Receives the number of pixels per horizontal unit.}
|
|
|
|
\docparam{yUnit}{Receives the number of pixels per vertical unit.}
|
|
|
|
\wxheading{See also}
|
|
|
|
\helpref{wxScrolledWindow::SetScrollbars}{wxscrolledwindowsetscrollbars},\rtfsp
|
|
\helpref{wxScrolledWindow::GetVirtualSize}{wxscrolledwindowgetvirtualsize}
|
|
|
|
\pythonnote{The wxPython version of this methods accepts no
|
|
parameters and returns a tuple of values for xUnit and yUnit.}
|
|
|
|
\perlnote{In wxPerl this method takes no parameters and returns a
|
|
2-element list {\tt ( xUnit, yUnit )}.}
|
|
|
|
\membersection{wxScrolledWindow::GetVirtualSize}\label{wxscrolledwindowgetvirtualsize}
|
|
|
|
\constfunc{void}{GetVirtualSize}{\param{int* }{x}, \param{int* }{y}}
|
|
|
|
Gets the size in device units of the scrollable window area (as
|
|
opposed to the client size, which is the area of the window currently
|
|
visible).
|
|
|
|
\wxheading{Parameters}
|
|
|
|
\docparam{x}{Receives the length of the scrollable window, in pixels.}
|
|
|
|
\docparam{y}{Receives the height of the scrollable window, in pixels.}
|
|
|
|
\wxheading{Remarks}
|
|
|
|
Use \helpref{wxDC::DeviceToLogicalX}{wxdcdevicetologicalx} and \helpref{wxDC::DeviceToLogicalY}{wxdcdevicetologicaly}\rtfsp
|
|
to translate these units to logical units.
|
|
|
|
\wxheading{See also}
|
|
|
|
\helpref{wxScrolledWindow::SetScrollbars}{wxscrolledwindowsetscrollbars},\rtfsp
|
|
\helpref{wxScrolledWindow::GetScrollPixelsPerUnit}{wxscrolledwindowgetscrollpixelsperunit}
|
|
|
|
\pythonnote{The wxPython version of this methods accepts no
|
|
parameters and returns a tuple of values for x and y.}
|
|
|
|
\perlnote{In wxPerl this method takes no parameters and returns a
|
|
2-element list {\tt ( x, y )}.}
|
|
|
|
\membersection{wxScrolledWindow::IsRetained}\label{wxscrolledwindowisretained}
|
|
|
|
\constfunc{bool}{IsRetained}{\void}
|
|
|
|
Motif only: TRUE if the window has a backing bitmap.
|
|
|
|
\membersection{wxScrolledWindow::PrepareDC}\label{wxscrolledwindowpreparedc}
|
|
|
|
\func{void}{PrepareDC}{\param{wxDC\& }{dc}}
|
|
|
|
Call this function to prepare the device context for drawing a scrolled image. It
|
|
sets the device origin according to the current scroll position.
|
|
|
|
PrepareDC is called automatically within the default wxScrolledWindow::OnPaint event
|
|
handler, so your \helpref{wxScrolledWindow::OnDraw}{wxscrolledwindowondraw} override
|
|
will be passed a 'pre-scrolled' device context. However, if you wish to draw from
|
|
outside of OnDraw (via OnPaint), or you wish to implement OnPaint yourself, you must
|
|
call this function yourself. For example:
|
|
|
|
\begin{verbatim}
|
|
void MyWindow::OnEvent(wxMouseEvent& event)
|
|
{
|
|
wxClientDC dc(this);
|
|
PrepareDC(dc);
|
|
|
|
dc.SetPen(*wxBLACK_PEN);
|
|
float x, y;
|
|
event.Position(&x, &y);
|
|
if (xpos > -1 && ypos > -1 && event.Dragging())
|
|
{
|
|
dc.DrawLine(xpos, ypos, x, y);
|
|
}
|
|
xpos = x;
|
|
ypos = y;
|
|
}
|
|
\end{verbatim}
|
|
|
|
\membersection{wxScrolledWindow::OnDraw}\label{wxscrolledwindowondraw}
|
|
|
|
\func{virtual void}{OnDraw}{\param{wxDC\& }{dc}}
|
|
|
|
Called by the default paint event handler to allow the application to define
|
|
painting behaviour without having to worry about calling
|
|
\helpref{wxScrolledWindow::PrepareDC}{wxscrolledwindowpreparedc}.
|
|
|
|
Instead of overriding this function you may also just process the paint event
|
|
in the derived class as usual, but then you will have to call PrepareDC()
|
|
yourself.
|
|
|
|
\membersection{wxScrolledWindow::Scroll}\label{wxscrolledwindowscroll}
|
|
|
|
\func{void}{Scroll}{\param{int}{ x}, \param{int}{ y}}
|
|
|
|
Scrolls a window so the view start is at the given point.
|
|
|
|
\wxheading{Parameters}
|
|
|
|
\docparam{x}{The x position to scroll to, in scroll units.}
|
|
|
|
\docparam{y}{The y position to scroll to, in scroll units.}
|
|
|
|
\wxheading{Remarks}
|
|
|
|
The positions are in scroll units, not pixels, so to convert to pixels you
|
|
will have to multiply by the number of pixels per scroll increment.
|
|
If either parameter is -1, that position will be ignored (no change in
|
|
that direction).
|
|
|
|
\wxheading{See also}
|
|
|
|
\helpref{wxScrolledWindow::SetScrollbars}{wxscrolledwindowsetscrollbars},\rtfsp
|
|
\helpref{wxScrolledWindow::GetScrollPixelsPerUnit}{wxscrolledwindowgetscrollpixelsperunit}
|
|
|
|
\membersection{wxScrolledWindow::SetScrollbars}\label{wxscrolledwindowsetscrollbars}
|
|
|
|
\func{void}{SetScrollbars}{\param{int}{ pixelsPerUnitX}, \param{int}{ pixelsPerUnitY},\rtfsp
|
|
\param{int}{ noUnitsX}, \param{int}{ noUnitsY},\rtfsp
|
|
\param{int }{xPos = 0}, \param{int}{ yPos = 0},\rtfsp
|
|
\param{bool }{noRefresh = FALSE}}
|
|
|
|
Sets up vertical and/or horizontal scrollbars.
|
|
|
|
\wxheading{Parameters}
|
|
|
|
\docparam{pixelsPerUnitX}{Pixels per scroll unit in the horizontal direction.}
|
|
|
|
\docparam{pixelsPerUnitY}{Pixels per scroll unit in the vertical direction.}
|
|
|
|
\docparam{noUnitsX}{Number of units in the horizontal direction.}
|
|
|
|
\docparam{noUnitsY}{Number of units in the vertical direction.}
|
|
|
|
\docparam{xPos}{Position to initialize the scrollbars in the horizontal direction, in scroll units.}
|
|
|
|
\docparam{yPos}{Position to initialize the scrollbars in the vertical direction, in scroll units.}
|
|
|
|
\docparam{noRefresh}{Will not refresh window if TRUE.}
|
|
|
|
\wxheading{Remarks}
|
|
|
|
The first pair of parameters give the number of pixels per `scroll step', i.e. amount
|
|
moved when the up or down scroll arrows are pressed.
|
|
The second pair gives the length of scrollbar in scroll steps, which sets the size of the virtual
|
|
window.
|
|
|
|
{\it xPos} and {\it yPos} optionally specify a position to scroll to immediately.
|
|
|
|
For example, the following gives a window horizontal and vertical
|
|
scrollbars with 20 pixels per scroll step, and a size of 50 steps (1000
|
|
pixels) in each direction.
|
|
|
|
\begin{verbatim}
|
|
window->SetScrollbars(20, 20, 50, 50);
|
|
\end{verbatim}
|
|
|
|
wxScrolledWindow manages the page size itself,
|
|
using the current client window size as the page size.
|
|
|
|
Note that for more sophisticated scrolling applications, for example where
|
|
scroll steps may be variable according to the position in the document, it will be
|
|
necessary to derive a new class from wxWindow, overriding {\bf OnSize} and
|
|
adjusting the scrollbars appropriately.
|
|
|
|
\wxheading{See also}
|
|
|
|
\helpref{wxWindow::SetVirtualSize}{wxwindowsetvirtualsize}
|
|
|
|
\membersection{wxScrolledWindow::SetScrollRate}\label{wxscrolledwindowsetscrollrate}
|
|
|
|
\func{void}{SetScrollRate}{\param{int}{xstep}, \param{int}{ystep}}
|
|
|
|
Set the horizontal and vertical scrolling increment only. See the pixelsPerUnit
|
|
parameter in SetScrollbars.
|
|
|
|
\membersection{wxScrolledWindow::SetTargetWindow}\label{wxscrolledwindowsettargetwindow}
|
|
|
|
\func{void}{SetTargetWindow}{\param{wxWindow* }{window}}
|
|
|
|
Call this function to tell wxScrolledWindow to perform the actual scrolling on
|
|
a different window (not on itself).
|
|
|
|
\membersection{wxScrolledWindow::GetViewStart}\label{wxscrolledwindowgetviewstart}
|
|
|
|
\constfunc{void}{GetViewStart}{\param{int* }{x}, \param{int* }{ y}}
|
|
|
|
Get the position at which the visible portion of the window starts.
|
|
|
|
\wxheading{Parameters}
|
|
|
|
\docparam{x}{Receives the first visible x position in scroll units.}
|
|
|
|
\docparam{y}{Receives the first visible y position in scroll units.}
|
|
|
|
\wxheading{Remarks}
|
|
|
|
If either of the scrollbars is not at the home position, {\it x} and/or
|
|
\rtfsp{\it y} will be greater than zero. Combined with \helpref{wxWindow::GetClientSize}{wxwindowgetclientsize},
|
|
the application can use this function to efficiently redraw only the
|
|
visible portion of the window. The positions are in logical scroll
|
|
units, not pixels, so to convert to pixels you will have to multiply
|
|
by the number of pixels per scroll increment.
|
|
|
|
\wxheading{See also}
|
|
|
|
\helpref{wxScrolledWindow::SetScrollbars}{wxscrolledwindowsetscrollbars}
|
|
|
|
\pythonnote{The wxPython version of this methods accepts no
|
|
parameters and returns a tuple of values for x and y.}
|
|
|
|
\perlnote{In wxPerl this method takes no parameters and returns a
|
|
2-element list {\tt ( x, y )}.}
|
|
|