swift tts
2.1.2 Error if built with macOS
Этот пакет содержит некоторые очень простые обертки вокруг TTS часть AvFoundation/AvspechSynthesizer, чтобы с легкостью использование текста в речь.
SwiftTTS с использованием Swift Antrulurence с async await , пара AsyncStreamSwiftTTSDependency Обертка вокруг библиотеки выше, облегчающая интеграцию с библиотекой именных зависимостей или проектом, изготовленным с композитной архитектурой (TCA).SwiftTTSCombine Библиотека OG все еще доступна в этом пакете speak(String) -> Void - вызовите этот метод, когда вы просто хотите использовать TTS с простой строкойisSpeaking() -> AsyncStream<Bool> - чтобы узнать, когда высказывание начинает слышать, и когда оно останавливаетсяspeakingProgress() -> AsyncStream<Double> - чтобы узнать прогресс, от 0 до 1rateRatio() -> Float - установите скорость, чтобы замедлить или ускорить двигатель TTSsetRateRatio(Float) -> Void - установите скорость, чтобы замедлить или ускорить двигатель TTSvoice() -> AVSpeechSynthesisVoice? - Голос двигателя TTS, по умолчанию, это голос для en-GBsetVoice(AVSpeechSynthesisVoice) -> Void - установите голос двигателя TTSimport SwiftTTS
let tts = SwiftTTS . live
tts . speak ( " Hello World! " )
Task {
for await isSpeaking in tts . isSpeaking ( ) {
print ( " TTS is currently ( isSpeaking ? " speaking " : " not speaking " ) " )
}
}
Task {
for await progress in tts . speakingProgress ( ) {
print ( " Progress: ( Int ( progress * 100 ) ) % " )
}
}
tts . setRateRatio ( 3 / 4 )
tts . speak ( " Hello World! But slower " ) Добавьте @Dependency(.tts) var tts в свой Reducer , вы будете иметь доступ ко всем функциям, упомянутым выше.
import ComposableArchitecture
import Foundation
import SwiftTTSDependency
public struct TTS : ReducerProtocol {
public struct State : Equatable {
public var text = " "
public var isSpeaking = false
public var speakingProgress = 1.0
public var rateRatio : Float = 1.0
public init (
text : String = " " ,
isSpeaking : Bool = false ,
speakingProgress : Double = 1.0 ,
rateRatio : Float = 1.0
) {
self . text = text
self . isSpeaking = isSpeaking
self . speakingProgress = speakingProgress
self . rateRatio = rateRatio
}
}
public enum Action : Equatable {
case changeRateRatio ( Float )
case speak
case startSpeaking
case stopSpeaking
case changeSpeakingProgress ( Double )
}
@ Dependency ( . tts ) var tts
public init ( ) { }
public var body : some ReducerProtocol < State , Action > {
Reduce { state , action in
switch action {
case let . changeRateRatio ( rateRatio ) :
state . rateRatio = rateRatio
tts . setRateRatio ( rateRatio )
return . none
case . speak :
tts . speak ( state . text )
return . run { send in
for await isSpeaking in tts . isSpeaking ( ) {
if isSpeaking {
await send ( . startSpeaking )
} else {
await send ( . stopSpeaking )
}
}
}
case . startSpeaking :
state . isSpeaking = true
return . run { send in
for await progress in tts . speakingProgress ( ) {
await send ( . changeSpeakingProgress ( progress ) )
}
}
case . stopSpeaking :
state . isSpeaking = false
return . none
case let . changeSpeakingProgress ( speakingProgress ) :
state . speakingProgress = speakingProgress
return . none
}
}
}
} Вы можете создать экземпляр/инъекцию объекта TTSEngine , он имеет такое поведение
func speak(string: String) : вызовите этот метод, когда вы просто хотите использовать TTS с простой строкойisSpeakingPublisher чтобы узнать, когда начинает услышать высказывание, и когда оно останавливаетсяspeakingProgressPublisher , чтобы узнать прогресс, от 0 до 1var rateRatio: Float : установите скорость, чтобы замедлить или ускорить двигатель TTSvar voice: AVSpeechSynthesisVoice? : Установите голос двигателя TTS по умолчанию, это голос для en-GBimport Combine
import SwiftTTSCombine
let engine : TTSEngine = SwiftTTSCombine . Engine ( )
var cancellables = Set < AnyCancellable > ( )
engine . speak ( string : " Hello World! " )
engine . isSpeakingPublisher
. sink { isSpeaking in
print ( " TTS is currently ( isSpeaking ? " speaking " : " not speaking " ) " )
}
. store ( in : & cancellables )
engine . speakingProgressPublisher
. sink { progress in
print ( " Progress: ( Int ( progress * 100 ) ) % " )
}
. store ( in : & cancellables )
engine . rateRatio = 3 / 4
engine . speak ( string : " Hello World! But slower " ) Вы можете добавить Swifttts Libs в проект Xcode, добавив его в качестве зависимости от пакета.
Отредактируйте свой Package.swift Задайте, чтобы добавить одну из библиотеки, которую вы хотите среди трех доступных.
let package = Package (
...
dependencies : [
. package ( url : " https://github.com/renaudjenny/swift-tts " , from : " 2.0.0 " ) ,
...
] ,
targets : [
. target (
name : " <Your project name> " ,
dependencies : [
. product ( name : " SwiftTTS " , package : " swift-tts " ) , // <-- Modern concurrency
. product ( name : " SwiftTTSDependency " , package : " swift-tts " ) , // <-- Point-Free Dependencies library wrapper
. product ( name : " SwiftTTSCombine " , package : " swift-tts " ) , // <-- Combine wrapper
] ) ,
...
]
)