AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / coding / 问题 / 79174512
Accepted
TarJae
TarJae
Asked: 2024-11-10 17:08:58 +0800 CST2024-11-10 17:08:58 +0800 CST 2024-11-10 17:08:58 +0800 CST

如何在 shinyscreenshot 中排除 radioGroupButtons

  • 772

我正在使用 构建一个 Shiny 应用shinyscreenshot。我的应用包含一个“分数”卡,其中有一个 radioGroupButtons 列表,用户可以从中进行选择。radioGroupButtons 在应用中不可见,但是,当我使用 截取屏幕截图时shinyscreenshot,radioGroupButtons 会出现并与数值重叠,导致屏幕截图混乱。

我想在截屏时隐藏 radioGroupButtons。我尝试使用 shinyjs 来切换按钮的可见性,但没有按预期工作。

这是一个最小的可重现示例,演示了我的设置和方法:

library(shiny)
library(bs4Dash)
library(shinyWidgets)
library(shinyjs)
library(shinyscreenshot)

my_ids <- c("region_1", "region_2") 
my_labels <- c("A", "B") 

ui <- bs4DashPage(
  title = "My Example",
  header = bs4DashNavbar(),
  sidebar = bs4DashSidebar(disable = TRUE),  
  body = bs4DashBody(
    useShinyjs(),
    
    # CSS for radio button styles and hiding elements
    tags$style(HTML("
      .btn-zero {background-color: white; color: black;}
      .btn-zero.active {background-color: #a2ff45; color: black;}
      .btn-one {background-color: white; color: black;}
      .btn-one.active {background-color: #a2ff45; color: black;}
      .btn-two {background-color: white; color: black;}
      .btn-two.active {background-color: #a2ff45; color: black;}
      .btn-three {background-color: white; color: black;}
      .btn-three.active {background-color: #a2ff45; color: black;}
      .region-label { line-height: 2.5; }

      /* Hide elements during screenshot */
      .hide-for-screenshot { display: none !important; }
    ")),
    
    bs4Card(
      title = "My Score",
      width = 6,
      style = "height: 200px; overflow: auto;",  
      tags$style(HTML("
        .region-label { margin-top: -10px; }
      ")),
      # Render radio buttons for each region
      lapply(seq_along(my_ids), function(i) {
        fluidRow(
          column(6, h4(class = "region-label", paste(i-1, my_labels[i]))),
          column(6, div(
            style = "display: inline-block;",
            shinyWidgets::radioGroupButtons(
              inputId = my_ids[i],
              label = NULL,
              choices = 0:3,
              selected = 0,
              checkIcon = list(yes = icon("check")),
              status = c("zero", "one", "two", "three"),
              size = 'xs'
            )
          ))
        )
      })
    ),
    
    # Screenshot Button
    actionButton("take_screenshot", "Take Screenshot", style = "margin-top: 10px;")
  )
)

server <- function(input, output, session) {
  observeEvent(input$take_screenshot, {
    # Temporarily hide radio buttons
    shinyjs::addClass(selector = ".radioGroupButtons", class = "hide-for-screenshot")
    
    # Take screenshot and remove the hide class afterward
    shinyscreenshot::screenshot()
    
    # Show radio buttons again
    shinyjs::removeClass(selector = ".radioGroupButtons", class = "hide-for-screenshot")
  })
}

shinyApp(ui, server)

我尝试过的方法 自定义 CSS:我添加了一个.hide-for-screenshotCSS 类 display: none !important; 来隐藏元素。该类在截屏前应用,截屏后删除。

使用shinyjs:我正在使用shinyjs::addClass和shinyjs::removeClass来切换.hide-for-screenshot类radioGroupButtons。

问题 尽管在截屏之前添加了hide-for-screenshot类并隐藏了,但它们仍然出现在屏幕截图中。我怀疑这可能是因为没有遵守临时的 CSS 更改,或者延迟时间不足以应用样式。radioGroupButtonsshinyscreenshot

问题 如何确保截取屏幕截图radioGroupButtons时完全隐藏?shinyscreenshot

任何建议或其他方法都将不胜感激!谢谢。

截图如下: 在此处输入图片描述

它看起来应该是这样的: 在此处输入图片描述

  • 1 1 个回答
  • 23 Views

1 个回答

  • Voted
  1. Best Answer
    smartse
    2024-11-11T00:01:44+08:002024-11-11T00:01:44+08:00

    关于您的示例,有几点需要说明 - 首先,您试图隐藏整个radioGroupButton对象,而不仅仅是<input>导致问题的元素,并且您还使用了无效的类 - 它们不在 中radio-group-buttons。radioGroupButtons此外, 中的事件observeEvent只会在最后触发,因此您的addClass和removeClass相互抵消。因此,您需要三个observeEvents,一个用于隐藏它们,一个用于截取屏幕截图,然后另一个用于取消隐藏它们。请注意,这当前隐藏了所有元素<input>,这不太可能是您在实际用例中想要的,但我一直无法弄清楚要使用哪个选择器。

    server <- function(input, output, session) {
      observeEvent(input$take_screenshot, {
        shinyjs::addClass(selector = "input", class = "hide-for-screenshot")
        if (is.null(input$take_screenshot2)){
          new_value <- 1
        } else {
          new_value <- input$take_screenshot2 + 1
        }
        shinyjs::runjs(paste0("Shiny.setInputValue('take_screenshot2',", new_value, ");"))
      })
    
      observeEvent(input$take_screenshot2, {
        shinyscreenshot::screenshot()
        if (is.null(input$take_screenshot3)){
          new_value <- 1
        } else {
          new_value <- input$take_screenshot3 + 1
        }
        shinyjs::runjs(paste0("Shiny.setInputValue('take_screenshot3',", new_value, ");"))
      })
    
      observeEvent(input$take_screenshot3, {
        shinyjs::removeClass(selector = "input", class = "hide-for-screenshot")
      })
    }
    

    在此处输入图片描述

    • 1

相关问题

  • 将复制活动的序列号添加到 Blob

  • Packer 动态源重复工件

  • 选择每组连续 1 的行

  • 图形 API 调用列表 subscribedSkus 状态权限不足,但已授予权限

  • 根据列值创建单独的 DF 的函数

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    Vue 3:创建时出错“预期标识符但发现‘导入’”[重复]

    • 1 个回答
  • Marko Smith

    为什么这个简单而小的 Java 代码在所有 Graal JVM 上的运行速度都快 30 倍,但在任何 Oracle JVM 上却不行?

    • 1 个回答
  • Marko Smith

    具有指定基础类型但没有枚举器的“枚举类”的用途是什么?

    • 1 个回答
  • Marko Smith

    如何修复未手动导入的模块的 MODULE_NOT_FOUND 错误?

    • 6 个回答
  • Marko Smith

    `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它?

    • 3 个回答
  • Marko Smith

    何时应使用 std::inplace_vector 而不是 std::vector?

    • 3 个回答
  • Marko Smith

    在 C++ 中,一个不执行任何操作的空程序需要 204KB 的堆,但在 C 中则不需要

    • 1 个回答
  • Marko Smith

    PowerBI 目前与 BigQuery 不兼容:Simba 驱动程序与 Windows 更新有关

    • 2 个回答
  • Marko Smith

    AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String”

    • 1 个回答
  • Marko Smith

    我正在尝试仅使用海龟随机和数学模块来制作吃豆人游戏

    • 1 个回答
  • Martin Hope
    Aleksandr Dubinsky 为什么 InetAddress 上的 switch 模式匹配会失败,并出现“未涵盖所有可能的输入值”? 2024-12-23 06:56:21 +0800 CST
  • Martin Hope
    Phillip Borge 为什么这个简单而小的 Java 代码在所有 Graal JVM 上的运行速度都快 30 倍,但在任何 Oracle JVM 上却不行? 2024-12-12 20:46:46 +0800 CST
  • Martin Hope
    Oodini 具有指定基础类型但没有枚举器的“枚举类”的用途是什么? 2024-12-12 06:27:11 +0800 CST
  • Martin Hope
    sleeptightAnsiC `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它? 2024-11-09 07:18:53 +0800 CST
  • Martin Hope
    The Mad Gamer 何时应使用 std::inplace_vector 而不是 std::vector? 2024-10-29 23:01:00 +0800 CST
  • Martin Hope
    Chad Feller 在 5.2 版中,bash 条件语句中的 [[ .. ]] 中的分号现在是可选的吗? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench 为什么双破折号 (--) 会导致此 MariaDB 子句评估为 true? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng 为什么 `dict(id=1, **{'id': 2})` 有时会引发 `KeyError: 'id'` 而不是 TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String” 2024-03-20 03:12:31 +0800 CST
  • Martin Hope
    MarkB 为什么 GCC 生成有条件执行 SIMD 实现的代码? 2024-02-17 06:17:14 +0800 CST

热门标签

python javascript c++ c# java typescript sql reactjs html

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve