大概半月前寫了一篇博文:C++中使用Curl和JsonCpp調用有道翻譯API實現在線翻譯, 得到大家的熱情捧場,有人看了文章說要是能發聲不是更好,我覺得說的也是哈,能聽到專家的標准發音,那該是多美的一件事,那我就研究下唄。這段時間一直在忙着學習Unix Network Programming的東西,終於在今天下午抽出時間來完成這個事情。
好了,閑話不說,我給大家說說我的語音辭典開發之旅吧!開發環境Ubuntu + GCC4.7
一、 聲音從哪里來
要讓辭典發音,也就是說,我們需要得到這個單詞的發音的音頻,之前實現辭典用的是有道辭典的API,很好用,所以這次也就欣欣然選擇有道發音API來得到單詞的發音,API地址如下:
1 http://dict.youdao.com/dictvoice?audio=%word_you_want_to_play%
諸如,你要得到futures這個單詞的發音,你只需要在瀏覽器輸入http://dict.youdao.com/dictvoice?audio=futures,然后就可以聽到一個女聲的futures的發音了!
二、 怎么使用程序去發音
1. 把聲音拿回來
聲音有了,但是我們要自己實現程序去作這個事情,難道我還每次去打開瀏覽器訪問以下不成!No,no!我沒有想到太好的辦法,就用我認為很土很笨的方法吧!
我把API返回的聲音存成mp3文件,然后再想辦法唄,后來一想,也有必要哈,把查過的這個單詞存下來了,如果一次沒有聽清楚,我還可以再聽一次撒!那動手唄,把聲音先放到硬盤再說!
我們需要使用的三方庫還是上一篇文章C++中使用Curl和JsonCpp調用有道翻譯API實現在線翻譯用到的libcurl,直接貼代碼:
1 #include "curl/curl.h" 2 3 FILE *fp; 4 5 size_t voice_writer(void *ptr, size_t size, size_t nmemb, void *stream) 6 { 7 int written = fwrite(ptr, size, nmemb, (FILE *)fp); 8 return written; 9 }
上面這個方法在以下的代碼中,也就是curl的回調中會用到:
1 int main(int argc, char *argv[]) 2 { 3 CURL *curl; 4 curl_global_init(CURL_GLOBAL_ALL); 5 curl = curl_easy_init(); 6 std::string voice_url = "http://dict.youdao.com/dictvoice?audio="; 7 voice_url += argv[1]; 8 curl_easy_setopt(curl, CURLOPT_URL, voice_url.c_str()); 9 10 if((fp = fopen("voice.mp3", "w")) == NULL) 11 { 12 curl_easy_cleanup(curl); 13 exit(1); 14 } 15 16 curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, voice_writer); 17 curl_easy_perform(curl); 18 curl_easy_cleanup(curl); 19 20 return 0; 21 }
好了,根據我的想法,編譯運行之后一個voice.mp3的文件就放在了我的當前目錄中!(PS:不是完整代碼,其實就差幾個頭文件而已,自己加上吧!)
2. 把聲音放出來
聲音到手,我先試着用播放器聽了下,沒錯,正是我想要的!下一個步驟,我們要在程序中把聲音放出來,總不能每次用播放器去聽吧!C++中如何播放mp3,以前作VC開發的時候貌似遇到過,linux下我還是第一次面對這個需求,怎么辦?問GOOGLE,輸入諸如C++ mp3 encoder library,找了一圈,貌似也沒個太好的庫供我使用,我可不喜歡解碼開始!腫么辦?我想到了另外一個方法,system方法,是的,你沒看錯,就是他!這個最拿手了,SoX大家應該都知道,SoX是Sound eXchange的簡寫,主頁見這里。SoX在音頻處理領域有瑞士軍刀的美稱,支持很多格式的音頻文件,如 WAV,MP3,MPG,OGG,FLAC 等等!沒有安裝的童鞋看這里:
1 sudo apt-get install sox 2 sudo apt-get install sox libsox-fmt-all
安裝成功之后,只需要使用以下命令去播放既可:
1 play voice.mp3
好了,走遠了,我們繼續回到我們的system方法吧:
1 system("play voice.mp3");
Are you kidding me? 不好意思,我確實沒有太好的方法了!(PS:有其他的C++庫可以播放MP3,有知道的朋友歡迎指導,我也很想用個比較perfect的方法!)
三、 小結
好了,這就是今天的主要內容,使用之前的一篇文章中提供的辭典源碼,和今天的發音源碼整合到一起,就是一個准perfect的在線發音辭典了,這里不再貼出所有源碼,感興趣的可以自己整合一下!
用程序改變世界,我是敢想敢做的程序猿。感謝閱讀,希望幫到大家!