堆叠的ggplot百分比条形图在闪亮

AK 47

我的目标是在ggplot中创建带有百分比标签的堆叠条形图。经过研究并阅读了一些材料后,我设法管理了所需的图表。有很多材料。

如何在ggplot2中标记堆叠的条形图而不创建摘要数据框?

创建堆叠的条形图,其中每个堆叠的缩放比例总计为100%

R堆叠百分比条形图,带有二进制因子和标签的百分比(带ggplot)

但是,我有两个问题:

1)我找不到合适的放置标签的地方。您会看到标签未居中且位于错误的部分。(图生成时未使用闪亮) 在此处输入图片说明如何解决此问题?

第二个问题是当我尝试在中使用绘图代码时shiny我使用以下功能创建标签:df$label = paste0(sprintf("%.0f", df$percent), "%"),但是插入标签reactive出现错误。在实际情况下,我有更困难的数据生成和子集示例,因此我的数据必须为reactive

我设法获得了最好的结果shiny在此处输入图片说明

另外,我附上了该应用程序的可重现esample。

我的目标是绘制漂亮labelsstacked percent bar chartggplot

library(shiny)
library(shinydashboard)
library(plyr)
library(ggplot2)



# Header -----------------------------------------------------------

header <- dashboardHeader(title= "DashBoard")


# Sidebar --------------------------------------------------------------

sm <- sidebarMenu(

  menuItem(
    text="stacked bar chart",
    tabName="chart",
    icon=icon("eye")
  )  

)

sidebar <- dashboardSidebar(sm)

# Body --------------------------------------------------

body <- dashboardBody(

  # Layout  --------------------------------------------  

  tabItems(


    tabItem(
      tabName="chart",
      fluidPage(

        fluidRow(

          title = "Inputs", status = "warning", width = 2, solidHeader = TRUE, collapsible = TRUE,


          plotOutput("M1"),
          dataTableOutput(outputId="M3")


        )
      )
    )
  )
)

# Setup Shiny app UI components -------------------------------------------

ui <- dashboardPage(header, sidebar, body)

# Setup Shiny app back-end components -------------------------------------

server <- function(input, output) {






  # ----------------------------------------------------------------------------- 
  #reproducable data generation
  Mdata <- reactive({

    set.seed(1992)
    n=8

    Category <- sample(c("Car", "Bus", "Bike"), n, replace = TRUE, prob = NULL)
    Brand <- sample("Brand", n, replace = TRUE, prob = NULL)
    Brand <- paste0(Brand, sample(1:14, n, replace = TRUE, prob = NULL))
    USD <- abs(rnorm(n))*100

    df <- data.frame(Category, Brand, USD)

    # Calculate the percentages
    df = ddply(df, .(Brand), transform, percent = USD/sum(USD) * 100)


    # Format the labels and calculate their positions
    df = ddply(df, .(Brand), transform, pos = (cumsum(USD) - 0.5 * USD))

    #create nice labes
    #df$label = paste0(sprintf("%.0f", df$percent), "%")  

})



output$M1 <- renderPlot({ 

  ggplot(Mdata(), aes(x=reorder(Brand,USD,
                           function(x)+sum(x)),  y=percent, fill=Category))+
    geom_bar(position = "fill", stat='identity',  width = .7)+
    geom_text(aes(label=percent, ymax=100, ymin=0), vjust=0, hjust=2, color = "white",  position=position_fill())+
    coord_flip()+
    scale_y_continuous(labels = percent_format())+
    ylab("")+
    xlab("")

})  



output$M3 <- renderDataTable({
  Mdata()
})  


  # -----------------------------------------------------------------------------


}

# Render Shiny app --------------------------------------------------------

shinyApp(ui, server)
迈克·怀斯

来自paste0命令的错误是因为它是中的最后一行reactive,因此成为返回值。只需添加一条语句return(df)或等效的内容即可解决该问题。

至于标签的位置,代码按设计工作,您必须计算所需的位置geom_text并明确使用这些坐标,这需要您汇总每个品牌段的坐标,以便知道其左右位置并可以计算中心

其他答案可以在这里找到:

如何居中堆叠百分比条形图标签居中

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

将百分比标签添加到堆叠的条形图ggplot2

条形图 - 堆叠的 ggplot 百分比条形图起始值不是 0%

ggplot条形图百分比组

用 R ggplot2 中的百分比从头开始分类变量的堆叠条形图

按y连续值订购堆叠的ggplot2百分比条形图-重新过帐

R:ggplot堆叠的条形图,y轴上有计数,但百分比为标签

如何计算和绘制堆叠条形图的百分比标签以及条形图的总数?

向堆叠条形图添加百分比标签

如何创建以百分比计算的数字的堆叠条形图?

具有 50 多个创建的虚拟变量的堆叠条形图(百分比)?

百分比堆积条形图熊猫

带百分比的堆积条形图

试图从百分比绘制堆积条形图

堆积条形图百分比

如何显示百分比和条形图

叠加的堆积百分比条形图

总与部分的条形图,百分比 (R)

ggplot2:如何绘制条形图,条形图表示百分比,并根据百分比值进行着色?

如何在堆积的条形图ggplot2上组织百分比值

ggplot2中条形图的计数和百分比如何?[R

在每个类的中间注释百分比堆积条形图,ggplot

使用ggplot在R中创建堆积百分比条形图

在R中计算百分比并制作ggplot条形图

ggplot2 中按组显示的百分比条形图

如何使用ggplot输入2位数的条形图百分比(%)?

R ggplot Sort 百分比堆积条形图

ggplot2 R:具有多个变量的百分比堆积条形图

堆叠条形图将变量转换为ggplot2 R中不相关变量的基于不存在的百分比

R堆叠百分比条形图,带有二元因子和标签的百分比