簡單畫圖程序課程設(shè)計_第1頁
已閱讀1頁,還剩18頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p><b>  目錄</b></p><p>  1. 基本功能描述1</p><p><b>  2. 設(shè)計思路1</b></p><p><b>  3. 軟件設(shè)計3</b></p><p>  3.1 設(shè)計步驟3</p><p&g

2、t;  3.2 界面設(shè)計6</p><p>  3.3 關(guān)鍵功能的實現(xiàn)7</p><p>  4. 結(jié)論與心得體會8</p><p><b>  5. 參考文獻9</b></p><p><b>  6. 思考題9</b></p><p><b>  7.

3、 附錄9</b></p><p>  7.1 調(diào)試報告9</p><p>  7.2 測試結(jié)果10</p><p>  7.3 關(guān)鍵源代碼1</p><p><b>  簡單畫圖程序</b></p><p><b>  1. 基本功能描述</b></

4、p><p>  1) 在菜單處的有相應(yīng)的菜單項,可以選擇繪制的圖形形狀,如直線、矩形及橢圓,可以選擇線寬,有1-5可供選擇,還可以選擇線色以及填充色,通過彈出的顏色對話框選擇需要的顏色,如果不選擇線寬、線色以及填充色,則按默認的畫筆以及畫刷來繪制選擇的圖形。</p><p>  2) 選擇好圖形后,通過鼠標可以繪制出相應(yīng)的直線,矩形或橢圓,鼠標的按下確定圖形的起點,鼠標的拖動則確定了圖形的終點

5、,即通過鼠標的拖動來決定圖形的大小,鼠標彈起,此圖形則繪制完畢。</p><p>  3) 增添了工具欄,有相應(yīng)的選擇項,可以更方便地實現(xiàn)相應(yīng)的功能。</p><p><b>  2. 設(shè)計思路</b></p><p>  1) 對需要用到的變量進行初始化。</p><p>  2) 選擇相應(yīng)的圖形之后就響應(yīng)相應(yīng)的消息處

6、理函數(shù),給shape賦對應(yīng)的值。選擇不同的線寬,線色與填充色,則改變畫筆和畫刷的屬性。</p><p>  3) 鼠標的按下響應(yīng)LButtonDown(),定義起點的坐標,鼠標的拖動響應(yīng)MouseMove()改變終點的坐標,鼠標的彈起響應(yīng)LButtonUp(),刷新,得到繪制圖形。</p><p>  4) 選擇圖形或其它屬性,可進行下一次繪制。</p><p>&

7、lt;b>  Y</b></p><p><b>  N</b></p><p><b>  Y</b></p><p><b>  N</b></p><p><b>  Y</b></p><p><b

8、>  N</b></p><p><b>  圖1 程序流程圖</b></p><p><b>  3. 軟件設(shè)計</b></p><p><b>  3.1 設(shè)計步驟</b></p><p>  創(chuàng)建一個給予單文檔的應(yīng)用程序框架。命名為“yuyangyi”。

9、</p><p><b>  圖2 創(chuàng)建工程</b></p><p>  編輯菜單。添加需要的菜單項,如圖3;設(shè)定好ID值,如圖4;建立類向?qū)?,在視圖類中,對菜單項添加對應(yīng)的COMMAND消息出理函數(shù),部分菜單項還添加對應(yīng)的UPDATE_COMMAND_UI消息函數(shù),如圖5。</p><p><b>  圖3 添加菜單項</b&

10、gt;</p><p>  圖4 設(shè)定菜單項ID</p><p><b>  圖5 建立類向?qū)?lt;/b></p><p>  創(chuàng)建工具欄。在插入處選擇資源,新建工具欄,如圖6;在工具欄上添加相應(yīng)的按鈕,在屬性處更改其ID,如圖7。</p><p><b>  圖6 新建工具欄</b></p>

11、;<p><b>  圖7 編輯工具欄</b></p><p>  4)在相應(yīng)消息函數(shù)處添加代碼,實現(xiàn)其功能。建立類向?qū)?,添加WM_PAINT消息,以及LBUTTONDOWN、LBUTTONUP、MOUSEMOVE消息,并在其中添加相應(yīng)的代碼,如圖8。</p><p>  圖8 添加WM_PAINT消息</p><p><b

12、>  3.2 界面設(shè)計</b></p><p><b>  表1 界面控件表</b></p><p>  3.3 關(guān)鍵功能的實現(xiàn)</p><p>  1)繪制選擇的圖形。在直線、矩形以及橢圓的消息處理函數(shù)里為shape賦值,選擇直線,則shape=1,選擇矩形,則shape=2,選擇橢圓,則shape=3,在OnPaint()

13、里添加繪圖的代碼,其中運用3個if語句來繪制不同的圖形。當shape=1時執(zhí)行繪制直線的代碼,同理繪制出矩形與橢圓。</p><p>  2)通過鼠標繪制圖形。在視圖類里添加WM_LBUTTONDOWN、WM_LBUTTONUP以及WM_MOUSEMOVE消息,在OnLButtonDown()函數(shù)里,獲取鼠標坐標,將其賦給之前定義作為起點的變量opoint;在OnMouseMove()函數(shù)里,把鼠標坐標賦給之前定

14、義作為終點的變量epoint,OnPaint()中繪圖的代碼中的坐標都得到了,進行繪圖;在OnLButtonUp()函數(shù)里,進行刷新,顯示繪制出的圖。</p><p>  3)改變線寬。定義了默認線寬w=1,在菜單處選擇了線寬的值后,對應(yīng)的值賦給了w,在OnPaint()創(chuàng)建的畫筆中,pen.CreatePen(PS_SOLID,w, m_nColor),線寬處用w表示,則改變w的值即改變了畫筆的粗細。</

15、p><p>  4)改變線色。在選擇線色時,會彈出系統(tǒng)帶的顏色對話框,把選中的顏色給m_nColor,在OnPaint()創(chuàng)建的畫筆中,pen.CreatePen(PS_SOLID,w, m_nColor),線色處用m_nColor表示,則當 m_nColor改變時,畫筆的顏色就會跟著發(fā)生變化。</p><p>  5)改變填充色。選擇填充色時,通過顏色對話框選擇顏色,選中的顏色賦給m_fCo

16、lor,在OnPaint()創(chuàng)建的畫刷中,brush.CreateSolidBrush(m_fColor),顏色就是用m_fColor表示的,所以m_fColor是什么顏色,畫刷就是什么顏色。</p><p>  4. 結(jié)論與心得體會</p><p>  這次C++程序設(shè)計(簡單畫圖程序的實現(xiàn))的課程設(shè)計至此已基本完成,利用這個程序可以在用戶區(qū)繪制出直線、矩形與橢圓圖形,可以自定義線條的顏

17、色以及選擇線的寬度,還可以改變圖形的填充色。最終設(shè)計的程序基本能夠達到課設(shè)任務(wù)書指定的基本功能。</p><p>  這次課程設(shè)計讓我收獲頗多,感覺很是充實,看到最后程序正常運行時候心里還略有一點小小成就感。在選課題的時候,看到有畫圖程序這個題目時候,覺得應(yīng)該有趣一點,不是很枯燥那種,加上平時C++理論課上這種類似的畫圖程序接觸過,老師也講過類似例子,于是就選擇了它。原本以為這個程序制作起來很簡單,但是到了開始著

18、手程序設(shè)計時候,發(fā)現(xiàn)第一步,也就是畫出程序流程圖,我就不知什么樣子的流程圖才是任務(wù)要求的,在查閱課本以及相關(guān)書籍上類似程序流程圖實例后,借鑒了例子中的基本框架,然后才畫出符合要求的流程圖。</p><p>  當開始用VC進行程序編制時候,創(chuàng)建完工程、編輯好相應(yīng)菜單選項以及對菜單項添加對應(yīng)的COMMAND消息出理函數(shù)和對應(yīng)的UPDATE_COMMAND_UI消息函數(shù)后,突然思維卡住了,不知道下一步該從何處下手。請

19、教了一下同學才發(fā)現(xiàn)自己的問題很低級,在添加完函數(shù)后得做的就是在相應(yīng)消息函數(shù)處添加代碼來實現(xiàn)其功能。</p><p>  真正的困難從這時候開始出現(xiàn)了,代碼是程序核心部分,自然也是也困難的地方了,在參閱了課本和平時上課的課件之后,自己嘗試著編寫相應(yīng)功能的代碼,可是編寫完某個功能后用VC編譯時候,程序便報出許多的錯誤,其中較大的一些問題在和同學討論及請教之后得到解決,多數(shù)的錯誤還是屬于那種低級的小錯誤,開始體會到平時

20、一些看起來簡單自己編懶得親自敲打代碼實踐的小程序在真正做起來也是需要認真細心對待的。在建立完類向?qū)В砑油闣M_PAINT消息,以及LBUTTONDOWN、LBUTTONUP、MOUSEMOVE消息,對其進行代碼添加時候,最難得部分出現(xiàn)了,自己參照資料所寫的代碼總是不能運行正確,而且代碼不是很精簡,冗余度很大,最終參照著從網(wǎng)上找到的一段代碼改寫自己代碼,最后才得到正常精簡的程序代碼。</p><p>  在編程中

21、,遇到過很多問題,有時候好不容易解決掉一個問題,還沒來得及高興就發(fā)現(xiàn)這個問題的額解決卻衍生出了另外的問題,甚至是一連引發(fā)好幾個小問題,例如在實現(xiàn)動態(tài)畫圖時,發(fā)現(xiàn)每次接著畫下一個圖形時候,上次以及之前畫的圖案就全部清空了,修改了相應(yīng)刷新函數(shù)之后,圖案是能夠保存了,可是動態(tài)畫圖的每一個中間過程也都被一起保留下來了,這一點到最后也沒有被解決,這是這次課程設(shè)計中最遺憾的一個地方,雖然程序能基本滿足要求,但是沒能完全滿足相應(yīng)要求。</p&g

22、t;<p>  通過這次課程設(shè)計,我學習到了很多,讓我感受到之前在理論課程安排的上機試驗中,所掌握的實際程序操作都是在表層的,沒有深入的程序設(shè)計的核心以及整體把握,上機時候我們大部分都是參照著課本以及課件來操作的,所以遇到的問題不多也不大。但這次課程設(shè)計是的靠自己來獨立操作,需要自己去查閱以及篩選相應(yīng)的資料來幫助自己完成設(shè)計,鍛煉我們的獨立工作及動手實踐能力。讓我對VC 中的MFC有了更多的了解及認知。</p>

23、<p><b>  5. 參考文獻</b></p><p>  [1]揣錦華.面向?qū)ο蟪绦蛟O(shè)計與VC++實踐.西安電子科技大學出版社.2005.</p><p>  [2]Walter Savitch. 完美C++教程.清華大學出版社.2005. </p><p>  [3](美) Judy Scholl. C++編程:從問題分析

24、到程序設(shè)計實驗指導書.電子工業(yè)出版社.2003.</p><p>  [4] 夏崇鐠, 任海軍, 余健. Visual C++課程設(shè)計案例精編.清華大學出版社.2008</p><p><b>  6. 思考題</b></p><p>  1) 說明直線、橢圓、矩形繪制使用的函數(shù),及其參數(shù)含義?</p><p>  答:

25、直線、橢圓、矩形繪制使用的函數(shù)是OnPaint()。函數(shù)里面定義和創(chuàng)建了畫筆和畫刷,3種圖形本身對應(yīng)的消息處理函數(shù)里分別賦給shape不同的值,在OnPaint()里有3個if語句,如果shape=1時,繪制直線,如果shape=2時,繪制矩形,如果shape=3時,繪制橢圓。</p><p>  2) 如何控制菜單項的狀態(tài),使用的消息類型?</p><p>  答:添加UPDATE_CO

26、MMAND_UI消息函數(shù),在生成的函數(shù)里添加相關(guān)代碼,如選擇直線時,使shape=1,則OnUpdateLine里添加pCmdUI->SetCheck(shape==1),那么當shape的值為1時,即代表選擇了直線項,此時菜單中的直線選項前就打勾了,代表選中。</p><p>  3) 如何設(shè)置菜單和工具欄按鈕的快捷鍵操作?</p><p>  答:在資源視圖下選擇Accelera

27、tor,雙擊IDR_MAINFRAME,打開編輯窗口,雙擊空白處,在ID下拉列表框中選擇需要快捷鍵的菜單項或工具欄按鈕的ID,在鍵一欄中輸入快捷鍵,選擇Ctrl復選框和虛擬鍵單選按鈕即可。</p><p><b>  7. 附錄</b></p><p><b>  7.1 調(diào)試報告</b></p><p>  1)在程序第

28、一次運行時候,工具欄線型選定直線,然后發(fā)現(xiàn)鼠標在用戶區(qū)怎么也畫不出直線,換作矩形和橢圓也一樣,但在菜單繪圖里選定線寬之后方能畫出圖形,后來發(fā)現(xiàn),原理我沒有設(shè)置默認線寬,于是在“yuyangyiView.cpp”中,添加如下函數(shù)及代碼:</p><p>  CyuyangyiView::CyuyangyiView()</p><p>  { w=1; shape=0; }&

29、lt;/p><p>  于是在程序運行時候即便開始不選擇線寬,也能畫出圖形來。</p><p>  2)要讓鼠標來決定圖形的起始點,所以定義了起始點opoint和終止點cpoint,把OnPaint中繪制圖形代碼的坐標都改成了這2個變量。然后在添加的OnLButtonDown()、OnMouseMove()和OnLButtonUp()中,給這兩個變量賦值。接著我編譯運行,確出現(xiàn)了這樣的錯誤,我

30、只要把鼠標左鍵一按,即使已經(jīng)馬上松開,鼠標拖動還是會進行繪制,與需要實現(xiàn)的功能不符。于是我添加了一布爾類型的變量m_Down,代表鼠標的按下與否,當按下時讓它為TRUE,在OnMouseMove()里添加當按下時才執(zhí)行之前代碼的語句。這樣畫圖時,只有鼠標左鍵按著拖動時,才會進行繪制。</p><p>  3)在實現(xiàn)動態(tài)畫圖時候,發(fā)現(xiàn)鼠標每次移動時候,所在點都會與原起始點間產(chǎn)生圖形顯示出來,效果如圖9,后來發(fā)現(xiàn)我在

31、在“yuyangyiView.cpp”中的代碼段:</p><p>  void CyuyangyiView::OnMouseMove(UINT nFlags, CPoint point)</p><p>  { f(m_Down) cpoint=point; Invalidate(0); </p><p>  CView::OnMouseMove(nF

32、lags, point);}</p><p>  中多了“Invalidate(0)”一條刷新句,去掉后程序便正常運行。</p><p><b>  圖9 錯誤圖樣</b></p><p><b>  7.2 測試結(jié)果</b></p><p>  1) 點擊編譯、連接、運行后,彈出畫圖的界面。有添加

33、的菜單和工具欄。如圖10。</p><p><b>  圖10 畫圖界面</b></p><p>  2) 菜單處點擊“繪圖”,彈出相關(guān)選項,點擊選擇的圖形后,被選項前打了個勾,相應(yīng)的工具欄按鈕也顯示被按下,在線寬處選擇需要線寬,被選項前有圓點,不選默認為1。如圖11。</p><p>  圖11 選擇圖形及相關(guān)屬性</p>&l

34、t;p>  3) 選擇好圖形及相關(guān)屬性后,用鼠標進行繪制。如圖12。</p><p><b>  圖12 繪制圖形</b></p><p>  4) 繼續(xù)畫多個圖形,或改變屬性,或改變形狀,繪制圖形。如圖13。</p><p>  圖13 繪制多個圖形</p><p><b>  7.3 關(guān)鍵源代碼<

35、;/b></p><p>  在“MainFrm.h”中,在class CMainFrame : public CFrameWnd里的protected下定義:</p><p>  CToolBar m_drawToolBar; //工具欄</p><p>  2)在“MainFrm.cpp”中,在CMainFrame::OnCreate(LPCREATE

36、STRUCT lpCreateStruct)里添加以下代碼:</p><p>  if (!m_drawToolBar.Create(this) ||</p><p>  !m_drawToolBar.LoadToolBar(IDR_DRAW))</p><p>  {TRACE0("Failed to create status bar\n"

37、);</p><p>  return -1; </p><p>  } </p><p>  3)在“yuyangyiView.h”中,在class CyuyangyiView : public CView里的public下定義相關(guān)變量:</p><p>  COLORREF m_nColor;</p>

38、<p>  COLORREF m_fColor;</p><p>  CPoint cpoint; </p><p>  CPoint opoint;</p><p>  BOOL m_Down;</p><p><b>  int w;</b></p><p>  int shap

39、e;</p><p>  4)在“yuyangyiView.cpp”中,添加如下函數(shù)及代碼:</p><p>  CyuyangyiView::CyuyangyiView()</p><p>  { w=1; //初始線寬默認為1</p><p><b>  shape=0;</b></p>

40、<p><b>  }</b></p><p>  void Cyuyangyi::OnW1() </p><p><b>  {</b></p><p>  w=1; //令線寬為1</p><p><b>  }</b></p><p&g

41、t;  void CyuyangyiView::OnW2() </p><p><b>  {</b></p><p>  w=2; //令線寬為2</p><p><b>  }</b></p><p>  void CyuyangyiView::OnW3() </p><

42、;p><b>  {</b></p><p>  w=3; //令線寬為3</p><p><b>  }</b></p><p>  void CyuyangyiView::OnW4() </p><p><b>  {</b></p><p&

43、gt;  w=4; //令線寬為4</p><p><b>  }</b></p><p>  void CyuyangyiView::OnW5() </p><p><b>  {</b></p><p>  w=5; //令線寬為5</p><p><b

44、>  }</b></p><p>  void CyuyangyiView::OnUpdateW1(CCmdUI* pCmdUI) </p><p><b>  {</b></p><p>  pCmdUI->SetRadio(w==1); //當線寬為1時,此選項前標有圓點</p><p>

45、<b>  }</b></p><p>  void CyuyangyiView::OnUpdateW2(CCmdUI* pCmdUI) </p><p><b>  {</b></p><p>  pCmdUI->SetRadio(w==2); //當線寬為2時,此選項前標有圓點</p><

46、p><b>  }</b></p><p>  void CyuyangyiView::OnUpdateW3(CCmdUI* pCmdUI) </p><p><b>  {</b></p><p>  pCmdUI->SetRadio(w==3); //當線寬為3時,此選項前標有圓點</p>

47、<p><b>  }</b></p><p>  void CyuyangyiView::OnUpdateW4(CCmdUI* pCmdUI) </p><p><b>  {</b></p><p>  pCmdUI->SetRadio(w==4); //當線寬為4時,此選項前標有圓點<

48、/p><p><b>  }</b></p><p>  void CyuyangyiView::OnUpdateW5(CCmdUI* pCmdUI) </p><p><b>  {</b></p><p>  pCmdUI->SetRadio(w==5); //當線寬為5時,此選項前標

49、有圓點</p><p><b>  }</b></p><p>  void CyuyangyiView::OnLine() </p><p><b>  {</b></p><p>  shape=1; //選擇直線,則令shape為1</p><p><b&

50、gt;  }</b></p><p>  void CyuyangyiView::OnRect() </p><p><b>  {</b></p><p>  shape=2; //選擇矩形,則令shape為2</p><p><b>  }</b></p>&l

51、t;p>  void CyuyangyiView::OnEllipse() </p><p><b>  {</b></p><p>  shape=3; //選擇橢圓,則令shape為3</p><p><b>  }</b></p><p>  void CyuyangyiView

52、::OnUpdateLine(CCmdUI* pCmdUI) </p><p><b>  {</b></p><p>  pCmdUI->SetCheck(shape==1); //shape為1時,直線選項前打上勾</p><p><b>  }</b></p><p>  void

53、CyuyangyiView::OnUpdateRect(CCmdUI* pCmdUI) </p><p><b>  {</b></p><p>  pCmdUI->SetCheck(shape==2); //shape為2時,矩形選項前打上勾</p><p><b>  }</b></p>&l

54、t;p>  void CyuyangyiView::OnUpdateEllipse(CCmdUI* pCmdUI) </p><p><b>  {</b></p><p>  pCmdUI->SetCheck(shape==3); //shape為3時,橢圓選項前打上勾</p><p><b>  }</b&

55、gt;</p><p>  void CyuyangyiView::OnColor() </p><p><b>  {</b></p><p>  CColorDialog Color; // 創(chuàng)建顏色對話框</p><p>  if(Color.DoModal() == IDOK) // 如果用戶點擊OK按鈕 &l

56、t;/p><p>  m_nColor=Color.GetColor(); // 更改顏色,把顏色賦到m_nColor</p><p><b>  }</b></p><p>  void CyuyangyiView::OnFillColor() </p><p><b>  {</b></p&g

57、t;<p>  CColorDialog FillColor; // 創(chuàng)建顏色對話框</p><p>  if(FillColor.DoModal() == IDOK) // 如果用戶點擊OK按鈕 </p><p>  m_fColor=FillColor.GetColor(); // 更改顏色,把顏色賦到m_fColor</p><p><

58、b>  }</b></p><p>  void CyuyangyiView::OnPaint() </p><p><b>  {</b></p><p>  CPaintDC dc(this); // device context for painting</p><p>  CPen pen;

59、 //定義畫筆</p><p>  CBrush brush; //定義畫刷</p><p>  pen.CreatePen(PS_SOLID,w, m_nColor); //創(chuàng)建畫筆</p><p>  brush.CreateSolidBrush(m_fColor); //創(chuàng)建畫刷</p><p>  dc.

60、SelectObject(&pen); //獲取畫筆</p><p>  dc.SelectObject(&brush); //獲取畫刷</p><p>  if(shape==1)</p><p>  {dc.MoveTo(opoint.x,opoint.y);</p><p>  dc.LineTo(cpo

61、int.x,cpoint.y);} //繪制直線,從opoint到epoint連線</p><p>  if(shape==2)</p><p>  dc.Rectangle(opoint.x,opoint.y,cpoint.x,cpoint.y); //繪制矩形</p><p>  if(shape==3)</p><p>  dc.El

62、lipse(opoint.x,opoint.y,cpoint.x,cpoint.y);//繪制橢圓</p><p><b>  }</b></p><p>  void CyuyangyiView::OnLButtonDown(UINT nFlags, CPoint point) </p><p><b>  {</b>

63、</p><p>  // TODO: Add your message handler code here and/or call default</p><p>  m_Down=TRUE; //鼠標按下 </p><p>  SetCapture(); //獲取坐標</p><p>  opoint=point

64、; //把鼠標所在坐標賦給起點坐標opoint</p><p>  ReleaseCapture(); //釋放坐標</p><p>  CView::OnLButtonDown(nFlags, point);</p><p><b>  }</b></p><p>  void CyuyangyiVi

65、ew::OnMouseMove(UINT nFlags, CPoint point) </p><p><b>  {</b></p><p>  if(m_Down) //如果鼠標按下</p><p>  cpoint=point; //把鼠標所在點坐標賦給終點坐標epoint</p><p>

66、  CView::OnMouseMove(nFlags, point);</p><p><b>  }</b></p><p>  void CyuyangyiView::OnLButtonUp(UINT nFlags, CPoint point) </p><p><b>  {</b></p><

溫馨提示

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

評論

0/150

提交評論