The tabular widget allows a user to select one (or more) row(s)
using the mouse or keyboard selection. The selected rows are the
main property and are returned by svalue through their key (from
the column specified by chosen.col
), or by index. The
change handler changes on double-click event. Use add handler
click to respond to a change in selection.
For gtable one can pass in row(s) to select by index (when index=TRUE) or by match among the values in the chosen column. For setting by index, a value of 0L or integer(0) will clear the current selection
For GTable
objects the [
and [<-
methods are
(mostly) implemented. The [
method allows one to access the
object using the regular matrix notation (but there is no list
notation, e.g. $
or [[
, defined). The [<-
method is available, but for most toolkits is restricted: one can
not add columns, add rows, remove columns, remove rows, or change
the type of the column. For all of these actions, one can reassign
the items being displayed through the idiom obj[] <-
new_items
. This allows the widget to resize or redo the column
renderers.
The change handler for GTable
is called when the selection
changes. This is often the result of a click event (but need not
be), although we alias to addHandlerClicked
. For double
click events, see addHandlerDoubleclick
.
Double clicking is used to activate an item (single click is selection). We also bind pressing the Return key on an item to initiate this signal
For GTable
, visibility refers to which rows are currently
shown, not whether the widget itself is shown or hidden. (For the
latter, place the widget into a container and adjust that). One
can use this method to perform filtering by adjusting which rows
are displayed according to some criteria that returns a logical.
For GTable
the size<-
method is overridden to allow
one to specify the column widths. To do so, pass in the values for
width
, height
or column.widths
as named components
of a list. The value of column.widths
should be a numeric
vector of pixel widths of length matching the number of columns.
gtable(
items,
multiple = FALSE,
chosen.col = 1,
icon.col = NULL,
tooltip.col = NULL,
handler = NULL,
action = NULL,
container = NULL,
...,
toolkit = guiToolkit()
).gtable(
toolkit,
items,
multiple = FALSE,
chosen.col = 1,
icon.col = NULL,
tooltip.col = NULL,
handler = NULL,
action = NULL,
container = NULL,
...
)
# S3 method for GTable
svalue(obj, index = NULL, ..., value)
# S3 method for GTable
[(x, i, j, ..., drop = TRUE)
# S3 method for GTable
addHandlerChanged(obj, handler, action = NULL, ...)
# S3 method for GTable
addHandlerDoubleclick(obj, handler, action = NULL, ...)
# S3 method for GTable
visible(obj, ...)
# S3 method for GTable
size (obj) <- value
Returns an object of class GTable
data.frame specifies items for selection. May be a vector, matrix or data frame
logical allow multiple selection
which value from the row is returned by selection
NULL or integer. If latter, specifies column containing stock icon
NULL or integer. If latter, specifies column containing tooltip
A handler assigned to the default change
signal. Handlers are called when some event triggers a widget to
emit a signal. For each widget some default signal is assumed, and
handlers may be assigned to that through addHandlerChanged
or at construction time. Handlers are functions whose first
argument, h
in the documentation, is a list with atleast
two components obj
, referring to the object emitting the
signal and action
, which passes in user-specified data to
parameterize the function call.
Handlers may also be added via addHandlerXXX
methods for
the widgets, where XXX
indicates the signal, with a default
signal mapped to addHandlerChanged
(cf. addHandler
for a listing). These methods pass
back a handler ID that can be used with blockHandler
and
unblockHandler
to suppress temporarily the calling of the
handler.
User supplied data passed to the handler when it is called
A parent container. When a widget is created it can be incorporated into the widget heirarchy by passing in a parent container at construction time. (For some toolkits this is not optional, e.g. gWidgets2tcltk or gWidgets2WWW2.)
These values are passed to the add
method of the
parent container. Examples of values are expand
,
fill
, and anchor
, although they're not always
supported by a given widget. For more details see add.
Occasionally the variable arguments feature has been used to sneak
in hidden arguments to toolkit implementations. For example, when
using a widget as a menubar object one can specify a parent
argument to pass in parent information, similar to how the
argument is used with gaction and the dialogs.
Each widget constructor is passed in the toolkit it
will use. This is typically done using the default, which will
lookup the toolkit through guiToolkit
.
object of method call
NULL or logical. If TRUE
and widget supports it an index, instead of a value will be returned.
value to assign for selection or property
GTable
object
row index
column index
do we drop when subsetting
Many generic methods for data frames are implemented for
gtable
. These include [
, [<-
, length
,
names
, and names<-
if (FALSE) {
w <- gwindow("gtable example", visible=FALSE)
g <- gvbox(cont=w)
tbl <- gtable(mtcars, cont=g, expand=TRUE, fill=TRUE)
addHandlerClicked(tbl, handler=function(h,...) sprintf("You selected %s", svalue(h$obj)))
visible(w) <- TRUE
}
Run the code above in your browser using DataLab