C語言課程設計簡單圖形處理

上傳人:仙*** 文檔編號:29287161 上傳時間:2021-10-07 格式:DOC 頁數(shù):17 大小:458.32KB
收藏 版權申訴 舉報 下載
C語言課程設計簡單圖形處理_第1頁
第1頁 / 共17頁
C語言課程設計簡單圖形處理_第2頁
第2頁 / 共17頁
C語言課程設計簡單圖形處理_第3頁
第3頁 / 共17頁

下載文檔到電腦,查找使用更方便

15 積分

下載資源

還剩頁未讀,繼續(xù)閱讀

資源描述:

《C語言課程設計簡單圖形處理》由會員分享,可在線閱讀,更多相關《C語言課程設計簡單圖形處理(17頁珍藏版)》請在裝配圖網(wǎng)上搜索。

1、 1. 課程設計總體要求 2 2. 設計任務與分析 2 2.1設計題目 2 2.2主要內(nèi)容 2 2.3任務分析 2 3. 設計方案 2 3.1模塊 2 3.2流程圖 3 3.3主要函數(shù) 3 3.4負責的模塊設計 3 4. 程序調(diào)試 6 5. 總結(jié)與心得 12 6. 參考文獻 13 1. 課程設計總體要求 采用模塊兒化程序設計; 鼓勵可視化編程; 源程序中有足夠的注釋; 學生可自行增加新功能模塊兒; 必須上機調(diào)試通過; 注重算法運用,優(yōu)化存儲效率與運

2、算效率; 需提交源程序及相關文件; 2. 設計任務與分析 2.1設計題目 簡單圖形處理 2.2主要內(nèi)容 只考慮點、直線、圓三種基本圖形。對于點,給出點的橫縱坐標;對于直線,給出直線方程ax+by+c=0的三個系數(shù)a,b,c;對于圓,給出圓心坐標和半徑。試說明圖形的幾何形狀類型,并編寫輸入和輸出圖形數(shù)據(jù)、求兩點矩離、求兩直線交點、已知點和半徑形成圓、已知兩點形成直線等函數(shù)。 2.3任務分析 這個系統(tǒng)主要需要實現(xiàn)對求兩點矩離、求兩直線交點、已知點和半徑形成圓、已知兩點形成直線。我們可以先構(gòu)建一個主函數(shù),然后一次插入不同的功能函數(shù)。在實現(xiàn)功能函數(shù)的過程

3、中又通過菜單函數(shù)進行各功能函數(shù)的調(diào)用。在運用圖形處理函數(shù)的時候要用到圖形文件。 3. 設計方案 3.1模塊 (1)輸入兩點,求出之間的距離。 (2)輸入圓心和半徑輸出一般的圓。 (3)輸入兩直線表達式X,Y的系數(shù),求出兩直線的交點。 (4)輸入兩點,輸出通過該兩點的直線。 (5)退出。 3.2流程圖 進入選擇菜單 輸入數(shù)字0~4 0 退出系統(tǒng) 開始 1~兩點之間的距離 退出系統(tǒng) 4~ 形成直線 2~兩直線的交點 退出系統(tǒng) 3~ 形成圓 3.3主要函數(shù) 1.pointjl() (求兩點之間的距離) 2.lin

4、ejd();(求兩直線的交點) 3.yuan();(已知圓心和半徑形成圓) 4.line1();(已知兩點形成直線) 5.choice();(功能選擇) 3.4負責的模塊設計 我所負責的模塊: (1) 輸入兩直線表達式X,Y的系數(shù),求出兩直線的交點。 void linejd()/*求兩直線交點*/ { float a1,a2,b1,b2,c1,c2,x,y;/*請輸入直線的系數(shù)*/ printf("***********************************************************************************

5、**************************\n"); printf("請輸入直線1 a1x+b1y+c1=0 的系數(shù) a1,b1,c1 和直線2 a2x+b2y+c2=0 的系數(shù) a2,b2,c1:\n"); printf("*************************************************************************************************************\n"); scanf("%f,%f,%f,%f,%f,%f",&a1,&b1,&c1,&a2,&b2,&c2); if(a

6、1*b2==b1*a2) { if(b1*c2==c1*b2) printf("兩直線重合,有無數(shù)個交點。\n"); else printf("兩直線平行,無交點。\n"); } else { x=(c2/b2-c1/b1)/(a1/b1-a2/b2); y=(c2/a2-c1/a1)/(b1/a1-b2/a2); printf("兩直線交點是 x=%f,y=%f.\n",x,y); } getchar(); } (2) 輸入兩點,輸出通過該兩點的直線。 void line1() /*輸出輸入已知數(shù)據(jù)

7、的直線*/ { int x1,y1,x2,y2; int gdriver, gmode, i; printf("*********************************************************\n"); printf("請輸入兩點 ,x1,y1,x2,y2:\n"); printf("*********************************************************\n"); scanf("%d,%d,%d,%d",&x1,&y1,&x2,&y2); gdriver=DETECT; initgr

8、aph(&gdriver, &gmode, "c:\\caic\\bgi"); setbkcolor(BLUE);/*設定背景顏色為藍色*/ cleardevice(); setcolor(GREEN); setlinestyle(0, 0, 3); setcolor(2); setcolor(WHITE); setlinestyle(4, 0xaaaa, 1); line(x1+320, y1+240, x2+320, y2+240); getch(); closegraph(); } (3) 選擇函數(shù)的設計 int choice ()/*選

9、擇函數(shù)的定義*/ { char c; int k=1; menu(); c=getchar(); while(k) switch(c) { case 1:pointjl() ;k=0;break; case 2:linejd() ;k=0;break; /*求已知兩直線之間的交點函數(shù)*/ case 3:yuan();k=0;break; case 4:line1();k=0;break; case 0:k=0;break; } printf("******

10、***************************************************\n"); printf("歡迎使用該系統(tǒng)\n"); printf("*********************************************************\n"); return 1; } 4. 程序調(diào)試 下面是進入時出現(xiàn)的一個示例圖片。通過查找資料并以此圖來調(diào)試我們知道畫面中心的坐標是(320,240),我們就在程序中每個輸入的橫坐標加上320,縱坐標加上240,以防輸入坐標偏離中心太遠導致顯示不理想。同時該圓的半徑是98,這樣我們就對數(shù)字

11、代表的長度有了一個大概的了解。 下面是對輸出直線功能的調(diào)試。 輸入數(shù)據(jù):0,0,200,200;顯示出的圖形如下圖所示。我們可以看出,X軸正方向向左,Y軸正方向向下。為了進一步驗證Y軸正方向向下,我做了第二次輸入。 如下圖,此次輸入的數(shù)據(jù)為:0,0,0,-200;由此可以斷定,Y軸的正方向向下。 接下來是對求兩直線交點的調(diào)試。 由下圖可以看出當輸入數(shù)據(jù)為1,2,3,3,2,1時得出交點為(1,-2)。對于直線x+2y+3=0與直線3x+2y+1=0,我們直接將x=1,y=-2帶入,發(fā)現(xiàn)均成立,于是所求交點是正確的,程序沒有問題。 但是當我們輸入兩條重合或者平行直線時

12、,程序給出了以下結(jié)果: 可以發(fā)現(xiàn)給出的結(jié)果為1.#INF00的字樣,這表示超出機器浮點類型所表示的范圍。于是我認為程序還需改進。 改進后調(diào)試結(jié)果如下: 改進成功! 下面是對選擇功能的調(diào)試。 輸入1,結(jié)果如下: 沒有問題。 輸入2,結(jié)果如下: 沒有問題。 輸入3,結(jié)果如下: 沒有問題。 輸入4,結(jié)果如下: 沒有問題。 至此,調(diào)試完畢! 5. 總結(jié)與心得 每一個簡單的功能的實現(xiàn)實際上背后都有一個繁重的工程。盡管這是一個很簡單的圖形的輸出、處理系統(tǒng),但是每一個函數(shù)的設計、每一個功能的實現(xiàn)都來之不易。尤其是當每一個模塊的程序編寫好后的試運行

13、,一個個error的尋找、改正花費了數(shù)倍于編寫的時間。盡管編寫的過程漫長、枯燥,甚至痛苦,但是當最后程序成功運行時,興奮的心情還是立刻充斥心間,最后的成功就是對前面付出的最好回報。 通過這次實踐我也學到了很多。C語言的知識更加扎實、豐富,做事更加細心、耐心,還學會了如何與人合作來更快、更高效地完成任務。總之,這次實踐中我收獲了許多,希望以后可以繼續(xù)與他人合作完成更多的任務! 6. 參考文獻 [1] 譚浩強. C語言程序設計[M].北京:清華大學出版社.2006 [2] 張高煜. C語言程序設計實訓.北京:中國水利出版社.2001 [3] 王曉東. C語言設計簡明教程.北京:中國水

14、利出版社.2006 附:源代碼: #include #include "stdio.h" #include "math.h" #include "stdlib.h" #include "conio.h" void linejd()/*求兩直線交點*/ { float a1,a2,b1,b2,c1,c2,x,y;/*請輸入直線的系數(shù)*/ printf("******************************************************************************************

15、*******************\n"); printf("請輸入直線1 a1x+b1y+c1=0 的系數(shù) a1,b1,c1 和直線2 a2x+b2y+c2=0 的系數(shù) a2,b2,c1:\n"); printf("*************************************************************************************************************\n"); scanf("%f,%f,%f,%f,%f,%f",&a1,&b1,&c1,&a2,&b2,&c2); if(a1*

16、b2==b1*a2) { if(b1*c2==c1*b2) printf("兩直線重合,有無數(shù)個交點。\n"); else printf("兩直線平行,無交點。\n"); } else { x=(c2/b2-c1/b1)/(a1/b1-a2/b2); y=(c2/a2-c1/a1)/(b1/a1-b2/a2); printf("兩直線交點是 x=%f,y=%f.\n",x,y); } getchar(); } void pointjl() /*求兩點之間的距離*/ { int x1,y1,x2,y2

17、; float jl; printf("*********************************************************\n"); printf("請輸入兩點,x1,y1,x2,y2:\n"); printf("*********************************************************\n"); scanf("%d,%d,%d,%d",&x1,&y1,&x2,&y2); jl=sqrt(pow(x1-x2,2)+pow(y1-y2,2)); printf("這是兩點 x1=%d , y

18、1=%d 和 x2=%d , y2=%d 之間的距離是\n jl=%f\n",x1,y1,x2,y2,jl); getchar(); } void line1() /*輸出輸入已知數(shù)據(jù)的直線*/ { int x1,y1,x2,y2; int gdriver, gmode, i; printf("*********************************************************\n"); printf("請輸入兩點 ,x1,y1,x2,y2:\n"); printf("*****************************

19、****************************\n"); scanf("%d,%d,%d,%d",&x1,&y1,&x2,&y2); gdriver=DETECT; initgraph(&gdriver, &gmode, "c:\\caic\\bgi"); setbkcolor(BLUE);/*設定背景顏色為藍色*/ cleardevice(); setcolor(GREEN); setlinestyle(0, 0, 3); setcolor(2); setcolor(WHITE); setlinestyle(4, 0xaaaa, 1);

20、line(x1+320, y1+240, x2+320, y2+240); getch(); closegraph(); } void yuan() /*輸出輸入了已知數(shù)據(jù)的圓*/ { int x1,y1,r; int gdriver, gmode, i; printf("*********************************************************\n"); printf("請輸入圓心 x1,y1 圓的半徑 r:\n"); printf("**************************************

21、*******************\n"); scanf("%d,%d,%d",&x1,&y1,&r); gdriver=DETECT; initgraph(&gdriver, &gmode, "c:\\caic\\bgi"); setbkcolor(BLUE); cleardevice(); setcolor(GREEN); circle(x1+320, y1+240, r); setlinestyle(0, 0, 3); setcolor(2); setcolor(WHITE); setlinestyle(4, 0xaaaa, 1); g

22、etch(); closegraph(); } void menu() /*菜單函數(shù)*/ { printf("*********************************************************\n"); printf("歡迎進入簡單的圖形處理系統(tǒng)!\n"); printf("*********************************************************\n"); printf("*********************************************************\n");

23、 printf("請輸入 1,2,3,4:\n");/*請輸入數(shù)字1,2,3,4*/ printf("1.兩點之間的距離\n");/*兩點之間的距離*/ printf("2.兩直線的交點 \n");/*兩直線的交點*/ printf("3.已知點和半徑形成圓\n");/*已知點和半徑形成圓*/ printf("4.已知兩點形成直線 \n");/*已知兩點形成直線*/ printf("*********************************************************\n"); } int choice ()/*選擇函

24、數(shù)的定義*/ { char c; int k=1; menu(); c=getchar(); while(k) switch(c) { case 1:pointjl() ;k=0;break; case 2:linejd() ;k=0;break; /*求已知兩直線之間的交點函數(shù)*/ case 3:yuan();k=0;break; case 4:line1();k=0;break; case 0:k=0;break; } printf("********

25、*************************************************\n"); printf("歡迎使用該系統(tǒng)\n"); printf("*********************************************************\n"); return 1; } int main() { int gdriver, gmode, i;/*在進入主菜單之前先形成一個已知圖形*/ gdriver=DETECT; initgraph(&gdriver, &gmode, "c:\\caic\\bgi"); setbk

26、color(BLUE); cleardevice(); setcolor(GREEN); circle(320, 240, 98); setlinestyle(0, 0, 3); setcolor(2); rectangle(220, 140, 420, 340); setcolor(WHITE); setlinestyle(4, 0xaaaa, 1); line(220, 240, 420, 240); line(320, 140, 320, 340); getch(); closegraph(); choice(); getchar(); return 1; } 16

展開閱讀全文
溫馨提示:
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. 裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

相關資源

更多
正為您匹配相似的精品文檔
關于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權所有   聯(lián)系電話:18123376007

備案號:ICP2024067431-1 川公網(wǎng)安備51140202000466號


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務平臺,本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權或隱私,請立即通知裝配圖網(wǎng),我們立即給予刪除!