iOS自帶TTS技術(shù)的實現(xiàn)即語音播報

文本轉(zhuǎn)語音技術(shù), 也叫TTS, 是Text To Speech的縮寫. iOS如果想做有聲書等功能的時候, 會用到這門技術(shù).

一,使用iOS自帶TTS需要注意的幾點:

    iOS7之后才有該功能
    需要 AVFoundation 庫
    AVSpeechSynthesizer: 語音合成器, 可以假想成一個可以說話的人, 是最主要的接口
    AVSpeechSynthesisVoice: 可以假想成人的聲音
    AVSpeechUtterance: 可以假想成要說的一段話

二,代碼示例, 播放語音

    //語音播報
    AVSpeechUtterance *utterance = [AVSpeechUtterance speechUtteranceWithString:@"床前明月光,疑是地上霜。"];

    utterance.pitchMultiplier=0.8;
    
    //中式發(fā)音
    AVSpeechSynthesisVoice *voice = [AVSpeechSynthesisVoice voiceWithLanguage:@"zh-CN"];
    //英式發(fā)音
//    AVSpeechSynthesisVoice *voice = [AVSpeechSynthesisVoice voiceWithLanguage:@"en-GB"];
    
    utterance.voice = voice;
    
    NSLog(@"%@",[AVSpeechSynthesisVoice speechVoices]);
    
    AVSpeechSynthesizer *synth = [[AVSpeechSynthesizer alloc]init];

三,AVSpeechSynthesizer介紹

這個類就像一個會說話的人, 可以”說話”, 可以”暫?!闭f話, 可以”繼續(xù)”說話, 可以判斷他當(dāng)前是否正在說話.有以下的方法或者屬性:

  • 說話: speakUtterance
  • 控制: continueSpeaking(繼續(xù)說), pauseSpeakingAtBoundary(暫停說話), paused(暫停狀態(tài)的屬性), speaking(說話的狀態(tài)), stopSpeakingAtBoundary(停止說話)
  • 委托: delegate

四,AVSpeechBoundary介紹

這是一個枚舉. 在暫停, 或者停止說話的時候, 停下的方式用這個枚舉標(biāo)示. 包括兩種:

  • AVSpeechBoundaryImmediate: 立即停
  • AVSpeechBoundaryWord : 說完一個整詞再停

五,AVSpeechSynthesizerDelegate介紹

合成器的委托, 對于一些事件, 提供了響應(yīng)的接口.

  • didCancelSpeechUtterance: 已經(jīng)取消說話
  • didContinueSpeechUtterance: 已經(jīng)繼續(xù)說話
  • didFinishSpeechUtterance: 已經(jīng)說完
  • didPauseSpeechUtterance: 已經(jīng)暫停
  • didStartSpeechUtterance:已經(jīng)開始
  • willSpeakRangeOfSpeechString:將要說某段話

六,AVSpeechSynthesisVoice介紹

AVSpeechSynthesisVoice定義了一系列的聲音, 主要是不同的語言和地區(qū).

  • voiceWithLanguage: 根據(jù)制定的語言, 獲得一個聲音.
  • speechVoices: 獲得當(dāng)前設(shè)備支持的聲音
  • currentLanguageCode: 獲得當(dāng)前聲音的語言字符串, 比如”ZH-cn”
  • language: 獲得當(dāng)前的語言

七,AVSpeechUtterance介紹

這個類就是一段要說的話. 主要的屬性和方法有:

  • pitchMultiplier: 音高
  • postUtteranceDelay: 讀完一段后的停頓時間
  • preUtteranceDelay: 讀一段話之前的停頓
  • rate: 讀地速度, 系統(tǒng)提供了三個速度:
    AVSpeechUtteranceMinimumSpeechRate, AVSpeechUtteranceMaximumSpeechRate, AVSpeechUtteranceDefaultSpeechRate
  • speechString: 要讀的字符串
  • voice: 使用的聲音, 是AVSpeechSynthesisVoice對象
  • volume: 音量

八,UML關(guān)系圖

這些類的關(guān)系如下:


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容