Nothing
setClass("gLabeltcltk",
contains="gComponenttcltk",
representation = representation("gComponenttcltk",
markup="logical"),
prototype=prototype(new("gComponenttcltk"))
)
## constructor
setMethod(".glabel",
signature(toolkit="guiWidgetsToolkittcltk"),
function(toolkit,
text= "", markup = FALSE, editable = FALSE, handler = NULL,
action = NULL, container = NULL,
...
) {
force(toolkit)
if(markup) {
gwCat(gettext("In gWidgetstcltk there is no markup language. Use font()<- instead.\n"))
}
if(is(container,"logical") && container)
container = gwindow()
if(!(is(container,"guiWidget") || is(container,"gWidgettcltk"))) {
warning("Container is not correct. No NULL containers possible\n" )
return()
}
tt <- getWidget(container)
label <- ttklabel(tt, text="")
obj <- new("gLabeltcltk",
block=label, widget=label, markup=markup,
toolkit=toolkit,ID=getNewID(), e = new.env())
## add text
svalue(obj) <- text
## add to container
add(container, obj, ...)
if(editable) {
handler <- function(h,...) {
val = ginput(message="Change label value:",text=svalue(h$obj),
title="Change text for label", icon="question")
if(!is.na(val))
svalue(obj) <- val
}
}
if(!is.null(handler)) {
id <- addhandlerclicked(obj, handler=handler,action=action)
}
invisible(obj)
})
### methods
setMethod(".svalue",
signature(toolkit="guiWidgetsToolkittcltk",obj="gLabeltcltk"),
function(obj, toolkit, index=NULL, drop=NULL, ...) {
val = tclvalue(tkcget(getWidget(obj),"-text")) # respects "\n"
if(length(val) == 0)
val=""
return(val)
})
setReplaceMethod(".svalue",
signature(toolkit="guiWidgetsToolkittcltk",obj="gLabeltcltk"),
function(obj, toolkit, index=NULL, ..., value) {
txt <- paste(as.character(value), collapse="\n")
tkconfigure(obj@widget, text=txt)
return(obj)
})
setMethod(".addhandlerchanged",
signature(toolkit="guiWidgetsToolkittcltk",obj="gLabeltcltk"),
function(obj, toolkit, handler, action=NULL, ...) {
.addhandlerclicked(obj, toolkit, handler, action, ...)
})
##################################################
## internal function -- used by gvariables in gcommandline
setGeneric("gaddlabel", function(obj, text="", markup=FALSE, pos=1, container=NULL, ...) standardGeneric("gaddlabel"))
setMethod("gaddlabel",
signature("guiWidget"),
function(obj, text="", markup=FALSE, pos=1, container=NULL, ...)
gaddlabel(obj@widget, text, markup, pos, container, ...)
)
setMethod("gaddlabel",
signature("gWidgettcltk"),
function(obj, text="", markup=FALSE, pos=1, container=NULL, ...) {
## wrap widget into a new package with label
if(pos %in% c(2,4)) {
group = ggroup(horizontal=TRUE,container=container,
toolkit=obj@toolkit)
} else {
group = ggroup(horizontal=FALSE,container=container,
toolkit=obj@toolkit)
}
if(pos %in% 2:3) {
glabel(text, markup=markup, container=group, toolkit=obj@toolkit)
add(group, obj,expand=TRUE)
} else {
add(group, obj,expand=TRUE)
glabel(text, markup=markup, container=group, toolkit=obj@toolkit)
}
## group is returned. No methods added here, just a new package
return(group)
})
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.