#pragma once #include "texttospeech.h" struct ITTSCentralW; struct ITTSAttributesA; class SpeechApi40a : public TextToSpeech { public: SpeechApi40a(); virtual ~SpeechApi40a(); //-------------------------------------------------------------------------- // Description : is the api available for use // Return : true - it is available // false - it is not available //-------------------------------------------------------------------------- virtual bool isAvailable(); //-------------------------------------------------------------------------- // Description : load/unload/reload the speech api // Return : true - the action succeeded // false - the action failed //-------------------------------------------------------------------------- virtual bool load(); virtual bool unload(); //-------------------------------------------------------------------------- // Description : check if the speech api is loaded // Return : true - the speech_api is loaded // false - its not loaded //-------------------------------------------------------------------------- virtual bool isLoaded() const; //-------------------------------------------------------------------------- // Description : speak a sentence // Parameters : sentence - the sentence to speak // Returns : true - speak successful // false - speak failed //-------------------------------------------------------------------------- virtual bool say(const std::wstring &sentence); //-------------------------------------------------------------------------- // Description : set the voice settings // Parameters : range from 0 to 100 //-------------------------------------------------------------------------- virtual bool setVolume(int volume); virtual bool setPitch(int pitch); virtual bool setRate(int rate); //-------------------------------------------------------------------------- // Description : set the voice //-------------------------------------------------------------------------- virtual bool setVoice(const std::wstring &voice); //-------------------------------------------------------------------------- // Description : get the available voices //-------------------------------------------------------------------------- virtual std::vector getVoices() const; //-------------------------------------------------------------------------- // Description : open the lexicon dialog for this engine // Parameters : window - handle to the parent window // Return : true - dialog completely successfully // false - dialog failed //-------------------------------------------------------------------------- virtual bool lexiconDialog(HWND window); //-------------------------------------------------------------------------- // Description : get the description of the tts engine //-------------------------------------------------------------------------- static std::wstring getDescription(); private: //-------------------------------------------------------------------------- // Description : load the speech api with the specified voice //-------------------------------------------------------------------------- bool loadWithVoice(std::wstring &voice); ITTSCentralW *m_tts_central; ITTSAttributesA *m_tts_attribs; TextToSpeech::State m_state; std::wstring m_voice; int m_volume; int m_pitch; int m_rate; };