• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            逛奔的蝸牛

            我不聰明,但我會很努力

               ::  :: 新隨筆 ::  ::  :: 管理 ::
            轉(zhuǎn)自: http://www.shnenglu.com/biao/archive/2009/05/15/83048.html
            文本語音(Text-to-Speech,以下簡稱TTS),它的作用就是把通過TTS引擎把文本轉(zhuǎn)化為語音輸出。本文不是講述如何建立自己的TTS引擎,而是簡單介紹如何運(yùn)用Microsoft Speech SDK 建立自己的文本語音轉(zhuǎn)換應(yīng)用程序。 

               Microsoft Speech SDK簡介 

               Microsoft Speech SDK是微軟提供的軟件開發(fā)包,提供的Speech API (SAPI)主要包含兩大方面: 

               1. API for Text-to-Speech 

               2. API for Speech Recognition 

               其中API for Text-to-Speech,就是微軟TTS引擎的接口,通過它我們可以很容易地建立功能強(qiáng)大的文本語音程序,金山詞霸的單詞朗讀功能就用到了這寫API,而目前幾乎所有的文本朗讀工具都是用這個SDK開發(fā)的。至于API for Speech Recognition就是與TTS相對應(yīng)的語音識別,語音技術(shù)是一種令人振奮的技術(shù),但由于目前語音識別技術(shù)準(zhǔn)確度和識別速度不太理想,還未達(dá)到廣泛應(yīng)用的要求。 

               Microsoft Speech SDK可以在微軟的網(wǎng)站免費(fèi)下載,目前的版本是5.1,為了支持中文,還要把附加的語言包(LangPack)一起下載。 

               為了在VC中使用這SDK,必需在工程中添加SDK的include和lib目錄,為免每個工程都添加目錄,最好的辦法是在VC的 

               Option->Directoris立加上SDK的include和lib目錄。 

               一個最簡單的例子 

               先看一個入門的例子: 

            #include <sapi.h> 

            #pragma comment(lib,"ole32.lib") //CoInitialize CoCreateInstance需要調(diào)用ole32.dll 
            #pragma comment(lib,"sapi.lib") //sapi.lib在SDK的lib目錄,必需正確配置 
            int main(int argc, char* argv[]) 

            ISpVoice * pVoice = NULL; 

            //COM初始化: 
            if (FAILED(::CoInitialize(NULL))) 
            return FALSE; 

            //獲取ISpVoice接口: 
            HRESULT hr = CoCreateInstance(CLSID_SpVoice, NULL, CLSCTX_ALL, IID_ISpVoice, (void **)&pVoice); 
            if( SUCCEEDED( hr ) ) 

            hr = pVoice->Speak(L"Hello world", 0, NULL); 
            pVoice->Release(); 
            pVoice = NULL; 


            //千萬不要忘記: 
            ::CoUninitialize(); 
            return TRUE; 



               短短20幾行代碼就實(shí)現(xiàn)了文本語音轉(zhuǎn)換,夠神奇吧。SDK提供的SAPI是基于COM封裝的,無論你是否熟悉COM,只要按部就班地用CoInitialize(), CoCreateInstance()獲取IspVoice接口就夠了,需要注意的是初始化COM后,程序結(jié)束前一定要用CoUninitialize()釋放資源。 

               IspVoice接口主要函數(shù) 

               上述程序的流程是獲取IspVoice接口,然后用ISpVoice::Speak()把文本輸出為語音,可見,程序的核心就是IspVoice接口。除了Speak外IspVoice接口還有許多成員函數(shù),具體用法請參考SDK的文檔。下面擇要說一下幾個主要函數(shù)的用法: HRESULT Speak(const WCHAR *pwcs,DWORD dwFlags,ULONG *pulStreamNumber); 

               功能:就是speak了 

               參數(shù): 

                *pwcs 輸入的文本字符串,必需為Unicode,如果是ansi字符串必需先轉(zhuǎn)換為Unicode。 

                dwFlags 用來標(biāo)志Speak的方式,其中SPF_IS_XML 表示輸入文本含有XML標(biāo)簽,這個下文會講到。 

                PulStreamNumber 輸出,用來獲取去當(dāng)前文本輸入的等候播放隊(duì)列的位置,只有在異步模式才有用。 

            HRESULT Pause ( void ); 
            HRESULT Resume ( void ); 

               功能:一看就知道了。 

            HRESULT SetRate(long RateAdjust ); 
            HRESULT GetRate(long *pRateAdjust); 

               功能:設(shè)置/獲取播放速度,范圍:-10 to 10 

            HRESULT SetVolume(USHORT usVolume); 
            HRESULT GetVolume(USHORT *pusVolume); 

               功能:設(shè)置/獲取播放音量,范圍:0 to 100 

            HRESULT SetSyncSpeakTimeout(ULONG msTimeout); 
            HRESULT GetSyncSpeakTimeout(ULONG *pmsTimeout); 

               功能:設(shè)置/獲取同步超時時間。由于在同步模式中,電泳Speak后程序就會進(jìn)入阻塞狀態(tài)等待Speak返回,為免程序長時間沒相應(yīng),應(yīng)該設(shè)置超時時間,msTimeout單位為毫秒。 

            HRESULT SetOutput(IUnknown *pUnkOutput,BOOL fAllowFormatChanges); 

               功能:設(shè)置輸出,下文會講到用SetOutput把Speak輸出問WAV文件。 

               這些函數(shù)的返回類型都是HRESULT,如果成功則返回S_OK,錯誤有各自不同的錯誤碼。 

               使用XML 
            引自: http://study.qqcf.com/web/198/22269.htm
               個人認(rèn)為這個TTS api功能最強(qiáng)大之處在于能夠分析XML標(biāo)簽,通過XML標(biāo)簽設(shè)置音量、音調(diào)、延長、停頓,幾乎可以使輸出達(dá)到自然語音效果。前面已經(jīng)提過,把Speak參數(shù)dwFlags設(shè)為SPF_IS_XML,TTS引擎就會分析XML文本,輸入文本并不需要嚴(yán)格遵守W3C的標(biāo)準(zhǔn),只要含有XML標(biāo)簽就行了,下面舉個例子: …… 

            pVoice->Speak(L"<VOICE REQUIRED=''NAME=Microsoft Mary''/>volume<VOLUME LEVEL=''100''>turn up</VOLUME>", SPF_IS_XML, NULL); 
            …… 
            <VOICE REQUIRED=''NAME=Microsoft Mary''/> 

               標(biāo)簽把聲音設(shè)為Microsoft Mary,英文版SDK中一共含有3種聲音,另外兩種是Microsoft Sam和Microsoft Mike。 …… 

            <VOLUME LEVEL=''100''> 

               把音量設(shè)為100,音量范圍是0~100。 

               另外:標(biāo)志音調(diào)(-10~10): <P99vCH MIDDLE="10">text</P99vCH> 

               注意:" 號在C/C++中前面要加 \ ,否則會出錯。
            posted on 2009-08-29 07:29 逛奔的蝸牛 閱讀(2496) 評論(0)  編輯 收藏 引用 所屬分類: Qt
            免费久久人人爽人人爽av| 伊人色综合久久天天| 无码人妻久久一区二区三区蜜桃| 日本三级久久网| 日日狠狠久久偷偷色综合免费| 欧美一级久久久久久久大| 久久久久久精品免费免费自慰| 亚洲伊人久久精品影院| 狠狠色婷婷久久一区二区三区| 97热久久免费频精品99| 久久激情五月丁香伊人| 日日噜噜夜夜狠狠久久丁香五月| 91久久精品国产免费直播| 中文字幕人妻色偷偷久久| yellow中文字幕久久网 | 伊人精品久久久久7777| 一本一本久久A久久综合精品| 国产精品狼人久久久久影院| 国产成人精品综合久久久久 | 久久影视国产亚洲| 99久久婷婷国产综合亚洲| 国产精品久久久久久久久久影院| 婷婷综合久久中文字幕| 久久精品国产99久久久| 久久AV高潮AV无码AV| 欧美午夜A∨大片久久| 亚洲国产精品热久久| 久久青青草原综合伊人| 韩国免费A级毛片久久| 7777久久久国产精品消防器材| 久久伊人色| 一本久久精品一区二区| 久久综合伊人77777| 久久久精品波多野结衣| 久久精品无码专区免费| 99久久精品无码一区二区毛片| 狠狠色婷婷综合天天久久丁香| 久久精品国产亚洲AV无码偷窥| 日韩精品久久无码中文字幕| 人人妻久久人人澡人人爽人人精品| 久久天天躁狠狠躁夜夜不卡 |