iOS開発 - AVSpeechSynthesizer AVFAudioの音声合成(テキスト読み上げ)機能

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 クラスのインスタンスです。

学習記録、日々改善を続けてください。

おすすめ

転載: blog.csdn.net/gloryFlow/article/details/131991707