R блестящий: как связать слайдер и радио кнопки на ggplot - PullRequest
0 голосов
/ 27 мая 2018

Я очень плохо знаком с бриллиантом и безуспешно читал другие подобные посты, в том числе: R бриллиантовых графиков, основанных на переключателях и вводе слайдера

Я хочу построить график здоровья (выбрано из переключателей) v Расходы из собственного кармана (ООП) с указанием года на основе ползунка

Это мой код, пока на графиках не отображается

пользовательский интерфейс:

 library(shiny)
 library(ggplot2)

 data <- read.csv("data.csv", header=TRUE)
 data

 data$OOP <- as.numeric(data$OOP)
 data$OOP

  shinyUI(fluidPage(
    titlePanel(title=h3("Out of pocket expenditure on health")),

    mainPanel(
      h5(textOutput("subheading")),
      plotOutput("view")),

    fluidRow(
        column(5,
           radioButtons("outcome", label=h4("Select Health Outcomes"),
                    choices=list("Mortality rate (per 100,000)", "Premature death risk (age 30-70)"), selected="Mortality rate (per 100,000)"),

           checkboxInput("smooth", "Add trend line")
),
        column(5,
            sliderInput("years", label=h4("Year"),
                   min=min(data$Year), max=max(data$Year), value=(min(data$Year)), step=5, sep="", animate=TRUE)
)
 )
   ))

сервер:

library(dplyr)
library(ggplot2)

shinyServer(
    function(input, output){
    formulaText <- reactive({
        paste("Health outcome:",input$outcome)
            })
        output$subheading <- renderText({formulaText()})

     datareact <- reactive({
        data %>%
        filter(Year == input$years) %>%
        select(Country, OOP, Mortality, Probability)
            })

     output$view <- renderPlot({
        p <- ggplot(datareact(), aes(x=OOP, y=input$outcome))+
           geom_point(aes(fill=Country))

        if(input$smooth)
           p <- p + geom_smooth()  
           })
         })

Возможно, что-то не так с линиями «реактивный» и «рендер».Спасибо за любую помощь, спасибо

* Редактировать: Вот как выглядят мои данные (фрагмент):

      Country Year     OOP Mortality Probability
1 Afghanistan 2000 No data     934.3        34.2
2 Afghanistan 2005      79     947.7        33.6
3 Afghanistan 2010      79     919.6        32.2
4 Afghanistan 2015    78.4     898.0        31.0
5     Albania 2000    64.6     710.3        20.0
6     Albania 2005    52.5     688.9        19.7

1 Ответ

0 голосов
/ 27 мая 2018

Как всегда, постпроизводимые данные с dput и ожидаемый результат полезны.Тем не менее, вот мое решение, дайте мне знать, если требуется обновление.

library(shiny)
library(ggplot2)
library(dplyr)

#No data changed to NA
Input = ("Country Year     OOP Mortality Probability
   1 Afghanistan 2000 NA     934.3        34.2
   2 Afghanistan 2005      79     947.7        33.6
   3 Afghanistan 2010      79     919.6        32.2
   4 Afghanistan 2015    78.4     898.0        31.0
   5     Albania 2000    64.6     710.3        20.0
   6     Albania 2005    52.5     688.9        19.7")

data = read.table(textConnection(Input),header=TRUE)


ui <- shinyUI(fluidPage(
          titlePanel(title=h3("Out of pocket expenditure on health")),

      mainPanel(
        h5(textOutput("subheading")),
        plotOutput("view")),

     fluidRow(
        column(5,
               radioButtons("outcome", label=h4("Select Health Outcomes"),
                    choices=c("Mortality rate", "Premature death risk (age 30-70)"), selected="Mortality rate"),

             checkboxInput("smooth", "Add trend line")
       ),
         column(5,
               sliderInput("years", label=h4("Year"),
                   min=min(data$Year), max=max(data$Year), value=(min(data$Year)), step=1, sep="", animate=TRUE)
       )
     )
 ))


server <- shinyServer(function(input, output, session){
formulaText <- reactive({
  paste("Health outcome:",input$outcome)
})
output$subheading <- renderText({formulaText()})

datareact <- reactive({
  print(input$years)      #to check variable before passing 
  print(input$outcome)
  data <- data %>%
  #change input$outcome from renderPlot to reactive
  filter(Year >= input$years)

if (input$outcome == "Mortality rate") {data$outcome <- data$Mortality} else {
  data$outcome <- data$Probability    #Please note this is not the best solution for large data set 
  }
data
})

observe(print(datareact()))   #to check which data you get

output$view <- renderPlot({

  p <- ggplot(datareact(), aes(x=OOP, y=outcome, color=Country))+
    geom_point()

  if(input$smooth)
    p <- p + geom_smooth()

       p   #Enforce renderPlot to return p 
     })
  })

 shinyApp(ui,server)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...