1
私はタイルの形で多数のイメージをレンダリングする光沢のあるアプリケーションを構築しています。私はLightbox jScriptを私のアプリケーションに統合したいと思っています。それ、どうやったら出来るの。光沢のあるアプリケーションにLightboxを統合するには?
最小限の作業コード:
UI:
shinyUI(dashboardPage(skin = "green",
dashboardHeader(title = "MYAPP"),
dashboardSidebar(
useShinyjs(),
includeCSS("www/styles.css"),
includeCSS("www/lightbox.css"),
includeCSS("www/lightbox.min.css"),
includeScript("www/lightbox.js"),
includeScript("www/lightbox.min.js"),
sidebarMenu(id = "tabs",
menuItem("PICTURES & IMAGES", tabName = "imag", icon = shiny::icon("angle-double-right"))
)
),
dashboardBody(
tabItems(
tabItem(
tabName = "imag", h3("PICTURES & IMAGES"),
fluidRow(
uiOutput("picss")
)
)
))
))
サーバコード:
shinyServer(function(input, output) {
output$picss <- renderUI({
fluidRow(
column(12, id="columns",
lapply(df1$recipe.link, function(i) {
box(width=NULL,
title = HTML(paste0("<div class='image-wrap'>
<img src='./images/",
df1$img[df1$recipe.link == i],"'class=fixed-height'",
df1$img[df1$recipe.link == i],
"'></div>"
))
)}
)))
})
})
global.R
library(shiny)
library(shinydashboard)
library(shinyjs)
library(base64enc)
df1 <- readRDS("df1.RDS")
filepath <- "www/images/"
dir.create(file.path(filepath), showWarnings = FALSE)
for (i in 1:nrow(df1)){
if(df1[i,"image_path"] == "NULL"){
next
}
testObj <- strsplit(df1[i,"image_path"],",")[[1]][2]
inconn <- testObj
outconn <- file(paste0(filepath,"image_id",df1[i,"id"],".jpg"),"wb")
base64decode(what=inconn, output=outconn)
close(outconn)
}
Beakovic助けを借りてくれてありがとう...これは本当に素晴らしいです....私は私の生産環境でこれを実装し、それは完璧に動作します。最後の2日間はこれで苦労していました。
Apricot
喜んで助けました! "私はそれを1つの小さなアプリで使うことを考えているので、好奇心が強いと思う。 –
はい、それはありました!私のデータセットは1000の写真を持ち、市場やその他のパラメータでサブセットするフィルタを使用しています....私は反応性のあるdfから供給された画像の下の複数の行に関連する情報を提供するために 'data-title =" My caption ">'を微調整しました。 Rは、私にはウェブインターフェイスを作成するのが難しい課題です。私はこのコミュニティ全体に感謝して、私が学習し、権限を与えられるように助けてくれます。 – Apricot