Мой пакет в настоящее время разрабатывается с использованием gWidgets2RGtk2. Я пытаюсь сделать его совместимым с gWidgets2tcltk. Однако я получаю эту ошибку, которую не могу понять:
Error in connect_to_toolkit_signal(signal, decorator = decorator, emitter = emitter, :
object 'event_decorator' not found
Небольшой пример, который работает с использованием gWidgets2RGtk2, но выдает ошибку с использованием gWidgets2tcltk:
require(gWidgets2)
gui_example <- function(){
# Main window.
w <- gwindow(title=paste("GUI test"), visible = FALSE, name=title)
# Main group.
gv <- ggroup(horizontal=FALSE, use.scrollwindow=FALSE, container = w, expand=TRUE)
# Notebook.
nb <- gnotebook(closebuttons = FALSE, dontCloseThese = NULL, container = gv)
# Define groups.
tab_1 <- ggroup(container = nb, label="Tab1")
tab_2 <- ggroup(container = nb, label="Tab2")
tab_3 <- ggroup(container = nb, label="Tab3")
gtext(text="Tab1", expand=TRUE, container = tab_1)
gtext(text="Tab2", expand=TRUE, container = tab_2)
gtext(text="Tab3", expand=TRUE, container = tab_3)
addHandlerChanged(nb, handler = function (h, ...) {
print("CHANGED...")
print(if(is.null(h$page.no)) svalue(h$obj) else h$page.no)
# Get active tab.
tab <- if(is.null(h$page.no)) svalue(h$obj) else h$page.no
tabName <- names(nb)[tab]
print(paste("Active tab:", tab))
print(paste("Active tab name:", tabName))
})
addHandlerFocus(w, handler = function (h, ...) {
print("FOCUS...")
# Get active tab.
tab <- svalue(nb)
tabName <- names(nb)[tab]
print(paste("Active tab:", tab))
print(paste("Active tab name:", tabName))
})
# Show GUI and first tab.
svalue(nb) <- 1
visible(w) <- TRUE
focus(w)
message("Example loaded!")
}
Как избежать этой ошибки при использовании пакета gWidgets2tcltk и поддерживать совместимость с gWidgets2RGtk2?
Вот моя системная информация:
R version 3.5.1 (2018-07-02)
Platform: x86_64-w64-mingw32/x64 (64-bit)
Running under: Windows >= 8 x64 (build 9200)
gWidgets2_1.0-7
gWidgets2RGtk2_1.0-7
RGtk2_2.20.35
gWidgets2tcltk_1.0-5