]> git.saurik.com Git - wxWidgets.git/blame - docs/latex/wx/vscrolledwindow.tex
Big wxGL classes refactoring/cleanup:
[wxWidgets.git] / docs / latex / wx / vscrolledwindow.tex
CommitLineData
f18eaf26
VZ
1%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2%% Name: vscrolledwindow.tex (moved from vscroll.tex)
3%% Purpose: wxVScrolledWindow Documentation
4%% Author: Vadim Zeitlin, Bryan Petty
5%% Modified by:
6%% Created: 2003-05-30, modified 2007-04-04
7%% RCS-ID: $Id$
8%% Copyright: (c) 2003, 2007 wxWidgets Team
9%% License: wxWindows Licence
10%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
11
12\section{\class{wxVScrolledWindow}}\label{wxvscrolledwindow}
13
14In the name of this class, "V" may stand for "variable" because it can be
15used for scrolling rows of variable heights; "virtual", because it is not
16necessary to know the heights of all rows in advance -- only those which
17are shown on the screen need to be measured; or even "vertical", because
18this class only supports scrolling vertically.
19
20In any case, this is a generalization of the
21\helpref{wxScrolledWindow}{wxscrolledwindow} class which can be only used when
22all rows have the same heights. It lacks some other wxScrolledWindow features
23however, notably it can't scroll only a rectangle of the window and not its
24entire client area.
25
26To use this class, you need to derive from it and implement the
27\helpref{OnGetRowHeight()}{wxvarvscrollhelperongetrowheight} pure virtual
28method. You also must call \helpref{SetRowCount}{wxvarvscrollhelpersetrowcount}
29to let the base class know how many rows it should display, but from that
30moment on the scrolling is handled entirely by wxVScrolledWindow. You only
31need to draw the visible part of contents in your {\tt OnPaint()} method as
32usual. You should use \helpref{GetVisibleRowsBegin()}{wxvarvscrollhelpergetvisiblerowsbegin}
33and \helpref{GetVisibleRowsEnd()}{wxvarvscrollhelpergetvisiblerowsend} to
34select the lines to display. Note that the device context origin is not shifted
35so the first visible row always appears at the point $(0, 0)$ in physical as
36well as logical coordinates.
37
38\wxheading{Derived from}
39
40\helpref{wxPanel}{wxpanel}\\
41\helpref{wxWindow}{wxwindow}\\
42\helpref{wxEvtHandler}{wxevthandler}\\
43\helpref{wxObject}{wxobject}
44
45\helpref{wxVarVScrollHelper}{wxvarvscrollhelper}\\
46\helpref{wxVarScrollHelperBase}{wxvarscrollhelperbase}
47
48\wxheading{Include files}
49
50<wx/vscroll.h>
51
52\wxheading{See also}
53
54\helpref{wxHScrolledWindow}{wxhscrolledwindow},
55\rtfsp\helpref{wxHVScrolledWindow}{wxhvscrolledwindow}
56
57\latexignore{\rtfignore{\wxheading{Members}}}
58
59
60%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
61%% wxVarVScrollLegacyAdapter Compatibility Functions
62%% This section will need to be removed when 2.8 compatibility is removed.
63%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
64
65\membersection{wxWidgets 2.6 and 2.8 Compatibility Functions}\label{wxvscrolledwindowbackwardcompatibility}
66
67The following functions provide backwards compatibility for applications
68originally built using wxVScrolledWindow in 2.6 or 2.8. Originally,
69wxVScrolledWindow referred to scrolling "lines". We now use "units" in
70wxVarScrollHelperBase to avoid implying any orientation (since the functions
71are used for both horizontal and vertical scrolling in derived classes). And
72in the new wxVScrolledWindow and wxHScrolledWindow classes, we refer to them
73as "rows" and "columns", respectively. This is to help clear some confusion
74in not only those classes, but also in wxHVScrolledWindow where functions
75are inherited from both.
76
77You are encouraged to update any existing code using these function to use
78the new replacements mentioned below, and avoid using these functions for
79any new code as they are deprecated.
80
81\constfunc{size\_t}{GetFirstVisibleLine}{\void}
82
83Deprecated for \helpref{GetVisibleRowsBegin()}{wxvarvscrollhelpergetvisiblerowsbegin}.
84
85\constfunc{size\_t}{GetLastVisibleLine}{\void}
86
87Deprecated for \helpref{GetVisibleRowsEnd()}{wxvarvscrollhelpergetvisiblerowsend}.
88
89This function originally had a slight design flaw in that it was possible to
90return \texttt{(size\_t)-1} (ie: a large positive number) if the scroll
91position was 0 and the first line wasn't completely visible.
92
93\constfunc{size\_t}{GetLineCount}{\void}
94
95Deprecated for \helpref{GetRowCount()}{wxvarvscrollhelpergetrowcount}.
96
97\constfunc{virtual wxCoord}{OnGetLineHeight}{\param{size\_t }{line}}
98
99Deprecated for \helpref{OnGetRowHeight()}{wxvarvscrollhelperongetrowheight}.
100
101\constfunc{virtual void}{OnGetLinesHint}{\param{size\_t }{lineMin}, \param{size\_t }{lineMax}}
102
103Deprecated for \helpref{OnGetRowsHeightHint()}{wxvarvscrollhelperongetrowsheighthint}.
104
105\func{virtual void}{RefreshLine}{\param{size\_t }{line}}
106
107Deprecated for \helpref{RefreshRow()}{wxvarvscrollhelperrefreshrow}.
108
109\func{virtual void}{RefreshLines}{\param{size\_t }{from}, \param{size\_t }{to}}
110
111Deprecated for \helpref{RefreshRows()}{wxvarvscrollhelperrefreshrows}.
112
113\func{virtual bool}{ScrollLines}{\param{int }{lines}}
114
115Deprecated for \helpref{ScrollRows()}{wxvarvscrollhelperscrollrows}.
116
117\func{virtual bool}{ScrollPages}{\param{int }{pages}}
118
119Deprecated for \helpref{ScrollRowPages()}{wxvarvscrollhelperscrollrowpages}.
120
121\func{bool}{ScrollToLine}{\param{size\_t }{line}}
122
123Deprecated for \helpref{ScrollToRow()}{wxvarvscrollhelperscrolltorow}.
124
125\func{void}{SetLineCount}{\param{size\_t }{count}}
126
127Deprecated for \helpref{SetRowCount()}{wxvarvscrollhelpersetrowcount}.
128
129%%%%%%%%%%%%%%%%%%%%%%% END COMPATIBILITY FUNCTIONS %%%%%%%%%%%%%%%%%%%%%%%%%%
130%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
131
132
133\membersection{wxVScrolledWindow::wxVScrolledWindow}\label{wxvscrolledwindowwxvscrolledwindow}
134
135\func{}{wxVScrolledWindow}{\void}
136
137Default constructor, you must call \helpref{Create()}{wxvscrolledwindowcreate}
138later.
139
140\func{}{wxVScrolledWindow}{\param{wxWindow* }{parent}, \param{wxWindowID }{id = wxID\_ANY}, \param{const wxPoint\& }{pos = wxDefaultPosition}, \param{const wxSize\& }{size = wxDefaultSize}, \param{long }{style = 0}, \param{const wxString\& }{name = wxPanelNameStr}}
141
142This is the normal constructor, no need to call {\tt Create()} after using this one.
143
144Note that {\tt wxVSCROLL} is always automatically added to our style, there is
145no need to specify it explicitly.
146
147\wxheading{Parameters}
148
149\docparam{parent}{The parent window, must not be {\tt NULL}}
150
151\docparam{id}{The identifier of this window, {\tt wxID\_ANY} by default}
152
153\docparam{pos}{The initial window position}
154
155\docparam{size}{The initial window size}
156
157\docparam{style}{The window style. There are no special style bits defined for
158this class.}
159
160\docparam{name}{The name for this window; usually not used}
161
162
163\membersection{wxVScrolledWindow::Create}\label{wxvscrolledwindowcreate}
164
165\func{bool}{Create}{\param{wxWindow* }{parent}, \param{wxWindowID }{id = wxID\_ANY}, \param{const wxPoint\& }{pos = wxDefaultPosition}, \param{const wxSize\& }{size = wxDefaultSize}, \param{long }{style = 0}, \param{const wxString\& }{name = wxPanelNameStr}}
166
167Same as the \helpref{non-default constuctor}{wxvscrolledwindowwxvscrolledwindow}
168but returns status code: {\tt true} if ok, {\tt false} if the window couldn't
169be created.
170
171Just as with the constructor above, the {\tt wxVSCROLL} style is always used,
172there is no need to specify it explicitly.
173