我有一个使用R-Shiny实现交互操作的绘图应用程序:单击、悬停(将鼠标移动到绘图上,这可以被shiny检测到)。为了给您一个想法,我在下面发布了一个简化的闪亮应用程序,其中包含对我来说存在问题的交互式绘图绘图功能。 (它来自我的旧答案here)
实际上它工作得很好,但是我需要人们从他们的智能手机上使用它。 问题是:我们在智能手机上进行的手指移动被手机解释为缩放页面或滚动页面,而不是鼠标选择或鼠标移动在绘图上(悬停)。
是否有代码修改(java?CSS?)可以在应用程序中实现将触摸事件转换为鼠标事件,或者智能手机上的选项/手势可以启用类似鼠标的移动?
非常感谢; 代码:
library(shiny)
ui <- fluidPage(
h4("Click on plot to start drawing, click again to pause"),
sliderInput("mywidth", "width of the pencil", min=1, max=30, step=1, value=10),
actionButton("reset", "reset"),
plotOutput("plot", width = "500px", height = "500px",
hover=hoverOpts(id = "hover", delay = 100, delayType = "throttle", clip = TRUE, nullOutside = TRUE),
click="click"))
server <- function(input, output, session) {
vals = reactiveValues(x=NULL, y=NULL)
draw = reactiveVal(FALSE)
observeEvent(input$click, handlerExpr = {
temp <- draw(); draw(!temp)
if(!draw()) {
vals$x <- c(vals$x, NA)
vals$y <- c(vals$y, NA)
}})
observeEvent(input$reset, handlerExpr = {
vals$x <- NULL; vals$y <- NULL
})
observeEvent(input$hover, {
if (draw()) {
vals$x <- c(vals$x, input$hover$x)
vals$y <- c(vals$y, input$hover$y)
}})
output$plot= renderPlot({
plot(x=vals$x, y=vals$y, xlim=c(0, 28), ylim=c(0, 28), ylab="y", xlab="x", type="l", lwd=input$mywidth)
})}
shinyApp(ui, server)