iOS開発 - AVSpeechSynthesizer AVFAudioの音声合成(テキスト読み上げ)機能
前回の開発では、テキスト読み上げの必要性に遭遇しました。幸いなことに、システムはこの機能を実装するための API、つまり AVFAudio の AVSpeechSynthesizer を提供します。
AVFAudio が提供する AVSpeechSynthesizer を使用して、テキスト読み上げ (音声合成) 機能を実装できます。このクラスは、1 つ以上の言語コンテンツを再生するために使用され、これらの音声コンテンツは AVSpeechUtterance クラスのインスタンスです。
1.AVスピーチシンセサイザー
AVSpeechSynthesizer は、テキスト発話から合成音声を生成し、進行中の音声を監視または制御できるオブジェクトです。
テキストを再生すると、そのテキストを含む AVSpeechUtterance のインスタンスを作成し、それを AVSpeechSynthesizer のインスタンスに渡して、speakUtterance: を通じて再生できます。
AVSpeechSynthesizer はキューを維持します。現在実行中のタスクがない場合は、すぐに合成を開始します。現在実行中の合成タスクがある場合は、それをキューに追加し、受信した順序で合成します。
AVSpeechSynthesizerDelegate メソッドを使用して、再生するかどうか、および再生が完了したかどうかを判断できます。
2、AVSpeechSynthesizer 音声合成コード
コードは以下のように表示されます
#import "INAVSpeechPresenter.h"
#import <AVFAudio/AVSpeechSynthesis.h>
@implementation INAVSpeechPresenter
- (void)didStart:(UIButton *)sender {
if(sender.selected == NO) {
if([self.avSpeech isPaused]) {
//如果暂停则恢复,会从暂停的地方继续
[self.avSpeech continueSpeaking];
sender.selected = !sender.selected;
}else{
// 初始化对象
AVSpeechUtterance *utterance = [[AVSpeechUtterance alloc]initWithString:@"收款9865.05元"];//需要转换的文字
utterance.rate = 0.2;// 设置语速,范围0-1,注意0最慢,1最快;AVSpeechUtteranceMinimumSpeechRate最慢,AVSpeechUtteranceMaximumSpeechRate最快
AVSpeechSynthesisVoice*voice = [AVSpeechSynthesisVoice voiceWithLanguage:@"zh-CN"];//设置发音,这是中文普通话
utterance.voice = voice;
[self.avSpeech speakUtterance:utterance];//开始
sender.selected = !sender.selected;
}
} else {
//[av stopSpeakingAtBoundary:AVSpeechBoundaryWord];//感觉效果一样,对应代理>>>取消
[self.avSpeech pauseSpeakingAtBoundary:AVSpeechBoundaryWord];//暂停
sender.selected = !sender.selected;
}
}
#pragma mark - AVSpeechSynthesizerDelegate
- (void)speechSynthesizer:(AVSpeechSynthesizer*)synthesizer didStartSpeechUtterance:(AVSpeechUtterance*)utterance{
NSLog(@"---开始播放");
}
- (void)speechSynthesizer:(AVSpeechSynthesizer*)synthesizer didFinishSpeechUtterance:(AVSpeechUtterance*)utterance{
NSLog(@"---完成播放");
}
- (void)speechSynthesizer:(AVSpeechSynthesizer*)synthesizer didPauseSpeechUtterance:(AVSpeechUtterance*)utterance{
NSLog(@"---播放中止");
}
- (void)speechSynthesizer:(AVSpeechSynthesizer*)synthesizer didContinueSpeechUtterance:(AVSpeechUtterance*)utterance{
NSLog(@"---恢复播放");
}
- (void)speechSynthesizer:(AVSpeechSynthesizer*)synthesizer didCancelSpeechUtterance:(AVSpeechUtterance*)utterance{
NSLog(@"---播放取消");
}
#pragma mark - SETTER/GETTER
- (AVSpeechSynthesizer *)avSpeech {
if (!_avSpeech) {
_avSpeech = [[AVSpeechSynthesizer alloc] init];
_avSpeech.delegate = self;
}
return _avSpeech;
}
@end
3. まとめ
iOS開発 - AVSpeechSynthesizer AVFAudioの音声合成(テキスト読み上げ)機能。AVSpeechSynthesizer はテキスト読み上げ (音声合成) 機能を実現します。このクラスは 1 つ以上の言語コンテンツを再生するために使用され、これらの音声コンテンツは AVSpeechUtterance クラスのインスタンスです。
学習記録、日々改善を続けてください。