- 相關(guān)推薦
牛人編寫聊天工具的心得
做一個聊天軟件,首先要懂得網(wǎng)絡(luò)通信的基礎(chǔ)TCP\IP,UDP之類的協(xié)議,還有socket編程。實現(xiàn)兩臺電腦之間的通信是非常簡單的,對于UDP是無連接的傳輸層協(xié)議,不像TCP那樣需要accept和connect什么的需要確保連接。但是UDP又是不可靠的,但是相對來說,我覺得對于即時聊天軟件來說,使用udp還是足夠的。于是我采用了UDP協(xié)議來貫穿我的軟件。當(dāng)然一般的不加修飾的Socket,只能實現(xiàn)同類網(wǎng)絡(luò)地址下的通信,對于一個不同內(nèi)網(wǎng)的計算機(jī),將無法進(jìn)行通信,這樣也大大局限了我們軟件的使用范圍,所以我采用了UDP下的NAT穿透技術(shù)來突破這一障礙,具體理論我們參照這篇文章。
先談?wù)務(wù)w的思想吧,這個即時聊天軟件是以C/S構(gòu)架的,服務(wù)器主要負(fù)責(zé)客戶的信息轉(zhuǎn)發(fā),當(dāng)然只是客戶本身的IP、各種端口(消息監(jiān)聽,文件監(jiān)聽)、用戶名之類的屬性,他不直接參與客戶之間的通訊,只有當(dāng)客戶之間需要nat穿透的時候才會通過服務(wù)器通知需要通信的一方向另一方發(fā)送"打洞"請求,另外還處理客戶之間的登錄和下線事件的廣播,所以服務(wù)器的壓力會比較小。
至于客戶端,我采用了傳統(tǒng)的聊天軟件的慣用方式,一個主對話框,顯示好友信息。出于減小難度,我只采用一個樹控件來控制這些好友信息,而沒有采用tab類型的控件,即使采用也是要花費(fèi)一定的功夫去重寫這些控件類,才能滿足我們的要求。然后通過雙擊樹控件的子項來彈出聊天對話框,說到這里我不得不說一下C++的確是高處C一大籌,(封裝、繼承、多態(tài))這是在是太帥了。創(chuàng)建這些聊天對話框時,將傳入對應(yīng)的客戶IP、對話框指針、用戶名(號碼)等以用來正確識別。主程序運(yùn)行就掛起一個消息監(jiān)聽線程,來循環(huán)監(jiān)聽從不同客戶發(fā)來的消息,然后進(jìn)行不同的處理,所以使用了較多的宏,吧來自不同客戶的消息傳給不同的本地聊天對話框處理,所以剛才說的在創(chuàng)建聊天對話框的時候的參數(shù)就非常重要了,處理不好可能會出現(xiàn)差錯。諸多細(xì)節(jié)在這里還是比較難以細(xì)說。雖然采用了UDP傳輸協(xié)議,但是我通過消息回執(zhí)來確保消息發(fā)送成功,這個回執(zhí)將決定是否進(jìn)行打洞處理。而在文件傳輸功能上的實現(xiàn),采用了TCP傳輸層協(xié)議(我也不知道為什么自己就選擇了這個,估計是但是第一感覺需要accept和connect),我是在主程序運(yùn)行時就掛起一個文件監(jiān)聽線程,當(dāng)然這個監(jiān)聽端口是在程序運(yùn)行是,沒有登錄服務(wù)器之前就首先動態(tài)獲取的,我只是循環(huán)地查找沒有被占用的端口并綁定套接字。在有客戶發(fā)來文件傳送請求時,就創(chuàng)建一個文件接收和發(fā)送線程。感覺以上這些還是比較容易實現(xiàn)的。當(dāng)然采用類的思想才會比較清晰,否則會比較亂。
再講講其他一些小小細(xì)節(jié),比如那個菜單的實現(xiàn),如果采用對話框的默認(rèn)菜單,我們都會覺得比較惡心,的確有點難看,所以我把對話框的菜單欄卻掉了,然后添加了ON_WM_NCHITTEST()消息,實現(xiàn)無菜單的客戶區(qū)拖動,然后重寫個Button類來實現(xiàn)png圖片的裝飾,實現(xiàn)鼠標(biāo)經(jīng)過、懸停和按下的狀態(tài)(就像qq的最小化和關(guān)閉按鈕那樣的效果),當(dāng)然,我使用的是VC6開發(fā)的,不能直接使用GDI+,所以配置了一下才行(具體方法自己網(wǎng)上一查就知道了)。然后那個對話框的主背景,也是通過把一張png圖片繪上去的,當(dāng)然還要解決一些閃爍的問題,可以采用雙緩沖來解決。在做界面的時候,我深感自己缺乏藝術(shù)細(xì)胞,ps技術(shù)實在太爛,做的按鈕圖片比較難看,顏色搭配和漸變效果實在難以控制。而文件實現(xiàn)拖拽發(fā)送也比較簡單,增加個ON_WM_DROPFILES()消息函數(shù),對話框拓展屬性勾上Accept File就好了,剩下的就是處理路徑的問題了,還有多個文件的同時拖拽問題。還有就是那個表情是比較難以處理的一個模塊,當(dāng)時就調(diào)試了我一個星期才解決,為了添加表情功能,我不得不放棄原來使用的EDIT控件(由于以前都只是使用EDIT),使用了RICHEDIT控件,使用該控件還是有很多細(xì)節(jié)要處理的,比如初始化才能使用啊什么的,當(dāng)然為了實現(xiàn)表情的功能,我還是得重新寫RICHEDIT這個類,拓展一下。因為我是使用轉(zhuǎn)義碼來實現(xiàn)的,每一個表情對應(yīng)一個轉(zhuǎn)義碼,就像c語言中\(zhòng)n代表換行一樣。重寫的類中要實現(xiàn),文本的添加和當(dāng)文本改變時要處理一些諸如是否寫入了轉(zhuǎn)義碼,超鏈接等等,至于那個表情布,只是一張小小的銀白色的圖片為底,然后再圖片上分出很多個小小的矩形來容納一個個小小的表情按鈕,很多按鈕吧,沒錯!每個小小的表情都是覆蓋在按鈕上的,同樣要實現(xiàn)鼠標(biāo)經(jīng)過懸停和按下的事件,還得畫一下那個藍(lán)色的邊框?傊@個表情功能的添加,我耗費(fèi)較多的時間了,明白一點:微軟提供的控件都是令我們不夠滿意的,我們得自己重寫這些控件類,也就是繼承他!(記得保存下來以后再用哦)。
講到這里,這個即時聊天軟件的主要思想也介紹差不多了。提幾點軟件開發(fā)的體會,要注意代碼的編寫習(xí)慣,不要寫那么多全局變量和外部變量(不到比不得以的話),注意內(nèi)存的釋放防止泄露,調(diào)試能力很重要(否則很多時候看卡你怎么不知所措)。
【牛人編寫聊天工具的心得】相關(guān)文章:
教材編寫心得體會09-05
編寫童話作文11-19
編寫童話的作文05-12
編寫童話作文02-07
如何規(guī)范編寫教案08-24
關(guān)于編寫童話的作文02-21
咱班的牛人作文01-12
班里的牛人作文02-15
編寫童話故事作文02-04