In the name of this class, “V” may stand for “variable” because it can be used for scrolling rows of variable heights; “virtual”, because it is not necessary to know the heights of all rows in advance – only those which are shown on the screen need to be measured; or even “vertical”, because this class only supports scrolling vertically.
In any case, this is a generalization of wx.Scrolled which can be only used when all rows have the same heights. It lacks some other wx.Scrolled features however, notably it can’t scroll specific pixel sizes of the window or its exact client area size.
To use this class, you need to derive from it and implement the OnGetRowHeight
pure virtual method. You also must call SetRowCount
to let the base class know how many rows it should display, but from that moment on the scrolling is handled entirely by wx.VScrolledWindow. You only need to draw the visible part of contents in your OnPaint()
method as usual. You should use GetVisibleRowsBegin
and GetVisibleRowsEnd
to select the lines to display. Note that the device context origin is not shifted so the first visible row always appears at the point (0, 0) in physical as well as logical coordinates.
The following functions provide backwards compatibility for applications originally built using wx.VScrolledWindow in 2.6 or 2.8. Originally, wx.VScrolledWindow referred to scrolling “lines”. We now use “units” in wx.VarScrollHelperBase to avoid implying any orientation (since the functions are used for both horizontal and vertical scrolling in derived classes). And in the new wx.VScrolledWindow and wx.HScrolledWindow classes, we refer to them as “rows” and “columns”, respectively. This is to help clear some confusion in not only those classes, but also in wx.HVScrolledWindow where functions are inherited from both. You are encouraged to update any existing code using these function to use the new replacements mentioned below, and avoid using these functions for any new code as they are deprecated.
GetFirstVisibleLine() |
Deprecated for |
GetLastVisibleLine() |
Deprecated for |
GetLineCount() |
Deprecated for |
HitTest(x, y) |
|
HitTest(pt) |
Deprecated for |
OnGetLineHeight(line) |
Deprecated for |
OnGetLinesHint(lineMin, lineMax) |
Deprecated for |
RefreshLine(line) |
Deprecated for |
RefreshLines(from_, to_) |
Deprecated for |
ScrollLines(lines) |
Deprecated for |
ScrollPages(pages) |
Deprecated for |
ScrollToLine(line) |
Deprecated for |
SetLineCount(count) |
Deprecated for |
Default constructor, you must call |
|
Same as the non-default constructor, but returns a status code: |
|
Deprecated compatibility helper. |
|
Deprecated compatibility helper. |
|
Deprecated compatibility helper. |
|
Deprecated compatibility helper. |
|
Deprecated compatibility helper. |
|
Deprecated compatibility helper. |
|
Deprecated compatibility helper. |
|
Deprecated compatibility helper. |
|
Deprecated compatibility helper. |
|
Deprecated compatibility helper. |
See |
wx.
VScrolledWindow
(Panel, VarVScrollHelper)¶Possible constructors:
VScrolledWindow()
VScrolledWindow(parent, id=ID_ANY, pos=DefaultPosition,
size=DefaultSize, style=0, name=PanelNameStr)
In the name of this class, “V” may stand for “variable” because it can be used for scrolling rows of variable heights; “virtual”, because it is not necessary to know the heights of all rows in advance only those which are shown on the screen need to be measured; or even “vertical”, because this class only supports scrolling vertically.
__init__
(self, *args, **kw)¶__init__ (self)
Default constructor, you must call Create
later.
__init__ (self, parent, id=ID_ANY, pos=DefaultPosition, size=DefaultSize, style=0, name=PanelNameStr)
This is the normal constructor, no need to call Create
after using this constructor.
parent (wx.Window) – The parent window, must not be None
.
id (wx.WindowID) – The identifier of this window, wx.ID_ANY
by default.
pos (wx.Point) – The initial window position.
size (wx.Size) – The initial window size.
style (long) – The window style. There are no special style bits defined for this class.
name (string) – The name for this window; usually not used.
Note
VSCROLL
is always automatically added to the style, there is no need to specify it explicitly.
Create
(self, parent, id=ID_ANY, pos=DefaultPosition, size=DefaultSize, style=0, name=PanelNameStr)¶Same as the non-default constructor, but returns a status code: True
if ok, False
if the window couldn’t be created.
Just as with the constructor, the VSCROLL
style is always used, there is no need to specify it explicitly.
GetClassDefaultAttributes
(variant=WINDOW_VARIANT_NORMAL)¶variant (WindowVariant) –
GetFirstVisibleLine
(self)¶Deprecated compatibility helper.
int
Deprecated
Use GetVisibleRowsBegin instead.
GetLastVisibleLine
(self)¶Deprecated compatibility helper.
int
Deprecated
Use GetVisibleRowsEnd instead.
GetLineCount
(self)¶Deprecated compatibility helper.
int
Deprecated
Use GetRowCount instead.
HitTest
(self, *args)¶Deprecated compatibility helper.
RefreshLine
(self, line)¶Deprecated compatibility helper.
Deprecated
Use RefreshRow instead.
RefreshLines
(self, from_, to_)¶Deprecated compatibility helper.
Deprecated
Use RefreshRows instead.
ScrollLines
(self, lines)¶Deprecated compatibility helper.
bool
Deprecated
Use ScrollRows instead.
ScrollPages
(self, pages)¶Deprecated compatibility helper.
bool
Deprecated
Use ScrollRowPages instead.
ScrollToLine
(self, line)¶Deprecated compatibility helper.
bool
Deprecated
Use ScrollToRow instead.
SetLineCount
(self, count)¶Deprecated compatibility helper.
Deprecated
Use SetRowCount instead.
FirstVisibleLine
¶LastVisibleLine
¶LineCount
¶See GetLineCount
and SetLineCount