2016-05-17 11 views
0

現在、私のプロットを光沢のあるものにする問題があります。レイアウトはすべて問題ありませんが、実行するとプロットは表示されません。 csvファイル内のデータへ光沢のあるggplotのレンダリングに関する問題

リンク: https://www.dropbox.com/s/hv3k12ja9r10tzz/pointvaluedfmelt.csv?dl=0

UIコード:

library(shiny) 
library(ggplot2) 
library(RColorBrewer) 

pointvaluedf.melt<- read.csv("pointvaluedfmelt.csv", stringsAsFactors = F) 
pointvaluedf.melt$X<- NULL 
pointvaluedf.melt$PLAYER_NAME<- as.factor(pointvaluedf.melt$PLAYER_NAME) 
pointvaluedf.melt$TEAM_ABBREVIATION<- as.factor(pointvaluedf.melt$TEAM_ABBREVIATION) 
pointvaluedf.melt$name.zone<- as.factor(pointvaluedf.melt$name.zone) 

ui <- fluidPage(

    titlePanel("Top 5 Most Valuable Shots by Player"), 
    sidebarLayout(
    sidebarPanel(selectInput("team", 
         label = "Choose a Team", 
         choices = c("Celtics", "Nets","Knicks", "76ers", "Raptors", 
            "Mavericks","Rockets","Grizzlies","Pelicans", 
            "Spurs","Bulls","Cavs","Pistons","Pacers","Bucks", 
            "Nuggets","Timberwolves","Thunder","Blazers", 
            "Jazz","Hawks","Hornets","Heat","Magic","Wiz", 
            "Warriors","Clippers","Lakers","Suns","Kings"), 
         selected = "Celtics"), width = 2 
    ), 
    mainPanel(plotOutput("myplot")) 

)) 

サーバコード:

library(shiny) 
library(ggplot2) 
library(RColorBrewer) 

pointvaluedf.melt<- read.csv("pointvaluedfmelt.csv", stringsAsFactors = F) 
pointvaluedf.melt$X<- NULL 
pointvaluedf.melt$PLAYER_NAME<- as.factor(pointvaluedf.melt$PLAYER_NAME) 
pointvaluedf.melt$TEAM_ABBREVIATION<- as.factor(pointvaluedf.melt$TEAM_ABBREVIATION) 
pointvaluedf.melt$name.zone<- as.factor(pointvaluedf.melt$name.zone) 

server <- function(input, output) { 

    df<- reactive({pointvaluedf.melt[pointvaluedf.melt$TEAM_ABBREVIATION==input$team,]}) 

    output$myplot <- renderPlot(function(){ 

    dd<- df() 

    tea <- switch(input$team, 
       "Celtics" = "BOS", 
       "Nets" = "BKN", 
       "Knicks" = "NYK", 
       "76ers" = "PHI", 
       "Raptors" = "TOR", 
       "Mavericks" = "DAL", 
       "Rockets" = "HOU", 
       "Grizzlies" = "MEM", 
       "Pelicans" = "NOP", 
       "Spurs" = "SAS", 
       "Bulls" = "CHI", 
       "Cavs" = "CLE", 
       "Pistons" = "DET", 
       "Pacers" = "IND", 
       "Bucks" = "MIL", 
       "Nuggets" = "DEN", 
       "Timberwolves" = "MIN", 
       "Thunder" = "OKC", 
       "Blazers" = "POR", 
       "Jazz" = "UTA", 
       "Hawks" = "ATL", 
       "Hornets" = "CHA", 
       "Heat" = "MIA", 
       "Magic" = "ORL", 
       "Wiz" = "WAS", 
       "Warriors" = "GSW", 
       "Lakers" = "LAL", 
       "Clippers" = "LAC", 
       "Suns" = "PHX", 
       "Kings" = "SAC") 

    p<- ggplot(data=head(subset(dd, TEAM_ABBREVIATION %in% tea) 
         [order(-subset(dd, TEAM_ABBREVIATION %in% tea)[,4]),],5), 
      aes(x=reorder(name.zone,-value), y=value))+ 
    geom_bar(stat="identity", fill="#4292C6", col="black", size=1.2)+ 
    theme(axis.text.x=element_text(angle=35, hjust=1))+ 
    labs(x="Player and Shot Type", y="Point Value", title="Top 5 Value Shots") 
    print(p) 
}) 
    } 

答えて

1

そこにはエラーがあります:

1-レンダープロットでは、 "function()"キーワードは必要ありません。 renderPlot({})
2-適切な反応をしていません。 2つの反応性のあるオブジェクトを使用することで、シンプルで優れたものにすることができます。また、renderPlotは、すべてをrenderPlotロジックの中に入れるだけでなく消費します。この方法で、オブジェクトを再利用してコードをきれいにすることができます。
3反応が間違っているため、値を変更するとdata.frameが空になりました。

library(shiny) 
library(ggplot2) 
library(RColorBrewer) 

pointvaluedf.melt<- read.csv("pointvaluedfmelt.csv", stringsAsFactors = F) 
pointvaluedf.melt$X<- NULL 
pointvaluedf.melt$PLAYER_NAME<- as.factor(pointvaluedf.melt$PLAYER_NAME) 
pointvaluedf.melt$TEAM_ABBREVIATION<- pointvaluedf.melt$TEAM_ABBREVIATION 
pointvaluedf.melt$name.zone<- as.factor(pointvaluedf.melt$name.zone) 

ui <- fluidPage(

    titlePanel("Top 5 Most Valuable Shots by Player"), 
    sidebarLayout(
    sidebarPanel(selectInput("team", 
          label = "Choose a Team", 
          choices = c("Celtics", "Nets","Knicks", "76ers", "Raptors", 
             "Mavericks","Rockets","Grizzlies","Pelicans", 
             "Spurs","Bulls","Cavs","Pistons","Pacers","Bucks", 
             "Nuggets","Timberwolves","Thunder","Blazers", 
             "Jazz","Hawks","Hornets","Heat","Magic","Wiz", 
             "Warriors","Clippers","Lakers","Suns","Kings"), 
          selected = "Celtics"), width = 2 
    ), 
    mainPanel(plotOutput("myplot")) 

)) 

server <- function(input, output, session) { 

    df <- reactive({ 
    pointvaluedf.melt[pointvaluedf.melt$TEAM_ABBREVIATION==tea(),] 
    }) 

    tea <- reactive({ 
    switch(input$team, 
      "Celtics" = "BOS", 
      "Nets" = "BKN", 
      "Knicks" = "NYK", 
      "76ers" = "PHI", 
      "Raptors" = "TOR", 
      "Mavericks" = "DAL", 
      "Rockets" = "HOU", 
      "Grizzlies" = "MEM", 
      "Pelicans" = "NOP", 
      "Spurs" = "SAS", 
      "Bulls" = "CHI", 
      "Cavs" = "CLE", 
      "Pistons" = "DET", 
      "Pacers" = "IND", 
      "Bucks" = "MIL", 
      "Nuggets" = "DEN", 
      "Timberwolves" = "MIN", 
      "Thunder" = "OKC", 
      "Blazers" = "POR", 
      "Jazz" = "UTA", 
      "Hawks" = "ATL", 
      "Hornets" = "CHA", 
      "Heat" = "MIA", 
      "Magic" = "ORL", 
      "Wiz" = "WAS", 
      "Warriors" = "GSW", 
      "Lakers" = "LAL", 
      "Clippers" = "LAC", 
      "Suns" = "PHX", 
      "Kings" = "SAC") 
    }) 


    output$myplot <- renderPlot({ 
    p <- ggplot(data=head(subset(df(), TEAM_ABBREVIATION %in% tea()) 
          [order(-subset(df(), TEAM_ABBREVIATION %in% tea())[,4]),],5), 
       aes(x=reorder(name.zone,-value), y=value))+ 
     geom_bar(stat="identity", fill="#4292C6", col="black", size=1.2)+ 
     theme(axis.text.x=element_text(angle=35, hjust=1))+ 
     labs(x="Player and Shot Type", y="Point Value", title="Top 5 Value Shots") 
    p 
    }) 
} 

shinyApp(ui, server) 
関連する問題