C語(yǔ)言課程設(shè)計(jì)簡(jiǎn)單圖形處理
《C語(yǔ)言課程設(shè)計(jì)簡(jiǎn)單圖形處理》由會(huì)員分享,可在線閱讀,更多相關(guān)《C語(yǔ)言課程設(shè)計(jì)簡(jiǎn)單圖形處理(17頁(yè)珍藏版)》請(qǐng)?jiān)谘b配圖網(wǎng)上搜索。
1、 1. 課程設(shè)計(jì)總體要求 2 2. 設(shè)計(jì)任務(wù)與分析 2 2.1設(shè)計(jì)題目 2 2.2主要內(nèi)容 2 2.3任務(wù)分析 2 3. 設(shè)計(jì)方案 2 3.1模塊 2 3.2流程圖 3 3.3主要函數(shù) 3 3.4負(fù)責(zé)的模塊設(shè)計(jì) 3 4. 程序調(diào)試 6 5. 總結(jié)與心得 12 6. 參考文獻(xiàn) 13 1. 課程設(shè)計(jì)總體要求 采用模塊兒化程序設(shè)計(jì); 鼓勵(lì)可視化編程; 源程序中有足夠的注釋; 學(xué)生可自行增加新功能模塊兒; 必須上機(jī)調(diào)試通過(guò); 注重算法運(yùn)用,優(yōu)化存儲(chǔ)效率與運(yùn)
2、算效率; 需提交源程序及相關(guān)文件; 2. 設(shè)計(jì)任務(wù)與分析 2.1設(shè)計(jì)題目 簡(jiǎn)單圖形處理 2.2主要內(nèi)容 只考慮點(diǎn)、直線、圓三種基本圖形。對(duì)于點(diǎn),給出點(diǎn)的橫縱坐標(biāo);對(duì)于直線,給出直線方程ax+by+c=0的三個(gè)系數(shù)a,b,c;對(duì)于圓,給出圓心坐標(biāo)和半徑。試說(shuō)明圖形的幾何形狀類型,并編寫輸入和輸出圖形數(shù)據(jù)、求兩點(diǎn)矩離、求兩直線交點(diǎn)、已知點(diǎn)和半徑形成圓、已知兩點(diǎn)形成直線等函數(shù)。 2.3任務(wù)分析 這個(gè)系統(tǒng)主要需要實(shí)現(xiàn)對(duì)求兩點(diǎn)矩離、求兩直線交點(diǎn)、已知點(diǎn)和半徑形成圓、已知兩點(diǎn)形成直線。我們可以先構(gòu)建一個(gè)主函數(shù),然后一次插入不同的功能函數(shù)。在實(shí)現(xiàn)功能函數(shù)的過(guò)程
3、中又通過(guò)菜單函數(shù)進(jìn)行各功能函數(shù)的調(diào)用。在運(yùn)用圖形處理函數(shù)的時(shí)候要用到圖形文件。 3. 設(shè)計(jì)方案 3.1模塊 (1)輸入兩點(diǎn),求出之間的距離。 (2)輸入圓心和半徑輸出一般的圓。 (3)輸入兩直線表達(dá)式X,Y的系數(shù),求出兩直線的交點(diǎn)。 (4)輸入兩點(diǎn),輸出通過(guò)該兩點(diǎn)的直線。 (5)退出。 3.2流程圖 進(jìn)入選擇菜單 輸入數(shù)字0~4 0 退出系統(tǒng) 開(kāi)始 1~兩點(diǎn)之間的距離 退出系統(tǒng) 4~ 形成直線 2~兩直線的交點(diǎn) 退出系統(tǒng) 3~ 形成圓 3.3主要函數(shù) 1.pointjl() (求兩點(diǎn)之間的距離) 2.lin
4、ejd();(求兩直線的交點(diǎn)) 3.yuan();(已知圓心和半徑形成圓) 4.line1();(已知兩點(diǎn)形成直線) 5.choice();(功能選擇) 3.4負(fù)責(zé)的模塊設(shè)計(jì) 我所負(fù)責(zé)的模塊: (1) 輸入兩直線表達(dá)式X,Y的系數(shù),求出兩直線的交點(diǎn)。 void linejd()/*求兩直線交點(diǎn)*/ { float a1,a2,b1,b2,c1,c2,x,y;/*請(qǐng)輸入直線的系數(shù)*/ printf("***********************************************************************************
5、**************************\n"); printf("請(qǐng)輸入直線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("兩直線重合,有無(wú)數(shù)個(gè)交點(diǎn)。\n"); else printf("兩直線平行,無(wú)交點(diǎn)。\n"); } else { x=(c2/b2-c1/b1)/(a1/b1-a2/b2); y=(c2/a2-c1/a1)/(b1/a1-b2/a2); printf("兩直線交點(diǎn)是 x=%f,y=%f.\n",x,y); } getchar(); } (2) 輸入兩點(diǎn),輸出通過(guò)該兩點(diǎn)的直線。 void line1() /*輸出輸入已知數(shù)據(jù)
7、的直線*/ { int x1,y1,x2,y2; int gdriver, gmode, i; printf("*********************************************************\n"); printf("請(qǐng)輸入兩點(diǎn) ,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);/*設(shè)定背景顏色為藍(lán)色*/ 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ù)的設(shè)計(jì) 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; /*求已知兩直線之間的交點(diǎn)函數(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)試 下面是進(jìn)入時(shí)出現(xiàn)的一個(gè)示例圖片。通過(guò)查找資料并以此圖來(lái)調(diào)試我們知道畫面中心的坐標(biāo)是(320,240),我們就在程序中每個(gè)輸入的橫坐標(biāo)加上320,縱坐標(biāo)加上240,以防輸入坐標(biāo)偏離中心太遠(yuǎn)導(dǎo)致顯示不理想。同時(shí)該圓的半徑是98,這樣我們就對(duì)數(shù)字
11、代表的長(zhǎng)度有了一個(gè)大概的了解。 下面是對(duì)輸出直線功能的調(diào)試。 輸入數(shù)據(jù):0,0,200,200;顯示出的圖形如下圖所示。我們可以看出,X軸正方向向左,Y軸正方向向下。為了進(jìn)一步驗(yàn)證Y軸正方向向下,我做了第二次輸入。 如下圖,此次輸入的數(shù)據(jù)為:0,0,0,-200;由此可以斷定,Y軸的正方向向下。 接下來(lái)是對(duì)求兩直線交點(diǎn)的調(diào)試。 由下圖可以看出當(dāng)輸入數(shù)據(jù)為1,2,3,3,2,1時(shí)得出交點(diǎn)為(1,-2)。對(duì)于直線x+2y+3=0與直線3x+2y+1=0,我們直接將x=1,y=-2帶入,發(fā)現(xiàn)均成立,于是所求交點(diǎn)是正確的,程序沒(méi)有問(wèn)題。 但是當(dāng)我們輸入兩條重合或者平行直線時(shí)
12、,程序給出了以下結(jié)果: 可以發(fā)現(xiàn)給出的結(jié)果為1.#INF00的字樣,這表示超出機(jī)器浮點(diǎn)類型所表示的范圍。于是我認(rèn)為程序還需改進(jìn)。 改進(jìn)后調(diào)試結(jié)果如下: 改進(jìn)成功! 下面是對(duì)選擇功能的調(diào)試。 輸入1,結(jié)果如下: 沒(méi)有問(wèn)題。 輸入2,結(jié)果如下: 沒(méi)有問(wèn)題。 輸入3,結(jié)果如下: 沒(méi)有問(wèn)題。 輸入4,結(jié)果如下: 沒(méi)有問(wèn)題。 至此,調(diào)試完畢! 5. 總結(jié)與心得 每一個(gè)簡(jiǎn)單的功能的實(shí)現(xiàn)實(shí)際上背后都有一個(gè)繁重的工程。盡管這是一個(gè)很簡(jiǎn)單的圖形的輸出、處理系統(tǒng),但是每一個(gè)函數(shù)的設(shè)計(jì)、每一個(gè)功能的實(shí)現(xiàn)都來(lái)之不易。尤其是當(dāng)每一個(gè)模塊的程序編寫好后的試運(yùn)行
13、,一個(gè)個(gè)error的尋找、改正花費(fèi)了數(shù)倍于編寫的時(shí)間。盡管編寫的過(guò)程漫長(zhǎng)、枯燥,甚至痛苦,但是當(dāng)最后程序成功運(yùn)行時(shí),興奮的心情還是立刻充斥心間,最后的成功就是對(duì)前面付出的最好回報(bào)。 通過(guò)這次實(shí)踐我也學(xué)到了很多。C語(yǔ)言的知識(shí)更加扎實(shí)、豐富,做事更加細(xì)心、耐心,還學(xué)會(huì)了如何與人合作來(lái)更快、更高效地完成任務(wù)??傊?,這次實(shí)踐中我收獲了許多,希望以后可以繼續(xù)與他人合作完成更多的任務(wù)! 6. 參考文獻(xiàn) [1] 譚浩強(qiáng). C語(yǔ)言程序設(shè)計(jì)[M].北京:清華大學(xué)出版社.2006 [2] 張高煜. C語(yǔ)言程序設(shè)計(jì)實(shí)訓(xùn).北京:中國(guó)水利出版社.2001 [3] 王曉東. C語(yǔ)言設(shè)計(jì)簡(jiǎn)明教程.北京:中國(guó)水
14、利出版社.2006
附:源代碼:
#include
15、*******************\n"); printf("請(qǐng)輸入直線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("兩直線重合,有無(wú)數(shù)個(gè)交點(diǎn)。\n"); else printf("兩直線平行,無(wú)交點(diǎn)。\n"); } else { x=(c2/b2-c1/b1)/(a1/b1-a2/b2); y=(c2/a2-c1/a1)/(b1/a1-b2/a2); printf("兩直線交點(diǎn)是 x=%f,y=%f.\n",x,y); } getchar(); } void pointjl() /*求兩點(diǎn)之間的距離*/ { int x1,y1,x2,y2
17、; float jl; printf("*********************************************************\n"); printf("請(qǐng)輸入兩點(diǎn),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("這是兩點(diǎn) 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("請(qǐng)輸入兩點(diǎn) ,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);/*設(shè)定背景顏色為藍(lán)色*/ 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("請(qǐng)輸入圓心 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("歡迎進(jìn)入簡(jiǎn)單的圖形處理系統(tǒng)!\n"); printf("*********************************************************\n"); printf("*********************************************************\n");
23、 printf("請(qǐng)輸入 1,2,3,4:\n");/*請(qǐng)輸入數(shù)字1,2,3,4*/ printf("1.兩點(diǎn)之間的距離\n");/*兩點(diǎn)之間的距離*/ printf("2.兩直線的交點(diǎn) \n");/*兩直線的交點(diǎn)*/ printf("3.已知點(diǎn)和半徑形成圓\n");/*已知點(diǎn)和半徑形成圓*/ printf("4.已知兩點(diǎn)形成直線 \n");/*已知兩點(diǎ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; /*求已知兩直線之間的交點(diǎn)函數(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;/*在進(jìn)入主菜單之前先形成一個(gè)已知圖形*/ 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: 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 雅馬哈ts-x_ts-s使用說(shuō)明課件
- 多元函數(shù)的微積分
- 商業(yè)保險(xiǎn)與社會(huì)保險(xiǎn)的區(qū)別
- HL-X6280終端培訓(xùn)手冊(cè)
- 汽車電路原理
- 通信網(wǎng)絡(luò)演進(jìn)及LTE關(guān)鍵技術(shù)教材
- 借助展業(yè)夾提升平安福簽單率廣東葉華東終稿[1]課件
- (精品)珠江國(guó)際城代管人員2
- 零售-7-11經(jīng)營(yíng)模式分析
- 電子病歷簡(jiǎn)介及門診醫(yī)生工作站[1]課件
- 食管癌術(shù)后早期營(yíng)養(yǎng)支持相關(guān)研究
- LHQ電纜層保護(hù)器相關(guān)型號(hào)列表參數(shù)
- 大腦前動(dòng)脈動(dòng)脈瘤用
- 甲真菌病各藥物特點(diǎn)教學(xué)課件
- 滑輪組機(jī)械效率