安裝 Nuget Google.Cloud.TextToSpeech.V1
data:image/s3,"s3://crabby-images/26295/262950242ee459029aff5bcdbc0f9fe3f442cfbb" alt=""
data:image/s3,"s3://crabby-images/a6a80/a6a807c7d474c21d86376fa7ec6f9d2a2db0839e" alt=""
然後到 Google Cloud Platform 啟用 Text-to-Speech API
data:image/s3,"s3://crabby-images/c2cad/c2cad78900098d364a1ae16d4efe066484b5bb3a" alt=""
建立服務帳戶,完成後會產生一個 Json 檔案
data:image/s3,"s3://crabby-images/b0cee/b0cee9a66f93ee01cad0a202dd796ef6dace1e8e" alt=""
使用環境變數的方式,指向 服務帳戶產生的 Json 檔案的位置
System.Environment.SetEnvironmentVariable("GOOGLE_APPLICATION_CREDENTIALS","你的檔案路徑")
最後,整個照教學範例貼上程式
https://codelabs.developers.google.com/codelabs/cloud-text-speech-csharp#6
data:image/s3,"s3://crabby-images/08c9f/08c9f6ce0707df18861c0133e84e6ac6d1d59550" alt=""
整段程式碼如下 :
data:image/s3,"s3://crabby-images/0f1b4/0f1b4b5e7992511cae3fa5dd974f8f0cb24403fe" alt=""
Server 端
建立一個 SpeechViewModel 來傳遞資料,建立 SpeechViewModelResult 來回傳值
data:image/s3,"s3://crabby-images/bcca6/bcca66b234ea2d4b133c334dcea32a55a8144c04" alt=""
建立 API
data:image/s3,"s3://crabby-images/0084e/0084e3237676eb8660e7da0bb1d9dd94edb4d310" alt=""
使用Postman 測試呼叫 API
data:image/s3,"s3://crabby-images/59dd2/59dd2f63039bd4344bb6b7d5985607bc9b9391fe" alt=""
前端 : 增加 SpeechViewModel.ts
data:image/s3,"s3://crabby-images/bfa8a/bfa8a88e64e960c42e3decd64fe8392ff1699de6" alt=""
html 增加 Play 按鈕
data:image/s3,"s3://crabby-images/dc21b/dc21bcab2a52c9182180f14c62f7b504293076cc" alt=""
修改程式碼 :
data:image/s3,"s3://crabby-images/fa5e0/fa5e0ed2a2d5ad63f661c708f6abe7cbabde31ab" alt=""
經測試已經可以呼叫 Google 的 Text-to-Speech 後產生一個檔案回傳給 Client 撥放
data:image/s3,"s3://crabby-images/3850f/3850f5242712054bc9ff8e4dead18abb2166ef6e" alt=""