版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、<p><b> 目 錄</b></p><p> 1 基本功能描述----------------------------------------------------------1</p><p> 2 設(shè)計思路----------------------------------------------------------1</p>
2、;<p> 3 軟件設(shè)計----------------------------------------------------------3</p><p> 3.1 設(shè)計步驟----------------------------------------------------------3</p><p> 3.2 界面設(shè)計--------------------
3、--------------------------------------7</p><p> 3.3 關(guān)鍵功能實----------------------------------------------------------8</p><p> 4. 附錄----------------------------------------------------------9<
4、;/p><p> 4.1 調(diào)試報告----------------------------------------------------------9</p><p> 4.2 測試結(jié)果----------------------------------------------------------10</p><p> 4.3關(guān)鍵源代碼----------
5、-----------------------------------------------10</p><p> 5 結(jié)論與心得體會----------------------------------------------------------11</p><p> 6. 參考文獻-------------------------------------------------
6、---------11</p><p> 7. 思考題----------------------------------------------------------11</p><p><b> 簡單畫圖程序</b></p><p><b> 1 基本功能描述</b></p><p>
7、 1) 在單文檔菜單中,在菜單行中可插入一個菜單項,命名為繪圖,在下拉菜單中可分別設(shè)置繪制的圖形形狀,如直線、矩形及橢圓,線寬選項,有1-5可供選擇,還可以設(shè)置線色以及填充色,通過彈出的顏色對話框選擇需要的顏色,如果不選擇線寬、線色以及填充色,則按默認的畫筆,畫刷來繪制選擇的圖形。</p><p> 2) 選擇好圖形后,通過鼠標可以繪制出相應(yīng)的直線,矩形或橢圓,鼠標的按下確定圖形的起點,鼠標的拖動則確定了圖形的
8、終點,即通過鼠標的拖動來決定圖形的大小,當(dāng)鼠標彈起,此圖形則繪制完畢。</p><p> 3) 增添工具欄,設(shè)置繪制的圖形形狀,線色以及填充色,可更方便地選擇相應(yīng)的功能。</p><p><b> 2 設(shè)計思路</b></p><p> 1) 對需要用到的變量進行初始化。</p><p> 2) 選擇相應(yīng)的圖形之
9、后就響應(yīng)相應(yīng)的消息處理函數(shù),給shape賦對應(yīng)的值。選擇不同的線寬,線色與填充色,即可改變畫筆或畫刷的屬性。</p><p> 3) 鼠標的按下響應(yīng)函數(shù)OnLButtonDown(),捕捉鼠標當(dāng)前位置得到起點的坐標,鼠標的拖動響函數(shù)OnMouseMove()改變終點的坐標,鼠標的彈起響應(yīng)OnLButtonUp(),確定終點坐標,刷新,得到繪制圖形。</p><p> 4) 選擇圖形或其
10、它屬性,可進行下一次繪制。</p><p><b> 圖1 程序流程圖</b></p><p><b> 3 軟件設(shè)計</b></p><p><b> 3.1 設(shè)計步驟</b></p><p><b> 1)創(chuàng)建單文檔</b></p>
11、;<p> 創(chuàng)建一個MFC AppWizard[exe]工程,命名為“yinshuyan”,如圖1所示,并創(chuàng)建單文檔,如圖2所示。創(chuàng)建成功后,系統(tǒng)自動生成相應(yīng)的類,如圖3所示。</p><p><b> 圖2 創(chuàng)建工程</b></p><p><b> 圖3 創(chuàng)建單文檔</b></p><p>&l
12、t;b> 圖4 生成類</b></p><p><b> 編輯菜單</b></p><p> 添加需要的菜單項,如圖4所示;并在菜單的屬性中設(shè)定好所對應(yīng)的ID,如圖5所示,各項菜單對應(yīng)的ID如表1所示(其中線寬菜單為彈出菜單,只需在菜單項目屬性中的彈出選項前打勾即可,分隔線亦只需在菜單項目屬性中選中分隔符選項即可)。</p>&
13、lt;p><b> 圖5 添加菜單項</b></p><p> 圖6 設(shè)置菜單ID</p><p> 表1 菜單項對應(yīng)ID</p><p> 建立類向?qū)В谝晥D類CyinshuyanView中,對各菜單項添加對應(yīng)的COMMAND消息處理函數(shù),部分菜單項還添加對應(yīng)的UPDATE_COMMAND_UI消息函數(shù),如圖6所示。<
14、;/p><p> 圖7 建立類向?qū)?lt;/p><p><b> 3)創(chuàng)建工具欄</b></p><p> 在插入處選擇資源,新建工具欄,如圖7所示;</p><p><b> 圖8 新建工具欄</b></p><p> 在工具欄上添加相應(yīng)的按鈕,在屬性處更改其ID,
15、如圖8所示。</p><p><b> 圖9 編輯工具欄</b></p><p> 4)在相應(yīng)消息函數(shù)處添加代碼,實現(xiàn)其功能</p><p> 建立類向?qū)?,在視圖類CyinshuyanView中,添加WM_PAINT消息,以及WM_LBUTTONDOWN、WM_LBUTTONUP、WM_MOUSEMOVE消息,并在其中添加相應(yīng)的代碼,如
16、圖9所示。</p><p> 圖10 添加WM_PAINT消息</p><p><b> 3.2 界面設(shè)計</b></p><p> 各控件名稱,類型,屬性及相關(guān)變量如表2所示。 </p><p><b> 表2 界面控件表</b></p
17、><p> 續(xù)表2 界面控件表</p><p> 3.3 關(guān)鍵功能實現(xiàn)</p><p> 1)選擇要繪制的圖形</p><p> 在直線、矩形以及橢圓的消息處理函數(shù)里為shape分別賦值為1,2,3,在OnPaint()函數(shù)里添加3個if語句的代碼來這實現(xiàn)這三個圖形的繪制:當(dāng)選擇畫直線時,shape=1,則執(zhí)行繪制直線代碼,當(dāng)選擇畫矩形
18、時,shape =2,則執(zhí)行繪制矩形的代碼,當(dāng)性選擇畫橢圓時,shape=3,則執(zhí)行繪制橢圓的代碼。</p><p><b> 2)改變線寬</b></p><p> 在OnPaint()創(chuàng)建的畫筆中,pen.CreatePen(PS_SOLID,w, m_nColor),線寬處用w表示,則改變w的值即改變了畫筆的粗細。選擇菜單繪圖→線寬選擇劃線寬度值,此時所選的
19、線寬值就賦給線寬變量w。若不選擇線寬值,則w=1(即默認線寬值為1)。</p><p><b> 3)改變線色</b></p><p> 在OnPaint()創(chuàng)建的畫筆中,pen.CreatePen(PS_SOLID,w, m_nColor),線的顏色處用m_nColor表示,則改變m_nColor即改變了畫筆的顏色。選擇菜單繪圖→顏色,會彈出通過WM_COLOR
20、REF從系統(tǒng)中引入的顏色選擇對話框,選擇顏色后,點擊確定則相應(yīng)顏色值就賦給變量m_nColor,此時畫筆的顏色就會發(fā)上變化。若不選擇顏色,則默認(線)顏色為黑色。</p><p><b> 4)改變填充色</b></p><p> 在OnPaint()創(chuàng)建的畫刷中,brush.CreateSolidBrush(m_fColor),顏色就是用m_fColor表示的,
21、改變m_fColor即改變了畫刷的顏色。選擇菜單繪圖→填充色,會彈出通過WM_COLORREF從系統(tǒng)中引入的顏色選擇對話框,選擇顏色后,點擊確定則相應(yīng)顏色值就賦給變量m_fColor,此時畫刷的顏色就會發(fā)上變化。若不選擇顏色,則默認填充色為黑色。</p><p><b> 5)繪制圖形</b></p><p> 鼠標左鍵按下,則捕獲鼠標此時的位置坐標為畫圖的起點,
22、此時在OnLButtonDown()函數(shù)里,將捕獲的坐標值賦給定義作為起點的變量opoint;按下鼠標左鍵拖動鼠標時,捕捉鼠標當(dāng)前位置坐標值為終點坐標值,此時在OnMouseMove()函數(shù)里,把捕獲的坐標值賦給定義作為終點的變量cpoint,OnPaint()中繪圖的代碼中的坐標都得到了,進行繪圖;鼠標左鍵彈起時,此時繪圖結(jié)束,鼠標彈起時所在位置就是畫圖的最終終點位置,畫圖結(jié)束后,刷新窗口,以便重新畫圖,此時執(zhí)行的是OnLButton
23、Up()函數(shù)。</p><p> 圖11 快捷鍵的創(chuàng)建</p><p><b> 4. 附錄</b></p><p><b> 4.1 調(diào)試報告</b></p><p> 1)一開始我并沒有添加刷新函數(shù)Invalidate(),這就使程序運行之后,無論鼠標左鍵按下時如何移動無法繪圖,這是因
24、為當(dāng)一個窗口內(nèi)鍵入內(nèi)容其實就是將窗口刷新了,相當(dāng)于更新了窗口,故必須有刷新函數(shù),這和生活中的白紙寫字不一樣。</p><p> 2)當(dāng)添加Invalidate()后,我把Invalidate()放在OnMouseMove()里,但是這樣只能在窗口內(nèi)畫一個圖形,即每畫完一個圖形就刷新一次。之后我通過與同學(xué)討論,并查找資料將Invalidate()改為了Invalidate(0),這時是可繪制多個圖形,但鼠標每移動
25、一個位置都進行一次刷新,繪圖結(jié)束后,繪圖過程中的所有痕跡都在,產(chǎn)生了很多拖動的影子。,經(jīng)過幾次試驗,我將Invalidate(0) 放在了OnLButtonUp()中,那么每次重繪,上次的圖形會作為背景被保留下來,而不會被刷新掉。</p><p><b> 4.2 測試結(jié)果</b></p><p> 1)點擊鏈接,編譯,運行后的窗口如圖11所示。</p>
26、;<p> 圖11 運行結(jié)果</p><p> 2)改變繪制圖形形狀,顏色,線寬,填充色之后繪制的圖形如圖12所示。</p><p> 圖12 改便各項屬性厚后的圖形</p><p><b> 4.3 關(guān)鍵源代碼</b></p><p> 在“MainFrm.h”中,在class CMain
27、Frame : public CFrameWnd里的protected下定義:</p><p> CToolBar m_drawToolBar; //工具欄</p><p> 2)在“MainFrm.cpp”中,在CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)里添加以下代碼:</p><p> if
28、(!m_drawToolBar.Create(this) ||</p><p> !m_drawToolBar.LoadToolBar(IDR_DRAW))</p><p> {TRACE0("Failed to create status bar\n");</p><p> return -1; </p><
29、;p> } </p><p> 3)在“YinshuyanView.h”中,在class CYinshuyanView : public CView里的public下定義相關(guān)變量:</p><p> COLORREF m_nColor;</p><p> COLORREF m_fColor;</p><p>
30、CPoint cpoint; </p><p> CPoint opoint;</p><p> BOOL m_Down;</p><p><b> int w;</b></p><p> int shape;</p><p> 4)在“YinshuyanView.cpp”中,添加如下函
31、數(shù)及代碼:</p><p> CYinshuyanView:: CYinshuyanView()</p><p> { w=1; //初始線寬默認為1</p><p><b> shape=0;</b></p><p><b> }</b></p><p&
32、gt; void CYinshuyanView::OnW1() </p><p><b> {</b></p><p> w=1; //令線寬為1</p><p><b> }</b></p><p> void CYinshuyanView::OnW2() </p>&
33、lt;p><b> {</b></p><p> w=2; //令線寬為2</p><p><b> }</b></p><p> void CYinshuyan::OnW3() </p><p><b> {</b></p><p&g
34、t; w=3; //令線寬為3</p><p><b> }</b></p><p> void CYinshuyanView::OnW4() </p><p><b> {</b></p><p> w=4; //令線寬為4</p><p><b
35、> }</b></p><p> void CYinshuyanView::OnW5() </p><p><b> {</b></p><p> w=5; //令線寬為5</p><p><b> }</b></p><p> void
36、CYinshuyanView::OnUpdateW1(CCmdUI* pCmdUI) </p><p><b> {</b></p><p> pCmdUI->SetRadio(w==1); //當(dāng)線寬為1時,此選項前標有圓點</p><p><b> }</b></p><p>
37、 void CYinshuyanView::OnUpdateW2(CCmdUI* pCmdUI) </p><p><b> {</b></p><p> pCmdUI->SetRadio(w==2); //當(dāng)線寬為2時,此選項前標有圓點</p><p><b> }</b></p><
38、p> void CYinshuyanView::OnUpdateW3(CCmdUI* pCmdUI) </p><p><b> {</b></p><p> pCmdUI->SetRadio(w==3); //當(dāng)線寬為3時,此選項前標有圓點</p><p><b> }</b></p>
39、;<p> void CYinshuyanView::OnUpdateW4(CCmdUI* pCmdUI) </p><p><b> {</b></p><p> pCmdUI->SetRadio(w==4); </p><p><b> }</b></p><p&g
40、t; void CYinshuyanView::OnUpdateW5(CCmdUI* pCmdUI) </p><p><b> {</b></p><p> pCmdUI->SetRadio(w==5);</p><p><b> }</b></p><p> void CYins
41、huyanView::OnLine() </p><p><b> {</b></p><p> shape=1; //選擇直線,則令shape為1</p><p><b> }</b></p><p> void CYinshuyanView::OnRect() </p>
42、;<p><b> {</b></p><p> shape=2; //選擇矩形,則令shape為2</p><p><b> }</b></p><p> void CYinshuyanView::OnEllipse() </p><p><b> {&l
43、t;/b></p><p> shape=3; //選擇橢圓,則令shape為3</p><p><b> }</b></p><p> void CYinshuyanView::OnUpdateLine(CCmdUI* pCmdUI) </p><p><b> {</b>&
44、lt;/p><p> pCmdUI->SetCheck(shape==1); //shape為1時,直線選項前打上勾</p><p><b> }</b></p><p> void CYinshuyanView::OnUpdateRect(CCmdUI* pCmdUI) </p><p><b>
45、 {</b></p><p> pCmdUI->SetCheck(shape==2); //shape為2時,矩形選項前打上勾</p><p><b> }</b></p><p> void CYinshuyanView::OnUpdateEllipse(CCmdUI* pCmdUI) </p>
46、<p><b> {</b></p><p> pCmdUI->SetCheck(shape==3); //shape為3時,橢圓選項前打上勾</p><p><b> }</b></p><p> void CYinshuyanView::OnColor() </p><
47、p><b> {</b></p><p> CColorDialog Color; // 創(chuàng)建顏色對話框</p><p> if(Color.DoModal() == IDOK) // 如果用戶點擊OK按鈕 </p><p> m_nColor=Color.GetColor(); // 更改顏色,把顏色賦到m_nColor<
48、;/p><p><b> }</b></p><p> void CYinshuyanView::OnFullColor() </p><p><b> {</b></p><p> CColorDialog FullColor; // 創(chuàng)建顏色對話框</p><p>
49、 if(FullColor.DoModal() == IDOK) // 如果用戶點擊OK按鈕 </p><p> m_fColor=FullColor.GetColor(); // 更改顏色,把顏色賦到m_fColor</p><p><b> }</b></p><p> void CYinshuyanView::OnPaint()
50、 </p><p><b> {</b></p><p> CPaintDC dc(this); // device context for painting</p><p> CPen pen; //定義畫筆</p><p> CBrush brush; //定義畫刷</p>
51、<p> pen.CreatePen(PS_SOLID,w, m_nColor); //創(chuàng)建畫筆</p><p> brush.CreateSolidBrush(m_fColor); //創(chuàng)建畫刷</p><p> dc.SelectObject(&pen); //獲取畫筆</p><p> dc.SelectObj
52、ect(&brush); //獲取畫刷</p><p> if(shape==1)</p><p> {dc.MoveTo(opoint.x,opoint.y);</p><p> dc.LineTo(cpoint.x,cpoint.y);} //繪制直線,從opoint到cpoint連線</p><p> if(sh
53、ape==2)</p><p> dc.Rectangle(opoint.x,opoint.y,cpoint.x,cpoint.y); //繪制矩形</p><p> if(shape==3)</p><p> dc.Ellipse(opoint.x,opoint.y,cpoint.x,cpoint.y);//繪制橢圓</p><p>
54、;<b> }</b></p><p> void CYinshuyanView::OnLButtonDown(UINT nFlags, CPoint point) </p><p><b> {</b></p><p> // TODO: Add your message handler code here an
55、d/or call default</p><p> m_Down=TRUE; //鼠標按下 </p><p> SetCapture(); //獲取坐標</p><p> opoint=point; //把鼠標所在坐標賦給起點坐標opoint</p><p> ReleaseCapture()
56、; //釋放坐標</p><p> CView::OnLButtonDown(nFlags, point);</p><p><b> }</b></p><p> void CYinshuyanView::OnMouseMove(UINT nFlags, CPoint point) </p><p><
57、b> {</b></p><p> if(m_Down) //如果鼠標按下</p><p> cpoint=point; //把鼠標所在點坐標賦給終點坐標cpoint</p><p> CView::OnMouseMove(nFlags, point);</p><p><b>
58、}</b></p><p> void CYinshuyanView::OnLButtonUp(UINT nFlags, CPoint point) </p><p><b> {</b></p><p> m_Down=FALSE; //鼠標不按下,即彈起</p><p> Invalida
59、te(0); //刷新</p><p> CView::OnLButtonUp(nFlags, point);</p><p><b> }</b></p><p><b> 5 結(jié)論與心得體會</b></p><p> 這次課程設(shè)計我成功的完成了。通過本次課程設(shè)計,我完成了用移動鼠標
60、對直線,矩形,橢圓的簡單繪制工具的制作,其中完成了繪圖形狀的選擇,畫圖線寬、線色以及圖形填充色的設(shè)置。</p><p> 基于平時課外上機實驗的練習(xí),對菜單的創(chuàng)建,COMMAND消息處理函數(shù)和 UPDATE_COMMAND_UI消息函數(shù)的添加過程比較熟練,這部分還算簡單。難的是代碼的添加,對繪制圖形的程序有大概的思路,但具體編寫時變量的運用以及函數(shù)的調(diào)用設(shè)置。這次實驗中關(guān)鍵就是確定畫圖起點及終點坐標,因為是用鼠
61、標繪制圖形,所以需用函數(shù)來捕獲鼠標當(dāng)前所在位置的坐標,因此我設(shè)置了OnLButtonDown()函數(shù)來捕獲起點坐標,OnMouseMove()函數(shù)來捕獲鼠標移動是的當(dāng)前位置坐標,OnLButtonUp()函數(shù)來捕獲終點坐標。而繪制圖形使用的函數(shù)是OnPaint(),將圖形的起點和終點坐標和鼠標的位置坐標相聯(lián)系后就能用鼠標來繪制圖形了,所以在它們之間用opoint和cpoint兩變量實現(xiàn)鏈接。另外我覺得將繪圖語句集中在OnPaint()函
62、數(shù)中,然后其他函數(shù)來調(diào)用OnPaint()函數(shù),這樣不容易引起混亂,同時程序更簡單,更有條理,便于修改。</p><p> 這次課程設(shè)計雖只是做了一個極其簡單的繪圖工具的制作,但也讓我從設(shè)計者的角度看到了設(shè)計程序以及電腦軟件工具的實質(zhì)及難度,看似一個很簡單的工具,其制作的背后工作是很大的,不光是圖標,按鈕的設(shè)置,程序的編寫,代碼的實現(xiàn)都是很精密且不容許一點錯誤的工作。平時我們使用的很順手的一個小小工具,其開發(fā)的
63、各項小號都不可小覷,由此,我們需要學(xué)的東西還太多太多。</p><p><b> 6. 參考文獻</b></p><p> [1]揣錦華.面向?qū)ο蟪绦蛟O(shè)計與VC++實踐.西安電子科技大學(xué)出版社.2005.</p><p> [2]魏亮, 李春葆編著.Visual C++程序設(shè)計例學(xué)與實踐.清華大學(xué)出版社 .2006.</p
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 簡單畫圖程序課程設(shè)計報告
- 簡單畫圖程序課程設(shè)計
- 簡單畫圖程序-課程設(shè)計
- 畫圖板課程設(shè)計報告
- java畫圖板課程設(shè)計報告
- java畫圖板課程設(shè)計報告
- java課程設(shè)計--簡單的網(wǎng)絡(luò)聊天程序
- 操作系統(tǒng)課程設(shè)計--簡單的聊天程序
- 操作系統(tǒng)課程設(shè)計--簡單的聊天程序
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計——簡單行編輯程序
- java課程設(shè)計--簡單記事本程序的設(shè)計
- 簡單計算器課程設(shè)計報告
- 程序設(shè)計課程設(shè)計報告
- 程序設(shè)計課程設(shè)計報告
- 簡單頻率計課程設(shè)計報告
- 簡單計算器課程設(shè)計報告
- 簡單投票管理系統(tǒng)課程設(shè)計報告
- 課程設(shè)計一個簡單的網(wǎng)絡(luò)聊天程序
- 算術(shù)測試程序課程設(shè)計報告
- 面向?qū)ο蟪绦蛘n程設(shè)計報告
評論
0/150
提交評論