
Este é um pacote de texto para fala para o Laravel. Sua principal intenção é usar uma API compartilhada para converter o texto facilmente em fala.
Atualmente, o único driver suportado é a Amazon Polly. Estamos explorando a opção de apoiar em breve o Google WaveNet. Sinta -se à vontade para iniciar uma discussão sobre qualquer motorista possível.
use Cion TextToSpeech Facades TextToSpeech ;
// convert text from a text file
$ path = TextToSpeech:: source ( ' path ' )
-> convert ( ' /path/to/text/file ' );
// you may also pass the string directly to convert() method
$ path = TextToSpeech:: convert ( ' Convert this string. ' );
// configure where to save the converted output. In this case, it would save the output file in the storage/output.mp3
$ path = TextToSpeech:: saveTo ( ' output.mp3 ' )
-> convert ( ' Hi this is a test. ' );
// store the converted output directly to S3
$ path = TextToSpeech:: disk ( ' s3 ' )
-> saveTo ( ' output.mp3 ' )
-> convert ( ' Store me to S3. ' );
// convert website articles & blog posts to an audio file
$ path = TextToSpeech:: source ( ' website ' )
-> convert ( ' https://medium.com/cloud-academy-inc/an-introduction-to-aws-polly-s3-and-php-479490bffcbd ' );
/**
* Change the language to be used for the conversion.
* Note: every language has a specific voice_id.
* For example in ja-JP language we need to use either Mizuki or Takumi.
*
* We can pass an option array in convert to change the voice_id to be used
**/
$ options = [ ' voice ' => ' Takumi ' ];
$ path = TextToSpeech:: language ( ' ja-JP ' )
-> convert ( 'これはテストです' , $ options );
// use the SSML text type in the convert() method.
$ path = TextToSpeech:: ssml ()
-> convert ( ' <speak>Hi There <break /> This is SSML syntax</speak ' );
// using speech marks.
$ output = TextToSpeech:: speechMarks ([ ' sentence ' , ' word ' , ' viseme ' , ' ssml ' ])
-> convert ( ' This is a test ' ); // This will return an array. Você pode instalar o pacote via compositor:
composer require cion/laravel-text-to-speechO pacote se registrará automaticamente.
Opcionalmente, você pode publicar o arquivo de configuração com:
php artisan vendor:publish --provider= " CionTextToSpeechProvidersTextToSpeechServiceProvider " --tag= " config " Em seguida, adicione estas chaves ao seu arquivo .env :
TTS_DRIVER = polly
TTS_DISK = local
TTS_OUTPUT_FORMAT = mp3
TTS_LANGUAGE = en-US
TTS_TEXT_TYPE = text
AWS_VOICE_ID = Amy
AWS_ACCESS_KEY_ID = xxxxxxx
AWS_SECRET_ACCESS_KEY = xxxxxxx
AWS_DEFAULT_REGION = us-east-1A seguir, o conteúdo do arquivo de configuração publicado:
return [
/*
* The disk on which to store converted mp3 files by default. Choose
* one of the disks you've configured in config/filesystems.php.
*/
' disk ' => env ( ' TTS_DISK ' , ' local ' ),
/**
* The default audio format of the converted text-to-speech audio file.
* Currently, mp3 is the only supported format.
*/
' output_format ' => env ( ' TTS_OUTPUT_FORMAT ' , ' mp3 ' ),
/**
* The driver to be used for converting text-to-speech
* You can choose polly, or null as of now.
*/
' driver ' => env ( ' TTS_DRIVER ' , ' polly ' ),
/**
* The default language to be used.
*
* You may use any of the following:
*
* arb, cmn-CN, cy-GB, da-DK, de-DE, en-AU, en-GB, en-GB-WLS, en-IN, en-US,
* es-ES, es-MX, es-US, fr-CA, fr-FR, is-IS, it-IT, ja-JP, hi-IN, ko-KR, nb-NO,
* nl-NL, pl-PL, pt-BR, pt-PT, ro-RO, ru-RU, sv-SE, tr-TR
*/
' language ' => env ( ' TTS_LANGUAGE ' , ' en-US ' ),
' audio ' => [
/**
* Default path to store the output file.
*/
' path ' => ' TTS ' ,
/**
* Default filename formatter.
*/
' formatter ' => Cion TextToSpeech Formatters DefaultFilenameFormatter::class,
],
/**
* The default source that will be used.
*/
' default_source ' => ' text ' ,
/**
* The default text type to be used.
* You can use either text or ssml.
*/
' text_type ' => env ( ' TTS_TEXT_TYPE ' , ' text ' ),
/**
* The source that can be used.
* You can create your own source by implementing the Source interface.
*
* @see CionTextToSpeechContractsSource
*/
' sources ' => [
' text ' => Cion TextToSpeech Sources TextSource::class,
' path ' => Cion TextToSpeech Sources PathSource::class,
' website ' => Cion TextToSpeech Sources WebsiteSource::class,
],
' services ' => [
' polly ' => [
/**
* Voice ID to use for the synthesis.
* You may use any of the following:.
*
* Aditi, Amy, Astrid, Bianca, Brian, Camila, Carla, Carmen, Celine,
* Chantal, Conchita, Cristiano, Dora, Emma, Enrique, Ewa, Filiz,
* Geraint, Giorgio, Gwyneth, Hans, Ines, Ivy, Jacek, Jan, Joanna,
* Joey, Justin, Karl, Kendra, Kimberly, Lea, Liv, Lotte, Lucia,
* Lupe, Mads, Maja, Marlene, Mathieu, Matthew, Maxim, Mia, Miguel,
* Mizuki, Naja, Nicole, Penelope, Raveena, Ricardo, Ruben, Russell,
* Salli, Seoyeon, Takumi, Tatyana, Vicki, Vitoria, Zeina, Zhiyu.
*/
' voice_id ' => env ( ' AWS_VOICE_ID ' , ' Amy ' ),
/**
* You can request any or all of the speech mark types, but leave it empty if you don't use speech marks.
* You may add any of the following:.
*
* sentence, word, viseme, ssml
*/
' speech_marks ' => [],
/**
* IAM Credentials from AWS.
*/
' credentials ' => [
' key ' => env ( ' AWS_ACCESS_KEY_ID ' , '' ),
' secret ' => env ( ' AWS_SECRET_ACCESS_KEY ' , '' ),
],
' region ' => env ( ' AWS_DEFAULT_REGION ' , ' us-east-1 ' ),
' version ' => ' latest ' ,
],
],
];composer test Consulte nossa página de lançamentos para obter mais informações sobre o que mudou recentemente.
Por favor, consulte a contribuição para obter detalhes.
Para obter ajuda, discussão sobre as melhores práticas ou qualquer outra conversa que se beneficie de ser pesquisável:
Text-to-fala no GitHub
Para bate-papo casual com outras pessoas usando este pacote:
Junte -se ao servidor Meema Discord
Revise nossa política de segurança sobre como relatar vulnerabilidades de segurança.
A licença do MIT (MIT). Consulte a licença para obter mais informações.
Feito com ❤️ por Meema, Inc.