2017-09-11 13 views
2

반짝이는 앱을 사용하여 확대 된 영역의 좌표를 하이 커터에 저장할 수 있습니까?R Highcharter 선택한 영역 확대/축소

나는이 example's 비슷한 싶습니다

function getSelection(event) { 
    alert(event.xAxis[0].min); 
    alert(event.xAxis[0].max); 
} 

를 대신 경고로, 단지 그들을 저장하고 사용할 수 있습니다.

샘플 반짝 응용 프로그램 :

library(shiny) 
library(dplyr) 
library(highcharter) 
library(tidyr) 

df_plot <- cbind(
    seq(0, 1, by = 0.1), 
    sample(seq(from = 100, to = 300, by = 10), size = 11, replace = TRUE), 
    sample(seq(from = 1, to = 100, by = 9), size = 11, replace = TRUE), 
    sample(seq(from = 50, to = 60, by = 2), size = 11, replace = TRUE), 
    sample(seq(from = 100, to = 130, by = 1), size = 1, replace = TRUE) 
) %>% as.data.frame() 

names(df_plot) <- c("x", "a", "b", "c", "d") 


ui <- fluidPage(
    column(
    width = 3, 
    selectInput("select", "Select var:", choices = c("a", "b", "x", "y"), selected = c("a", "b", "x"), multiple = TRUE) 
), 
    column(
    width = 9 
), 
    column(
    width = 12, 
    highchartOutput("plot") 
) 
) 

server <- function(input, output){ 

    output$plot <- renderHighchart({ 
    highchart() %>% 
     hc_xAxis(categories = df_plot$x) %>% 
     hc_add_series(data = df_plot$a) %>% 
     hc_add_series(data = df_plot$b, yAxis = 1) %>% 
     hc_yAxis_multiples(
     list(lineWidth = 3, lineColor='#7cb5ec', title=list(text="First y-axis")), 
     list(lineWidth = 3, lineColor="#434348", title=list(text="Second y-axis"))) %>% 
     hc_chart(
     zoomType = "x" 
    ) 
    }) 
} 

shinyApp(ui, server) 

답변

1

당신은 다음과 같은 somethig에 작업을 수행 할 수 있습니다

library(shiny) 
library(highcharter) 


ui <- fluidPage(
    column(8,highchartOutput("hcout")), 
    column(4,textOutput("eventout")) 
) 

server <- function(input, output) { 

    output$hcout <- renderHighchart({ 

    highcharts_demo() %>% 
     hc_chart(
     zoomType = "xy", 
     events = list(
      selection = JS("function(event) { 
         Shiny.onInputChange('event', [event.xAxis[0].min,  event.xAxis[0].max]); 
          return true; 
          } ") 
     ) 
     ) 

    }) 

    output$eventout <- renderText({ 

    input$event 
    }) 

} 

그러나 reset zoom 버튼이 작동하지 않는 이유를 모르겠어요 (동일 jsfiddle 예를 들어 resetZoomButton을 사용할 때