畢業(yè)設計--點歌管理系統(tǒng)的設計與實現(xiàn)_第1頁
已閱讀1頁,還剩44頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

1、<p>  本科畢業(yè)設計(論文)</p><p>  題目: 小型點歌管理系統(tǒng)的設計與實現(xiàn)</p><p>  院 (系): 計算機科學與工程學院_</p><p>  專 業(yè): 計算機科學與技術 </p><p>  班 級: </p><p>  學

2、 生: </p><p>  學 號: </p><p>  指導教師: </p><p><b>  2013年 6月</b></p><p>  畢業(yè)設計(論文)任務書</p><p>  1.畢

3、業(yè)設計(論文)題目: 點歌管理系統(tǒng) </p><p>  2.題目背景和意義:隨著人民生活水平的提高,娛樂業(yè)在服務行業(yè)中占有越來越重要的地位,能夠在娛樂行業(yè)激勵的競爭中脫穎而出,獨樹一幟已成為每位娛樂經(jīng)營者所追求的目標。其中去KTV唱歌是深受廣大消費者喜愛的娛樂活動。</p><p>  該系統(tǒng)能方便顧客進行

4、選歌。給顧客提供舒適的環(huán)境。吸引顧客來消費,提高營業(yè)而流量。另一方面能幫助系統(tǒng)管理者管理歌曲,提高歌曲點唱的效率。</p><p>  3.設計(論文)的主要內(nèi)容(理工科含技術指標): 本系統(tǒng)前端開發(fā)工具采用目前較流行的VisualC++ 6.0,后臺數(shù)據(jù)庫系統(tǒng)SOL server 2005,該系統(tǒng)的運行平臺是Windows。 本系統(tǒng)總體分為選歌功能,播放操作,管理功能三個部分。選歌功能實現(xiàn)多種方式的點歌;播放

5、操作主要實現(xiàn)對當前播放歌曲的音量,播放模式;管理功能實現(xiàn)對數(shù)據(jù)庫的操作.</p><p>  4.設計的基本要求及進度安排(含起始時間、設計地點):本次課題從2011年2月20日開始,在校內(nèi)完成,具體的進度安排如下: </p><p>  第1~3周:查閱書籍資料,學習相關軟件,準備開題報告。 <

6、/p><p>  第4周: 分析設計任務,設計總體方案。 </p><p>  第5~12周: 模塊設計、完成3000個單詞以上的相關外文資料翻譯;中期總結。 </p><p>  第13~15周: 模塊設計、系統(tǒng)調(diào)試。 </p&g

7、t;<p>  第16~17周: 系統(tǒng)測試、撰寫畢業(yè)論文。 </p><p>  第18周: 對論文排版和打印,制光盤;論文答辯。 </p><p>  5.畢業(yè)設計(論文)的工作量要求</p><p> ?、?實驗(時數(shù))*或實習(天數(shù)): 上

8、機300學時 </p><p> ?、?圖紙(幅面和張數(shù))*: </p><p> ?、?其他要求:

9、 </p><p>  指導教師簽名: 2012年 12月07日</p><p>  學生簽名: 年 月 日</p><p>  系(教研室)主任審批: 年 月 日</p><p>  說明:1

10、本表一式二份,一份由學生裝訂入附件冊,一份教師自留。</p><p>  2 帶*項可根據(jù)學科特點選填。</p><p><b>  摘 要</b></p><p>  隨著人們生活質量的提高,對精神生活的追求日益迫切,各種娛樂活動應運而生酒吧、KTV等娛樂業(yè)在服務行業(yè)中占有越來越重要的地位,點歌系統(tǒng)是為KTV場所開發(fā)的視頻歌曲點唱軟件。該系

11、統(tǒng)能方便顧客進行點歌,給顧客提供舒適的環(huán)境,吸引顧客來消費,提高營業(yè)額流量。另一方面能幫助系統(tǒng)管理員管理歌曲,提高KTV點唱的效率。</p><p>  本系統(tǒng)是模擬KTV開發(fā)一個點歌管理系統(tǒng),前端開發(fā)工具采用VisualC++ 6.0,后臺數(shù)據(jù)庫系統(tǒng)SOL server 2005。 本系統(tǒng)總體分為選歌功能,播放操作,管理功能三個部分。選歌功能實現(xiàn)多種方式的點歌;播放操作主要實現(xiàn)對當前播放歌曲的音量,播放模式;管

12、理功能實現(xiàn)對數(shù)據(jù)庫的操作. </p><p><b>  關鍵詞:</b></p><p><b>  Abstract</b></p><p>  As people life quality improvement and pursuing for the life of the mind is imperative,

13、 all kinds of entertainment arises at the historic moment. Bars, KTV etc recreation in service industry plays a more and more important position, increasingly by put on the agenda. However, we have to our new generation

14、entertainment "dawdler" human-based demand also restrictive, for entertainment for the operator, and can meet the demand of the consumers in the fierce competition, unique and also streamline p</p><p

15、>  This system is simulated KTV develop a song management system. Design guiding ideology is everything for users consider, interface should beautiful and easy, simple operation, and as far as possible as a use of man

16、agement system should have good fault-tolerance in error is, can timely warning, so that users to rectify. In view of this system entertaining, but it needs to be good song interface. These functions of the module is sys

17、tem of main problems to solve. Through the original requirement an</p><p>  Keywords: The KTV sing song system ,video songs point correction ,improvement </p><p><b>  第一章 緒論</b></

18、p><p><b>  1.1 課題背景</b></p><p>  隨著人們生活水平的提高,人們的業(yè)余生活也發(fā)生了巨大的變化,去KTV唱歌便成了很多人在工作之余的娛樂休閑方式。而傳統(tǒng)歌廳中的設施在逐漸地老化,由于LD機器的停產(chǎn)和LD片源全部依賴于進口,成本較高,造出用戶經(jīng)濟上的負擔過重,而且老歌特別多,新歌很少,點歌方式也很原始,速度很慢,而且經(jīng)常出現(xiàn)搶歌現(xiàn)象,這樣就給

19、人們的休閑情緒蒙上了一層陰影。隨著科學的發(fā)展和信息時代的到來,利用高新技術來實現(xiàn)點歌系統(tǒng)娛樂城設備的革命性建設是完全可能的,而且可以滿足消費者的多種需求。本文將使用VC++制作一個KTV點播系統(tǒng)以實現(xiàn)人們對于點歌系統(tǒng)的需求。</p><p><b>  1.2課題研究現(xiàn)狀</b></p><p>  點歌系統(tǒng)從很早以前就開始進行研發(fā)與應用,經(jīng)過多年的經(jīng)驗摸索,不斷地完

20、善改進和升級,使得它更安全、更穩(wěn)定、更完善。無論夜總會型,還是量販式型的KTV都可以使用,該系統(tǒng)加上優(yōu)質的歌庫,并與點歌輔助工具和外圍歌廳設備一起使用時,可稱之為一套功能強大、可靠性高、實用性好、畫優(yōu)音美的點歌系統(tǒng),絕對領導著KTV點歌設備的新潮流。 全套系統(tǒng)是架構在計算機網(wǎng)絡上的,由電腦來管理,極大地提高了經(jīng)營效率。該系統(tǒng)從歌曲錄制編輯、歌曲庫的生成、點歌軟件的功能、界面的多樣性和美觀性、客人的使用人性化、前后臺管理的多樣性和方便性、

21、與各種外圍點歌設備的結合、有各類歌曲的提供等方面,形成了完整的解決方案,是一套集成的全面先進的系統(tǒng)。</p><p>  第二章 系統(tǒng)開發(fā)環(huán)境及相關技術</p><p><b>  2.1系統(tǒng)開發(fā)環(huán)境</b></p><p>  本系統(tǒng)主要應用了ADO數(shù)據(jù)庫連接,ADO對象操作數(shù)據(jù)庫的技術,開發(fā)此點歌管系統(tǒng) 所需用到的軟件環(huán)境如下:</p

22、><p>  1.操作系統(tǒng):Windows XP</p><p>  2..數(shù)據(jù)庫:SQL Server 2005。SQL Server 2005不僅為不同規(guī)模的企業(yè)提供快速構建各類商業(yè)只能解決方案,還具有較好系統(tǒng)的集成性及對日常任務的自動化管理能力。鑒于以上優(yōu)點,選擇SQL Server 2005作為數(shù)據(jù)庫管理系統(tǒng)。</p><p>  3.編譯工具:Visual C

23、++6.0編譯速度快,程序調(diào)試方便。它引入MFC類和一些實用開發(fā)工具,降低了編碼的復雜性,便于快速開發(fā)出點歌管理系統(tǒng)。</p><p>  2.1 ADO技術簡介</p><p>  ADO(active data object,活動數(shù)據(jù)對象)實際上是一種基于COM(組件對象模型)的自動化接口技術,并以OLE DB(對象連接和鑲入的數(shù)據(jù)庫)為基礎,經(jīng)過OLE DB精心包裝后的數(shù)據(jù)庫訪問技術

24、,利用它可以快速的創(chuàng)建數(shù)據(jù)庫應用程序。ADO提供了一組非常簡單,將一般通用的數(shù)據(jù)訪問細節(jié)進行封裝的對象。由于ODBC數(shù)據(jù)源也提供了一般的OLE DB Privider,所以ADO不僅可以應用自身的OLE DB Privider,而且還可以應用所有的ODBC驅動程序。</p><p>  2.1.1用ADO訪問數(shù)據(jù)元的特點</p><p>  1.易于使用,可以說這是ADO最重要的特點之一。

25、 2.ADO 是高層數(shù)據(jù)庫訪問技術,相對與ODBC來說,具有面性對象的特點。同時,在 ADO 對象結構中,對象與對象之間的層次結構不適非常明顯,比如,在應用程序中如果要使用記錄集對象,不一定要先建立連接、會話對象,如果需要就可以直接構造記錄集對象??偸?,已經(jīng)沒有必要去關心對象的構造層次和構造順序了。 3.可以訪問多種數(shù)據(jù)源。和 OLE DB 一樣,使應用程序具有很好的通用性和靈活性。 4.訪問數(shù)據(jù)源效率高。 5.

26、方便的Web應用。ADO 可以以 ActiveX 控件的形式出現(xiàn),這就大大方便了Web應用程序的編制。 6.技術編程接口豐富。 ADO 支持 Visual C++、Visual Basic、VBS、JS等。</p><p>  2.1.2 ADO 的對象● Connection 用于表示和數(shù)據(jù)源的連接,以及處理一些命令和事務?!?Command 用于執(zhí)行某些命令來進行諸如查詢、修改數(shù)據(jù)庫結構

27、的操作?!?Recordset 用于處理數(shù)據(jù)源的表格集,它是在表中修改、檢索數(shù)據(jù)的最主 要的方法?!?Field 描述數(shù)據(jù)集中的列信息?!?Parameter 用于對傳遞給數(shù)據(jù)源的命令賦參數(shù)值?!?Error 用于承載所產(chǎn)生所無的詳細信息。● Property 通過屬性,每個ADO對象借此來讓用戶描述和控制自身的行為?!?Set 集合是一種

28、可以方便的包含其他特殊類型對象的對象類型。 ADO 提供4種類型的集合:● Connection 對象具有Error集合?!?Command 對象具有Parameter集合?!?Recordset 對象具有Fields集合?!?Connection、 Command、Recordset、Field 對象都具有Pro</p><p>  2.1.3在V

29、isual C++中使用 ADO</p><p><b>  基本流程</b></p><p>  (1)初始化COM庫,引入ADO庫定義文件 (2)用Connection對象連接數(shù)據(jù)庫 (3)利用建立好的連接,通過Connection、Command對象執(zhí)行SQL命令,或利用Recordset對象取得結果記錄集進行查詢、處理。 (4)使用完畢

30、后關閉連接釋放對象。 </p><p>  2.1.4 ADO常用的數(shù)據(jù)庫連接方法:</p><p>  (1)通過JET數(shù)據(jù)庫引擎對ACCESS2000數(shù)據(jù)庫的連接m_pConnection->Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\\test.mdb","",&qu

31、ot;",adModeUnknown);(2)通過DSN數(shù)據(jù)源對任何支持ODBC的數(shù)據(jù)庫進行連接:m_pConnection->Open("Data Source=adotest;UID=sa;PWD=;","","",adModeUnknown);//m_pConnection->Open("DSN=test;","

32、;","",0); //連接叫作test的ODBC數(shù)據(jù)源(3)不通過DSN對SQL SERVER數(shù)據(jù)庫進行連接:m_pConnection->Open("driver={SQL Server};Server=127.0.0.1;DATABASE=vckbase;UID=sa;PWD=139","","",adModeUn

33、known);其中Server是SQL服務器的名稱,DATABASE是庫的名稱</p><p>  2.1.5 ADO接口簡介 ADO庫包含三個基本接口:_ConnectionPtr接口、_CommandPtr接口和_RecordsetPtr接口。</p><p>  _ConnectionPtr接口返回一個記錄集或一個空指針。通常使用它來創(chuàng)建一個數(shù)據(jù)連接或執(zhí)行一條不返回任

34、何結果的SQL語句,如一個存儲過程。使用_ConnectionPtr接口返回一個記錄集不是一個好的使用方法。對于要返回記錄的操作通常用_RecordserPtr來實現(xiàn)。用_ConnectionPtr操作時要想得到記錄條數(shù)得遍歷所有記錄,而用_RecordserPtr時不需要。_CommandPtr接口返回一個記錄集。它提供了一種簡單的方法來執(zhí)行返回記錄集的存儲過程和SQL語句。在使用_CommandPtr接口時,你可以利用全

35、局_ConnectionPtr接口,也可以在_CommandPtr接口里直接使用連接串。如果你只執(zhí)行一次或幾次數(shù)據(jù)訪問操作,后者是比較好的選擇。但如果你要頻繁訪問數(shù)據(jù)庫,并要返回很多記錄集,那么,你應該使用全局_ConnectionPtr接口創(chuàng)建一個數(shù)據(jù)連接,然后使用_CommandPtr接口執(zhí)行存儲過程和SQL語句。_RecordsetPtr是一個記錄集對象。與以上兩種對象相比,它對記錄集提供了更多的控制功能,如記錄鎖定,游

36、標控制等。</p><p>  2.2 SQL Server 2005簡介</p><p>  SQL Server 2005 是一個全面的數(shù)據(jù)庫平臺,使用集成的商業(yè)智能 (BI) 工具提供了企業(yè)級的數(shù)據(jù)管理。SQL Server 2005 數(shù)據(jù)庫引擎為關系型數(shù)據(jù)和結構化數(shù)據(jù)提供了更安全可靠的存儲功能,使您可以構建和管理用于業(yè)務的高可用和高性能的數(shù)據(jù)應用程序?! QL Server

37、2005 數(shù)據(jù)引擎是本企業(yè)數(shù)據(jù)管理解決方案的核心。此外 SQL Server 2005 結合了分析、報表、集成和通知功能。這使您的企業(yè)可以構建和部署經(jīng)濟有效的 BI 解決方案,幫助您的團隊通過記分卡、Dashboard、Web services 和移動設備將數(shù)據(jù)應用推向業(yè)務的各個領域?! ∨c Microsoft Visual Studio、Microsoft Office System 以及新的開發(fā)工具包(包括 Business In

38、telligence Development Studio)的緊密集成使 SQL Server 2005 與眾不同。無論您是開發(fā)人員、數(shù)據(jù)庫管理員、信息工作者還是決策者,SQL Server 2005 都可以為您提供創(chuàng)新的解決方案,幫助您從數(shù)據(jù)中更多地獲益。  M</p><p>  2.3 C/S模式結構簡介</p><p>  C/S 結構,即大家熟知的客戶機和服務器結構。它是軟件

39、系統(tǒng)體系結構,通過它可以充分利用兩端硬件環(huán)境的優(yōu)勢,將任務合理分配到Client端和Server端來實現(xiàn),降低了系統(tǒng)的通訊開銷。目前大多數(shù)應用軟件系統(tǒng)都是Client/Server形式的兩層結構,由于現(xiàn)在的軟件應用系統(tǒng)正在向分布式的Web應用發(fā)展,Web和Client/Server 應用都可以進行同樣的業(yè)務處理,應用不同的模塊共享邏輯組件;因此,內(nèi)部的和外部的用戶都可以訪問新的和現(xiàn)有的應用系統(tǒng),通過現(xiàn)有應用系統(tǒng)中的邏輯可以擴展出新的應用

40、系統(tǒng)。這也就是目前應用系統(tǒng)的發(fā)展方向。</p><p>  C/S 結構的基本原則是將計算機應用任務分解成多個子任務,由多臺計算機分工完成,即采用“功能分布”原則??蛻舳送瓿蓴?shù)據(jù)處理,數(shù)據(jù)表示以及用戶接口功能;服務器端完成DBMS的核心功能。這種客戶請求服務、服務器提供服務的處理方式是一種新型的計算機應用模式。</p><p>  2.4 Visual C++6.0\MFC簡介</p

41、><p>  vc++是Windows平臺上的C++編程環(huán)境,學習VC要了解很多Windows平臺的特性并且還要掌握MFC、ATL、COM等的知識,難度比較大。Windows下編程需要了解Windows的消息機制以及回調(diào)(callback)函數(shù)的原理;MFC是Win32API的包裝類,需要理解文檔視圖類的結構,窗口類的結構,消息流向等等;COM是代碼共享的二進制標準,需要掌握其基本原理等等。</p>&

42、lt;p>  VC作為一個主流的開發(fā)平臺一直深受編程愛好者的喜愛,但是很多人卻對它的入門感到難于上青天,究其原因主要是大家對他錯誤的認識造成的,嚴格的來說 VC++不是門語言,雖然它和C++之間有密切的關系,如果形象點比喻的話,可以C++看作為一種”工業(yè)標準”,而VC++則是某種操作系統(tǒng)平臺下的”廠商標準”,而”廠商標準”是在遵循”工業(yè)標準”的前提下擴展而來的。</p><p>  VC++應用程序的開發(fā)主

43、要有兩種模式,一種是WIN API方式,另一種則是MFC方式,傳統(tǒng)的WIN API開發(fā)方式比較繁瑣,而MFC則是對WIN API再次封裝,所以MFC相對于WIN API開發(fā)更具備效率優(yōu)勢。</p><p>  MFC借助C++的優(yōu)勢為Windows開發(fā)開辟了一片新天地,同時也借助ApplicationWizzard使開發(fā)者擺脫離了那些每次都必寫基本代碼,借助ClassWizard和消息映射使開發(fā)者擺脫了定義消息處

44、理時那種混亂和冗長的代碼段。更令人興奮的是利用C++的封裝功能使開發(fā)者擺脫Windows中各種句柄的困擾,只需要面對C++中的對象,這樣一來使開發(fā)更接近開發(fā)語言而遠離系統(tǒng)。(但我個人認為了解系統(tǒng)原理對開發(fā)很有幫助) </p><p>  正因為MFC是建立在C++的基礎上,所以我強調(diào)C/C++語言基礎對開發(fā)的重要性。利用C++的封裝性開發(fā)者可以更容易理解和操作各種窗口對象;利用C++的派生性開發(fā)者可以減少開發(fā)自定

45、義窗口的時間和創(chuàng)造出可重用的代碼;利用虛擬性可以在必要時更好的控制窗口的活動。而且C++本身所具備的超越C語言的特性都可以使開發(fā)者編寫出更易用,更靈活的代碼。 </p><p>  在MFC中對消息的處理利用了消息映射的方法,該方法的基礎是宏定義實現(xiàn),通過宏定義將消息分派到不同的成員函數(shù)進行處理。</p><p><b>  系統(tǒng)分析</b></p>&

46、lt;p><b>  3.1可行性分析</b></p><p>  可行性分析是對項目的可行程度進行分析,以便管理層對技術及資金的投入進行決策。其主要包括技術可行性,經(jīng)濟可行性,操作可行性,營運可行性等。通過對需求分析的研究,對本項目做如下的可行性分析。 </p><p>  3.1.1技術可行性</p><p>  技術方面的可行性就是

47、根據(jù)現(xiàn)有的技術條件,能否實現(xiàn)系統(tǒng)的各項要求。設備上,該系統(tǒng)對所需的硬件設備,如服務器、PC機等的性能要求一般,現(xiàn)有設備的性能完全能夠滿足系統(tǒng)功能的要求;軟件上,本系統(tǒng)屬于數(shù)據(jù)庫應用程序,本系統(tǒng)需要一個數(shù)據(jù)庫服務器及其運行的操作系統(tǒng)平臺,根據(jù)客戶的數(shù)據(jù)量并不是十分巨大,選擇SQL Server 2005作為數(shù)據(jù)庫可以滿足系統(tǒng)對數(shù)據(jù)庫的要求,安全性好,效率高。這些軟件在中小型MIS開發(fā)中已被大量應用,技術上都比較成熟,因此技術上是可行的。&

48、lt;/p><p>  3.1.2經(jīng)濟可行性</p><p>  從項目提出者的發(fā)面來說,根據(jù)實際的需求,開發(fā)本系統(tǒng),不但可以提高公司的管理水平,也可以提高消費者的點歌效率,為消費者提供便利,舒適的環(huán)境,增加顧客的流量,給公司帶來潛在的利潤,所以從經(jīng)濟上來說是完全可行的。另一方面,對該系統(tǒng)的開發(fā)既能增加項目開發(fā)公司的技術儲備,又能提高對同類項目開發(fā)的熟練程度。</p><p

49、>  3.1.3操作可行性</p><p>  本系統(tǒng)采用Windows圖形界面,是大家的熟悉的操作系統(tǒng),對于用戶,只需要具有一般計算機知識的人員都可以輕松上手。而且整個系統(tǒng)采用最友好的交互界面,簡潔明了,不需要對數(shù)據(jù)庫非常了解也可以熟練操作。再有就是操作上以后可以加載到觸屏的終端上,這樣就更可以使得操作更加的友好。</p><p><b>  3.2需求分析</b&

50、gt;</p><p><b>  3.2.1 </b></p><p>  小型點歌管理系統(tǒng)就是針對點歌用戶開發(fā)而成,本系統(tǒng)的宗旨是使KTV的歌曲管理工作更加科學、合理的規(guī)劃,系統(tǒng)、高效的實施。在用戶操作部分能實現(xiàn)根據(jù)歌手的地區(qū),性別,歌手的拼音,歌曲的名字數(shù),歌曲類別查詢;可以查看或者編輯播放列表,也可以刪除單首歌曲;還可以根據(jù)自己的喜好選擇播放模式。管理員也可以

51、對歌庫進行管理操作,并且實現(xiàn)用戶的結賬付費功能。此系統(tǒng)可以方便快捷的管理這些瑣碎的數(shù)據(jù)和瑣碎的事務,使點歌質量得到有效的保障。</p><p>  點歌系統(tǒng)的用戶主要分為:消費者.管理員以及系統(tǒng)維護人員。各用戶具體操作時實現(xiàn)的功能如下表所示:</p><p>  表 1-1 用戶一覽表</p><p>  3.2.2系統(tǒng)功能需求</p><p&g

52、t;  系統(tǒng)主要分為服務器端和客戶端。通過管理人員對服務器端的控制,管理點歌系統(tǒng)歌曲數(shù)據(jù)庫并且同時實現(xiàn)給用戶開包廂,查看包廂使用時間等功能;啟動服務器端程序后,客戶端可進行即點即播(即零等待)的點歌操作,并且多個客戶端可同時點播同一首歌曲。</p><p>  1.系統(tǒng)客戶端的主要功能</p><p>  系統(tǒng)客戶端的主要功能是:用戶可以根據(jù)個人愛好通過包房電腦及該軟件查詢(包括歌星查詢、

53、拼音查詢、字母查詢、組合查詢等查詢方式)所需要的歌曲,了解歌星的簡介、播放歌曲、控制歌曲、等,同時,系統(tǒng)的功能區(qū)與顯示信息區(qū)分開,使用戶在使用上更簡便,系統(tǒng)功能上更強大。點歌系統(tǒng)對于客戶端的主要需求功能有播放,暫停,點歌,控制音量等,各部分的功能描述如下圖所示:</p><p>  2-1 客戶端需求規(guī)定</p><p>  2.服務器端的主要功能</p><p>

54、;  通過管理員進行系統(tǒng)歌庫中的歌曲管理,如添加、編輯、刪除等。并且根據(jù)系統(tǒng)所能提供的服務內(nèi)容供消費者使用。當該請求有效時需要中央服務器系統(tǒng)進行響應,其服務內(nèi)容可根據(jù)消費者的需求進行設定。</p><p>  系統(tǒng)服務器端的主要需求功能是歌曲的添加和刪除等。各部分功能的具體描述如下圖所示:</p><p>  表2-2 服務器功端需求規(guī)定</p><p>  3.3

55、 系統(tǒng)業(yè)務流程</p><p>  本套KTV點歌系統(tǒng)軟件的編寫,是為了設計出一套C/S模式的KTV場所需求的應用和管理軟件。軟件分為三大部分,點歌部分,數(shù)據(jù)管理部分和服務器處理部分。</p><p>  點歌部分(客戶端)是以桌面軟件的形式實現(xiàn),用戶通過與軟件的交互,對數(shù)據(jù)庫中的音樂進行查詢,并對自己喜歡的歌曲進行點播。消費者實現(xiàn)的點歌功能基本包括歌曲的增加,刪除以及查找等功能。其基本的

56、用例圖如下圖所示:</p><p>  在管理部分中,管理員可以對數(shù)據(jù)庫中的音樂數(shù)據(jù)進行增加、修改、刪除和查詢等操作,從而對數(shù)據(jù)庫中的音樂數(shù)據(jù)進行管理。服務器處理部分(服務器端)則是可視化的操作處理軟件,對點歌客戶端和管理客戶端的請求進行響應,執(zhí)行相應的查詢數(shù)據(jù)庫操作,并向客戶端返回所需的數(shù)據(jù)。管理員的具體的用例圖如下圖所示:</p><p><b>  系統(tǒng)的總體設計</

57、b></p><p>  4.1系統(tǒng)基本模塊設計</p><p>  本系統(tǒng)總體分為選歌功能,播放操作,管理功能3個部分。選歌功能實現(xiàn)多種方式點歌;播放操作主要實現(xiàn)對當前播放歌曲的音量,播放模式,快進,快退等操作;而管理功能實現(xiàn)對數(shù)據(jù)庫的操作和收費操作等,系統(tǒng)整體模塊結構圖如下:</p><p>  各模塊的具體功能如下:</p><p&g

58、t;<b>  播放操作</b></p><p>  1.上\下一首歌:下移或者上移改變當前歌曲。</p><p>  2.增\減音量:實現(xiàn)對播放音量的控制。</p><p>  3.快\慢進:實現(xiàn)改變播放速度</p><p>  4.暫停,停止:實現(xiàn)對播放的控制</p><p>  5.播放模式

59、:有單曲循環(huán),單曲播放,順序播放,列表循環(huán)4種播放模式供選擇</p><p><b>  選歌功能</b></p><p>  1.播放點歌列表:將已點播的的歌曲顯示在主界面上</p><p>  2.刪除歌曲列表:可以刪除已點歌曲,分單手刪除和全部刪除</p><p>  3.按歌手點歌:根據(jù)歌手來自的地區(qū)查看,分為港

60、臺歌手,大陸歌手,外國歌手</p><p>  4.按拼音查詢:根據(jù)用戶輸入的拼音,對歌手姓名進行模糊查詢,顯示匹配的歌手</p><p>  5.按性別查詢:根據(jù)歌手的性別查詢,分為男歌手,女歌手,組合</p><p>  6.按歌曲類別查詢:根據(jù)歌曲類別查詢,分為流行歌曲,通俗歌曲,外國歌曲,世界名曲</p><p>  7.按歌曲名字數(shù)

61、查詢:根據(jù)用戶輸入的數(shù)字,對歌曲名字數(shù)查詢,顯示匹配的歌曲</p><p><b>  管理功能</b></p><p>  1.管理員登陸:先登錄后進行管理員操作,給消費者點歌</p><p>  2.開戶點歌:有管理員登陸后,設置房間類型和會員卡類型交預付金等</p><p>  3.添加歌曲:輸入歌曲信息,把歌曲文

62、件放入相應路徑。</p><p>  4.刪除歌曲:根據(jù)各區(qū)分為按歌手名拼音刪除和按歌曲名字數(shù)刪除</p><p>  5.消費金額:根據(jù)歌唱時間,包廂類型和用戶身份情況計算消費金額</p><p>  4.2系統(tǒng)功能模塊流程圖</p><p>  點歌管理系統(tǒng)主要由選歌模塊,管理模塊以及播放操作。選歌模塊和管理模塊主要實現(xiàn)的是對歌曲的查詢功

63、能,播放模塊主要是對歌曲信息的調(diào)取以及歌曲的播放功能。</p><p>  4.2.1主界面流程圖 </p><p>  當用戶進入主界面后將面對對歌曲的查詢與管理操作,具體內(nèi)容如下圖所示:</p><p>  當管理員進入系統(tǒng)后主要是實現(xiàn)歌曲數(shù)據(jù)的修改查詢等功能。具體職能如下圖所示</p><p>  4.2.2播放控制模塊</p&g

64、t;<p>  播放模塊主要是用戶通過控制界面實現(xiàn)所點歌曲的播放,其中用戶與控制界面的交互圖如下:</p><p>  4.2.3點歌管理模塊</p><p>  點歌系統(tǒng)對于歌曲的管理主要包括歌曲的刪除以及上移下移操作。用戶與客戶端的交互圖如下圖所示:</p><p>  4.2.4服務器處理模塊</p><p>  服務器系

65、統(tǒng)包括管理歌曲庫,相應的點歌系統(tǒng)模塊。分別負責數(shù)據(jù)庫的更新,與客戶端數(shù)據(jù)進行交互。相應的圖如下: </p><p>  4.2.5 各模塊之間的交互圖</p><p>  點歌管理系統(tǒng)的各模塊之間的交互圖如下圖所示:</p><p>  第五章:數(shù)據(jù)庫的設計</p><p>  進行管理系統(tǒng)的設計首先要考慮好如何實現(xiàn)數(shù)據(jù)庫的設計。數(shù)據(jù)庫作為整

66、個系統(tǒng)的基礎,要保證其設計的合理性,其中數(shù)據(jù)表要滿足規(guī)范化要求。在使用應用系統(tǒng)時,擁有合理的數(shù)據(jù)庫往往起到事半功倍的效果。</p><p><b>  5.1數(shù)據(jù)庫分析</b></p><p>  點歌管理系統(tǒng)架構采用C\S模式來實現(xiàn),在某一時刻可能有多個查詢操作進行。而且操作比較頻繁。因此對數(shù)據(jù)庫的并發(fā)性,安全性,共享性等性能要求較高,故采用SQL SERVER 2

67、005作為系統(tǒng)開發(fā)的數(shù)據(jù)庫管理系統(tǒng)。數(shù)據(jù)庫處理的的主要對象=是歌曲,而歌曲的類型,歌曲的歌手,歌手的性別等這些屬性也是需要考慮的操作對象。對歌曲的播放操作也要能滿足普通的消費者的需求。</p><p>  5.2數(shù)據(jù)庫管理系統(tǒng)E-R圖</p><p>  根據(jù)分析設計的結果,該系統(tǒng)包含的實體有:管理員,用戶,歌曲,歌手等。下面將分別介紹各實體及實體間的E-R圖。</p>&l

68、t;p> ?。?)管理員實體可以實現(xiàn)歌曲的管理功能,如:刪除歌舞,增加歌曲等。管理員實體E-R圖</p><p>  通過歌曲實體可以獲取歌曲的基本信息,如:歌曲的歌手名,歌名以及歌曲類型等。歌曲實體E-R圖</p><p>  歌手實體能夠提供歌手的基本信息,如:歌手的姓名,歌手的地區(qū)等等。歌手-實體E-R圖</p><p> ?。?)用戶實體可以提供用戶當

69、前的消費狀況以及他們所處的房間類型和剩余金額等。用戶實體E-R圖</p><p>  (5)各實體之間緊密相連,例如:消費者與管理員的聯(lián)系,消費者與歌曲的聯(lián)系,管理員與歌曲的聯(lián)系。具體相關的E-R圖如下圖所示</p><p>  5.3數(shù)據(jù)庫邏輯設計</p><p>  根據(jù)以上的數(shù)據(jù)庫分析,本系統(tǒng)數(shù)據(jù)庫命名為MUSIC,數(shù)據(jù)庫中包含5個表:admin表,singe

70、r表,musiclist表,abate表,room表。</p><p>  admin表:用于保存管理員信息。它的主鍵是管理員名稱.</p><p>  (2)singer表:用于保存歌手信息,主鍵是歌手編號。</p><p>  (3)musiclist表:用于歌曲信息的存儲,主鍵是歌曲編號,外鍵是歌手編號</p><p>  (4)use

71、rtemp表:用于保存用戶點歌歌曲信息,設置歌曲編號為主鍵,歌手編號為外鍵,對歌曲存儲途徑進行唯一性約束。</p><p>  (5)playlist表:用來記錄當前播放列表信息,設置歌曲編號為主鍵,歌曲編號為外鍵,對歌曲存儲途徑進行唯一性約束。</p><p>  (6)abate表:用來記錄會員的等級以及相應的會員折扣,主鍵是會員編號,</p><p>  ro

72、om表:用來記錄房間類型以及對應價格,主鍵是包間類型,外鍵是會員編號。</p><p>  5.4數(shù)據(jù)庫的具體實現(xiàn)</p><p>  點歌管理系統(tǒng)需要實現(xiàn)與服務器端的連接從而獲取并修改服務器端的信息,主要實現(xiàn)該功能的代碼如下:</p><p>  ConnectionPtr m_pConnection;</p><p><b> 

73、 try</b></p><p><b>  {</b></p><p>  HRESULT hr = m_pConnection.CreateInstance("ADODB.Connection");</p><p>  //創(chuàng)建Connection對象</p><p>  if(SUC

74、CEEDED(hr))</p><p><b>  { </b></p><p>  hr = m_pConnection->Open("driver={SQLServer};</p><p>  Server=YSS-59EA0D478A8;DATABASE=master;","","

75、",adModeUnknown);//2005及以上版本</p><p>  //hr = pConnection->Open("driver={SQL Server};Server=HC\\MSSQL2008;DATABASE=master; UID=sa; PWD=", "","",adModeUnknown);</p>

76、<p><b>  }</b></p><p><b>  }</b></p><p>  catch (_com_error e) //COM錯誤取得,當執(zhí)行COM功能的時候,如果出錯,可以捕捉到_com_error的異常</p><p><b>  { </b></p>

77、<p>  CString strComError;</p><p>  strComError.Format("錯誤編號: %08lx\n錯誤信息: %s\n錯誤源: %s\n錯誤描述: %s",</p><p>  e.Error(), // 錯誤編號</p><p>  e.ErrorMessage

78、(), // 錯誤信息</p><p>  (LPCSTR) e.Source(), // 錯誤源</p><p>  (LPCSTR) e.Description()); // 錯誤描述 ::MessageBox(NULL,strComError,"錯誤",MB_ICONEXCLAMATION);</p><p&

79、gt;<b>  }</b></p><p>  第六章 系統(tǒng)詳細設計</p><p>  根據(jù)系統(tǒng)的需求和功能能分析,本系統(tǒng)采用界面較為實用的基于對話框風格模式布局。前端開發(fā)采用Visual C++ 6.0,后臺數(shù)據(jù)庫系統(tǒng)采用大型數(shù)據(jù)庫系統(tǒng)SQL sever,系統(tǒng)的運行平臺為Windows。</p><p>  6.1系統(tǒng)主界面的實現(xiàn)<

80、/p><p>  系統(tǒng)框架采用基于對話框風格,可在該界面上實現(xiàn)所有操作功能。本系統(tǒng)操作對象主要是歌曲,所有需要插入的視頻或者音頻播放控件,通過各種點歌方式,最終的操作結果將采用列表控件顯示播放列表。這種顯示方式對進一步實現(xiàn)對歌曲的播放控制有利。播放控制不僅包括常見的快進,快退,前一首,后一首,還包括單曲循環(huán),單曲播放,循環(huán)播放等播放模式的切換。另外管理員對數(shù)據(jù)庫和系統(tǒng)的管理功能也通過主界面來實現(xiàn)。</p>

81、<p>  系統(tǒng)主界面分成4個區(qū)域:左上區(qū)是播放窗口區(qū)域,可以實現(xiàn)對視頻、音頻文件的播放;右邊是選歌和系統(tǒng)管理功能模塊操作區(qū),可以通過各種方式選歌,可以對系統(tǒng)進行設置;右下區(qū)是播放控制區(qū)域,實現(xiàn)對播放音量、播放速度、播放模式等的控制,初始界面效果如圖所示:</p><p>  圖6.1初始界面效果圖</p><p>  初始界面上許多初始按鈕都不能使用。通過管理員幫助消費者完

82、成開戶點歌設置,如圖:</p><p>  圖6.2 用戶點歌對話框</p><p>  設置成功后的點歌界面,各功能按鈕都可以使用了,界面效果如圖所示:</p><p>  圖6.3 消費者點歌對話框</p><p>  6.2 歌曲選擇模塊設計</p><p>  歌曲選擇模塊是本系統(tǒng)最重要的功能模塊。該模塊設計

83、的完善與否對整個系統(tǒng)起著至關重要的作用。本系統(tǒng)中主要精力都放在結合實際使用情況來逐步完善該模塊的功能。用戶通過管理員幫助開戶進入點歌模式。結合需求,歌曲選擇模塊應實現(xiàn)功能為:按歌手地區(qū)、按拼音查詢、按歌手性別查詢、按歌曲名字數(shù)查詢等方式點歌。</p><p>  開發(fā)該模塊具體功能前,首先要完成其界面的設計。本模塊歌曲選擇方式較多,故設計界面也較多,除了設計管理員開戶界面外,其他各點歌界面布局基本相同。按照顯示效

84、果開發(fā)好界面。這些界面設計方法基本類似,都是采用兩個列表自動關聯(lián)實現(xiàn)歌曲的選取。歌曲的查找通過組合框中不同的條件來構造對應的SQL語句,然后執(zhí)行查找并在列表框中顯示,最終再通過獲取主窗口指針動態(tài)更新播放列表,完成點歌過程。點歌前需要管理員用戶登錄后,通過開戶模塊設置好點歌房間以方便結賬計費的實現(xiàn)。</p><p>  (1)按歌手查詢的實現(xiàn)</p><p>  在點歌模式界面上單擊【按歌手

85、查詢】按鈕,顯示按歌手查詢界面。該界面初始顯示所有的大陸男歌手,通過切換歌手類型,在列表控件動態(tài)顯示相關歌手。選中一個歌手雙擊后,會在原列表框中顯示該歌手的所有歌曲。雙擊任一歌曲,會把該歌曲添加到主界面播放列表中。用戶可以通過【返回上一級菜單】按鈕切換到歌手界面繼續(xù)選歌。</p><p>  該界面的初始化部分主要實現(xiàn)組合框的數(shù)據(jù)添加并設置初始值,而且在列表中要顯示歌手類別組合框中默認類別的所有歌手的信息。如圖:

86、</p><p>  圖6.4 根據(jù)歌手查詢對話框</p><p>  圖6.5 選擇歌曲到播放列表</p><p>  (2)按拼音查詢的實現(xiàn)</p><p>  在點歌模式界面上單擊【按拼音查詢】按鈕,顯示該查詢界面,界面初始顯示所有的歌手,通過在編輯框中輸入歌手姓名拼音,列表控件中動態(tài)顯示相關歌手。雙擊任一歌曲,會把該歌曲添加到主界面

87、播放列表中。用戶可以通過【返回上一級菜單】按鈕切換到歌手界面繼續(xù)選歌。</p><p>  該界面的初始化部分主要實現(xiàn)組合框的數(shù)據(jù)添加并設置初始值,而且在列表中要顯示所有歌手的信息。</p><p>  該模塊也分為歌曲添加、顯示歌手、顯示歌曲三個子模塊,且功能與按歌手查詢類似。如圖6.6:</p><p>  圖6.6根據(jù)拼音查詢對話框</p>&l

88、t;p>  (3)按字數(shù)查詢的實現(xiàn):</p><p>  在點歌模式界面上單擊【按歌曲名字數(shù)查詢】按鈕,顯示對應查詢界面。該界面初始顯示歌曲名字數(shù)為1的歌曲信息,通過切換歌曲名字數(shù)組合框,列表控件中動態(tài)顯示對應字數(shù)的歌曲。雙擊任一歌曲,會把該歌曲添加到主界面播放列表中[22]。</p><p>  該界面的初始化部分主要實現(xiàn)組合框的數(shù)據(jù)添加并設置初始值,而且在列表控件中要顯示歌曲字數(shù)

89、為1的所有歌曲信息。</p><p>  圖6.8 根據(jù)字數(shù)查詢對話框</p><p>  以上各種查詢服務是很重要的,因為客戶他們查詢的方式是不一樣的,所以我們都要設計很多查詢模式,讓客戶更好的選擇,讓他們更好的享受服務,享受服務。實現(xiàn)本模塊功能的主要代碼如下:</p><p>  void CHCOKDlg::OnSinfind() </p>&l

90、t;p><b>  {</b></p><p>  //如果指針為NULL,則說明窗體還沒創(chuàng)建,那么動態(tài)創(chuàng)建</p><p>  if(bysingerdlg == NULL)</p><p>  { // 動態(tài)創(chuàng)建對話框對象</p><p>  bysingerdlg = new BYSGRDLG;</

91、p><p>  bysingerdlg->Create(IDD_BYSINGER,NULL);</p><p><b>  }</b></p><p>  bysingerdlg->ShowWindow(SW_SHOW);</p><p><b>  }</b></p><

92、;p>  //********************按歌手拼音查詢****************************************//</p><p>  void CHCOKDlg::OnPyfind() </p><p><b>  {</b></p><p>  //如果指針為NULL,則說明窗體還沒創(chuàng)建,那么動態(tài)

93、創(chuàng)建</p><p>  if(bypinyindlg == NULL)</p><p>  { // 動態(tài)創(chuàng)建對話框對象</p><p>  bypinyindlg = new BYPINYINDLG;</p><p>  bypinyindlg->Create(IDD_BYPINYIN,NULL);</p><

94、;p><b>  }</b></p><p>  bypinyindlg->ShowWindow(SW_SHOW);</p><p><b>  }</b></p><p>  //********************按歌曲名字數(shù)查詢*************************************

95、***//</p><p>  void CHCOKDlg::OnNufind() </p><p><b>  {</b></p><p>  //如果指針為NULL,則說明窗體還沒創(chuàng)建,那么動態(tài)創(chuàng)建</p><p>  if(bynumdlg == NULL)</p><p>  { //

96、動態(tài)創(chuàng)建對話框對象</p><p>  bynumdlg = new BYZISHUDLG;</p><p>  bynumdlg->Create(IDD_BYZISHU,NULL);</p><p><b>  }</b></p><p>  bynumdlg->ShowWindow(SW_SHOW);&

97、lt;/p><p><b>  }</b></p><p>  //********************按歌曲類別查詢****************************************//</p><p>  void CHCOKDlg::OnTfind() </p><p><b>  {<

98、;/b></p><p>  //BYSONGTYPDLG bysongtypedlg;</p><p>  //bysongtypedlg.DoModal ();</p><p>  //如果指針為NULL,則說明窗體還沒創(chuàng)建,那么動態(tài)創(chuàng)建</p><p>  if(bysongtypedlg == NULL)</p>

99、<p>  { // 動態(tài)創(chuàng)建對話框對象</p><p>  bysongtypedlg = new BYSONGTYPDLG;</p><p>  bysongtypedlg->Create(IDD_BYSONGTYP,NULL);</p><p><b>  }</b></p><p>  by

100、songtypedlg->ShowWindow(SW_SHOW);</p><p><b>  }</b></p><p>  void CHCOKDlg::ShowListDate() /////////////////////////在在播放列表里顯示歌曲</p><p><b>  {</b></p>

101、;<p>  CString songid, songname, singername, songtype, filename,fileformat;</p><p>  m_list.DeleteAllItems();//刪除所有</p><p>  ADOConn m_AdoConn; //定義數(shù)據(jù)庫操作對象</p><p>  m

102、_AdoConn.OnInitADOConn(); //鏈接數(shù)據(jù)庫</p><p>  _bstr_t sql;</p><p>  _RecordsetPtr m_pRecordset;</p><p>  sql = "select*from playlist "; //查詢 playlist表</p><p&g

103、t;  m_pRecordset=m_AdoConn.GetRecordSet(sql); //得到記錄集</p><p>  if(m_pRecordset->adoEOF) //如果沒有歌曲則退出</p><p><b>  {</b></p><p>  m_AdoConn.ExitConnect();</p>

104、<p><b>  return;</b></p><p><b>  } </b></p><p>  if(!m_pRecordset->adoEOF)</p><p><b>  { </b></p><p><b>  int t=

105、0;</b></p><p>  m_list.DeleteAllItems();</p><p>  while(!m_pRecordset->adoEOF)//遍歷記錄集</p><p>  {int b=t+1;</p><p>  songid.Format("%d",b);</p>

106、<p>  songname =m_pRecordset->GetFields()->GetItem("tmuname")->Value.bstrVal;/////////////////取歌名</p><p>  singername =m_pRecordset->GetFields()->GetItem("tsingername"

107、;)->Value.bstrVal;/////////////////取歌手名</p><p>  songtype =m_pRecordset->GetFields()->GetItem("tsongtype")->Value.bstrVal;/////////////////取歌的類型</p><p>  filename =m_pRecor

108、dset->GetFields()->GetItem("tfilename")->Value.bstrVal;/////////////////取歌的文件名</p><p>  fileformat =m_pRecordset->GetFields()->GetItem("tformate")->Value.bstrVal;///////

109、//////////取歌的格式</p><p>  6.3 播放控制模塊設計</p><p>  歌曲播放控制模塊主要實現(xiàn)對歌曲播放過程中的各種操作管理。結合功能分析可知,此模塊應實現(xiàn)以下幾個功能:播放上一曲、下一曲、增加音量、減少音量、快進、快退、暫停、停止及播放模式等功能模塊[27]。單獨設計函數(shù)實現(xiàn)播放控制模塊的上述功能是比較繁瑣的,但是由于使用了Windows Media Pla

110、yer控制進行歌曲播放,使得該模塊實現(xiàn)起來比較非常容易,主要是通過CMediaPlayer2類的方法來實現(xiàn)的。在播放列表控件上添加鼠標右鍵菜單(右鍵菜單消息NM_RCLICK)控制播放模式和編輯播放列表,在播放界面上添加按鈕和一組單選按鈕來實現(xiàn)播放控制和播放模式的切換。播放模塊涉及到人機交互的設計,人機交互很好重要,要給人們很多的好的體驗,我們采用簡介的設計風格,人們的體驗這種設計。讓人們更好的體驗,讓人們更好的享受點播服務。</

111、p><p>  歌曲選擇模塊中用戶通過主界面實現(xiàn)歌曲選擇功能,例如:歌曲的播放,上下一首歌,增減音量,快進退等。這些功能的主要實現(xiàn)代碼如下:</p><p><b> ?。?)播放:</b></p><p>  獲取路徑后,m_mediaplayer.Open(songpath);</p><p><b> ?。?/p>

112、2)上一首:</b></p><p>  列表控件行標向上走一個,獲取歌名進行播放;</p><p>  row=row-1; //行標 - 1 </p><p>  playsongname=m_list.GetItemText(row,0); //得到歌名</p><p>  songpath=m_list.Ge

113、tItemText(row,5); //歌曲格式</p><p><b>  (3)下一首:</b></p><p>  列表控件行標向下走一個,獲取歌名進行播放;</p><p>  row=row+1; //行標+1</p><p>  playsongname=m_list.GetItemText(row,1)

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論