在我们的 C/C++ 程序中使用 espeak 需要哪些行?
Which lines are necessary to use espeak in our C/C++ program?
我在网上找到这段代码:
#include <string.h>
#include <malloc.h>
#include <espeak/speak_lib.h>
espeak_POSITION_TYPE position_type;
espeak_AUDIO_OUTPUT output;
char *path=NULL;
int Buflength = 1000, Options=0;
void* user_data;
t_espeak_callback *SynthCallback;
espeak_PARAMETER Parm;
char Voice[] = {"English"};
char text[30] = {"this is a english test"};
unsigned int Size,position=0, end_position=0, flags=espeakCHARS_AUTO, *unique_identifier;
int main(int argc, char* argv[] )
{
output = AUDIO_OUTPUT_PLAYBACK;
int I, Run = 1, L;
espeak_Initialize(output, Buflength, path, Options );
espeak_SetVoiceByName(Voice);
const char *langNativeString = "en"; //Default to US English
espeak_VOICE voice;
memset(&voice, 0, sizeof(espeak_VOICE)); // Zero out the voice first
voice.languages = langNativeString;
voice.name = "US";
voice.variant = 2;
voice.gender = 1;
espeak_SetVoiceByProperties(&voice);
Size = strlen(text)+1;
espeak_Synth( text, Size, position, position_type, end_position, flags,
unique_identifier, user_data );
espeak_Synchronize( );
return 0;
}
我只希望 espeak
在我的程序中读取我的字符串,上面的代码可以做到,但我想知道,是否需要所有这些代码来达到这个目的? (我的意思是可以简化它吗?)
***我还想知道有没有办法将 espeak
用作系统函数?我是说 system("espeak "something" ");
?
eSpeak 本身的使用似乎很少 - 您需要阅读相关文档。可能有一些小的 C 代码简化,但也许不值得付出努力:
memset()
是不必要的。该结构可以初始化为零,因此:
espeak_VOICE voice = {0} ;
如果您这样声明 text
:
char text[] = "this is a English test";
那你就可以不用strlen()
,把Size
换成sizeof(text)
.
变量 I
、Run
和 L
未使用,可以删除。
为了能够在命令行上将文本作为字符串传递,从而能够发出 system( "espeak \"Say Something\"") ;
,例如,您只需将 argv[1]
传递给 espeak_Synth()
而不是 text
(但您需要恢复 strlen()
调用以获取大小。
我在网上找到这段代码:
#include <string.h>
#include <malloc.h>
#include <espeak/speak_lib.h>
espeak_POSITION_TYPE position_type;
espeak_AUDIO_OUTPUT output;
char *path=NULL;
int Buflength = 1000, Options=0;
void* user_data;
t_espeak_callback *SynthCallback;
espeak_PARAMETER Parm;
char Voice[] = {"English"};
char text[30] = {"this is a english test"};
unsigned int Size,position=0, end_position=0, flags=espeakCHARS_AUTO, *unique_identifier;
int main(int argc, char* argv[] )
{
output = AUDIO_OUTPUT_PLAYBACK;
int I, Run = 1, L;
espeak_Initialize(output, Buflength, path, Options );
espeak_SetVoiceByName(Voice);
const char *langNativeString = "en"; //Default to US English
espeak_VOICE voice;
memset(&voice, 0, sizeof(espeak_VOICE)); // Zero out the voice first
voice.languages = langNativeString;
voice.name = "US";
voice.variant = 2;
voice.gender = 1;
espeak_SetVoiceByProperties(&voice);
Size = strlen(text)+1;
espeak_Synth( text, Size, position, position_type, end_position, flags,
unique_identifier, user_data );
espeak_Synchronize( );
return 0;
}
我只希望 espeak
在我的程序中读取我的字符串,上面的代码可以做到,但我想知道,是否需要所有这些代码来达到这个目的? (我的意思是可以简化它吗?)
***我还想知道有没有办法将 espeak
用作系统函数?我是说 system("espeak "something" ");
?
eSpeak 本身的使用似乎很少 - 您需要阅读相关文档。可能有一些小的 C 代码简化,但也许不值得付出努力:
memset()
是不必要的。该结构可以初始化为零,因此:
espeak_VOICE voice = {0} ;
如果您这样声明 text
:
char text[] = "this is a English test";
那你就可以不用strlen()
,把Size
换成sizeof(text)
.
变量 I
、Run
和 L
未使用,可以删除。
为了能够在命令行上将文本作为字符串传递,从而能够发出 system( "espeak \"Say Something\"") ;
,例如,您只需将 argv[1]
传递给 espeak_Synth()
而不是 text
(但您需要恢复 strlen()
调用以获取大小。