Shiny Watson 实时文本转语音
Shiny Watson text to speech real time
library(shiny)
library(cognizer)
#' the required api keys
username_TTS <-""
password_TTS <- ""
TEXT_TO_SPEECH_USERNAME_PASSWORD = paste(username_TTS,":",password_TTS,sep="")
ui <- fluidPage(
# Application title
titlePanel("Just some text to speech example"),
fluidRow(textInput("caption","Enter the caption"),actionButton("gobutton","submit")),
fluidRow(verbatimTextOutput("answer"), width = 4),
# plays from www/
fluidRow(tags$audio(src = "1.wav", type = "audio/wav", controls = NA), helpText("Key in any sentences, wait and press F5. Then you can play your audio"))
)
server <- function(input, output) {
textfunction <- eventReactive(input$gobutton, {
thetext <- input$caption
text_audio(thetext, TEXT_TO_SPEECH_USERNAME_PASSWORD, directory = 'www', accept = "audio/wav")
"Done!"
})
output$answer <- renderText({textfunction()})
}
# Run the application
shinyApp(ui = ui, server = server)
我使用 Watson 创建了一个将文本转换为语音的应用程序。用户输入一个文本句子。单击提交,watson 会将其转换为音频文件。但是,播放的音频文件始终是之前的文本,除非您通过 F5 刷新应用程序。如何让音频播放器播放最新的音频文件?
示例:文本 1:你好
提交并播放 "hello"
文本 2:再见
提交并播放,仍然 "hello"
直到我F5,然后当我点击播放时,它"bye"
问题与 Shiny 对音频文件的缓存有关。如 所述的解决方法可以帮助您:
查询后重命名 wav 文件,并在服务器端使用 renderUI()
并在 UI 中使用 uiOutput()
将其传递到响应式 UI 组件。
请看下面的工作示例:
library(shiny)
library(cognizer)
# the required api keys
username_TTS <-""
password_TTS <- ""
TEXT_TO_SPEECH_USERNAME_PASSWORD = paste(username_TTS,":",password_TTS,sep="")
ui <- fluidPage(
# Application title
titlePanel("Just some text to speech example"),
fluidRow(textInput("caption","Enter the caption"),actionButton("gobutton","submit")),
fluidRow(verbatimTextOutput("answer"), width = 4),
# plays from www/
fluidRow(
uiOutput("play")
)
)
server <- function(input, output) {
observeEvent(input$gobutton, {
unlink("www/*.wav")
thetext <- input$caption
text_audio(thetext, TEXT_TO_SPEECH_USERNAME_PASSWORD, directory = 'www', accept = "audio/wav")
file.rename("www/1.wav", paste0("www/number",input$gobutton,".wav"))
"Done!"
output$play <- renderUI(
tags$audio(src = paste0("temp.wav"), type = "audio/wav", controls = NA)
)
output$play <- renderUI(
tags$audio(src = paste0("number", input$gobutton,".wav"), type = "audio/wav", controls = NA)
)
output$answer <- renderText(paste("Done!", input$gobutton))
})
}
# Run the application
shinyApp(ui = ui, server = server)
library(shiny)
library(cognizer)
#' the required api keys
username_TTS <-""
password_TTS <- ""
TEXT_TO_SPEECH_USERNAME_PASSWORD = paste(username_TTS,":",password_TTS,sep="")
ui <- fluidPage(
# Application title
titlePanel("Just some text to speech example"),
fluidRow(textInput("caption","Enter the caption"),actionButton("gobutton","submit")),
fluidRow(verbatimTextOutput("answer"), width = 4),
# plays from www/
fluidRow(tags$audio(src = "1.wav", type = "audio/wav", controls = NA), helpText("Key in any sentences, wait and press F5. Then you can play your audio"))
)
server <- function(input, output) {
textfunction <- eventReactive(input$gobutton, {
thetext <- input$caption
text_audio(thetext, TEXT_TO_SPEECH_USERNAME_PASSWORD, directory = 'www', accept = "audio/wav")
"Done!"
})
output$answer <- renderText({textfunction()})
}
# Run the application
shinyApp(ui = ui, server = server)
我使用 Watson 创建了一个将文本转换为语音的应用程序。用户输入一个文本句子。单击提交,watson 会将其转换为音频文件。但是,播放的音频文件始终是之前的文本,除非您通过 F5 刷新应用程序。如何让音频播放器播放最新的音频文件?
示例:文本 1:你好 提交并播放 "hello" 文本 2:再见 提交并播放,仍然 "hello" 直到我F5,然后当我点击播放时,它"bye"
问题与 Shiny 对音频文件的缓存有关。如
查询后重命名 wav 文件,并在服务器端使用 renderUI()
并在 UI 中使用 uiOutput()
将其传递到响应式 UI 组件。
请看下面的工作示例:
library(shiny)
library(cognizer)
# the required api keys
username_TTS <-""
password_TTS <- ""
TEXT_TO_SPEECH_USERNAME_PASSWORD = paste(username_TTS,":",password_TTS,sep="")
ui <- fluidPage(
# Application title
titlePanel("Just some text to speech example"),
fluidRow(textInput("caption","Enter the caption"),actionButton("gobutton","submit")),
fluidRow(verbatimTextOutput("answer"), width = 4),
# plays from www/
fluidRow(
uiOutput("play")
)
)
server <- function(input, output) {
observeEvent(input$gobutton, {
unlink("www/*.wav")
thetext <- input$caption
text_audio(thetext, TEXT_TO_SPEECH_USERNAME_PASSWORD, directory = 'www', accept = "audio/wav")
file.rename("www/1.wav", paste0("www/number",input$gobutton,".wav"))
"Done!"
output$play <- renderUI(
tags$audio(src = paste0("temp.wav"), type = "audio/wav", controls = NA)
)
output$play <- renderUI(
tags$audio(src = paste0("number", input$gobutton,".wav"), type = "audio/wav", controls = NA)
)
output$answer <- renderText(paste("Done!", input$gobutton))
})
}
# Run the application
shinyApp(ui = ui, server = server)