C語言課程設(shè)計(jì)簡(jiǎn)單圖形處理

上傳人:1777****777 文檔編號(hào):37570378 上傳時(shí)間:2021-11-03 格式:DOC 頁數(shù):17 大?。?58.32KB
收藏 版權(quán)申訴 舉報(bào) 下載
C語言課程設(shè)計(jì)簡(jiǎn)單圖形處理_第1頁
第1頁 / 共17頁
C語言課程設(shè)計(jì)簡(jiǎn)單圖形處理_第2頁
第2頁 / 共17頁
C語言課程設(shè)計(jì)簡(jiǎn)單圖形處理_第3頁
第3頁 / 共17頁

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

15 積分

下載資源

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

資源描述:

《C語言課程設(shè)計(jì)簡(jiǎn)單圖形處理》由會(huì)員分享,可在線閱讀,更多相關(guān)《C語言課程設(shè)計(jì)簡(jiǎn)單圖形處理(17頁珍藏版)》請(qǐng)?jiān)谘b配圖網(wǎng)上搜索。

1、1.課程設(shè)計(jì)總體要求22.設(shè)計(jì)任務(wù)與分析22.1設(shè)計(jì)題目22.2主要內(nèi)容22.3任務(wù)分析23.設(shè)計(jì)方案23.1模塊23.2流程圖33.3主要函數(shù)33.4負(fù)責(zé)的模塊設(shè)計(jì)34.程序調(diào)試65.總結(jié)與心得126.參考文獻(xiàn)131. 課程設(shè)計(jì)總體要求采用模塊兒化程序設(shè)計(jì); 鼓勵(lì)可視化編程; 源程序中有足夠的注釋; 學(xué)生可自行增加新功能模塊兒; 必須上機(jī)調(diào)試通過; 注重算法運(yùn)用,優(yōu)化存儲(chǔ)效率與運(yùn)算效率; 需提交源程序及相關(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+c0的三個(gè)系數(shù)a,b,c;

2、對(duì)于圓,給出圓心坐標(biāo)和半徑。試說明圖形的幾何形狀類型,并編寫輸入和輸出圖形數(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ù)的過程中又通過菜單函數(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),輸出通過該兩點(diǎn)的直線。(5)退出。3.

3、2流程圖進(jìn)入選擇菜單輸入數(shù)字040退出系統(tǒng)開始1兩點(diǎn)之間的距離退出系統(tǒng)4形成直線2兩直線的交點(diǎn)退出系統(tǒng)3形成圓3.3主要函數(shù)1.pointjl() (求兩點(diǎn)之間的距離)2.linejd();(求兩直線的交點(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(*n);printf(請(qǐng)輸入直線1 a1x

4、+b1y+c10 的系數(shù) a1,b1,c1 和直線2 a2x+b2y+c20 的系數(shù) a2,b2,c1:n); printf(*n);scanf(%f,%f,%f,%f,%f,%f,&a1,&b1,&c1,&a2,&b2,&c2);if(a1*b2=b1*a2)if(b1*c2=c1*b2)printf(兩直線重合,有無數(shù)個(gè)交點(diǎn)。n);elseprintf(兩直線平行,無交點(diǎn)。n);elsex=(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();

5、(2) 輸入兩點(diǎn),輸出通過該兩點(diǎn)的直線。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(*n);scanf(%d,%d,%d,%d,&x1,&y1,&x2,&y2);gdriver=DETECT;initgraph(&gdriver, &gmode, c:caicbgi);setbkcolor(BLUE);/*設(shè)定背景顏色為藍(lán)色*/cleardevice();setcolor(GREEN);setlinestyle(0

6、, 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 ()/*選擇函數(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

7、;break; case 4:line1();k=0;break; case 0:k=0;break; printf(*n);printf(歡迎使用該系統(tǒng)n);printf(*n);return 1;4. 程序調(diào)試下面是進(jìn)入時(shí)出現(xiàn)的一個(gè)示例圖片。通過查找資料并以此圖來調(diào)試我們知道畫面中心的坐標(biāo)是(320,240),我們就在程序中每個(gè)輸入的橫坐標(biāo)加上320,縱坐標(biāo)加上240,以防輸入坐標(biāo)偏離中心太遠(yuǎn)導(dǎo)致顯示不理想。同時(shí)該圓的半徑是98,這樣我們就對(duì)數(shù)字代表的長度有了一個(gè)大概的了解。下面是對(duì)輸出直線功能的調(diào)試。輸入數(shù)據(jù):0,0,200,200;顯示出的圖形如下圖所示。我們可以看出,X軸正方向向左,

8、Y軸正方向向下。為了進(jìn)一步驗(yàn)證Y軸正方向向下,我做了第二次輸入。如下圖,此次輸入的數(shù)據(jù)為:0,0,0,-200;由此可以斷定,Y軸的正方向向下。接下來是對(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)是正確的,程序沒有問題。但是當(dāng)我們輸入兩條重合或者平行直線時(shí),程序給出了以下結(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

9、,結(jié)果如下:沒有問題。輸入2,結(jié)果如下:沒有問題。輸入3,結(jié)果如下:沒有問題。輸入4,結(jié)果如下:沒有問題。至此,調(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)都來之不易。尤其是當(dāng)每一個(gè)模塊的程序編寫好后的試運(yùn)行,一個(gè)個(gè)error的尋找、改正花費(fèi)了數(shù)倍于編寫的時(shí)間。盡管編寫的過程漫長、枯燥,甚至痛苦,但是當(dāng)最后程序成功運(yùn)行時(shí),興奮的心情還是立刻充斥心間,最后的成功就是對(duì)前面付出的最好回報(bào)。通過這次實(shí)踐我也學(xué)到了很多。C語言的知識(shí)更加扎實(shí)、豐富,做事更加細(xì)心、耐心,還學(xué)會(huì)了如何與人合作來

10、更快、更高效地完成任務(wù)??傊@次實(shí)踐中我收獲了許多,希望以后可以繼續(xù)與他人合作完成更多的任務(wù)!6. 參考文獻(xiàn) 1 譚浩強(qiáng). C語言程序設(shè)計(jì)M.北京:清華大學(xué)出版社.20062 張高煜. C語言程序設(shè)計(jì)實(shí)訓(xùn).北京:中國水利出版社.20013 王曉東. C語言設(shè)計(jì)簡(jiǎn)明教程.北京:中國水利出版社.2006附:源代碼: #include #include stdio.h#include math.h#include stdlib.h#include conio.hvoid linejd()/*求兩直線交點(diǎn)*/float a1,a2,b1,b2,c1,c2,x,y;/*請(qǐng)輸入直線的系數(shù)*/printf

11、(*n);printf(請(qǐng)輸入直線1 a1x+b1y+c10 的系數(shù) a1,b1,c1 和直線2 a2x+b2y+c20 的系數(shù) a2,b2,c1:n); printf(*n); scanf(%f,%f,%f,%f,%f,%f,&a1,&b1,&c1,&a2,&b2,&c2);if(a1*b2=b1*a2)if(b1*c2=c1*b2)printf(兩直線重合,有無數(shù)個(gè)交點(diǎn)。n);elseprintf(兩直線平行,無交點(diǎn)。n);elsex=(c2/b2-c1/b1)/(a1/b1-a2/b2); y=(c2/a2-c1/a1)/(b1/a1-b2/a2); printf(兩直線交點(diǎn)是 x=%f

12、,y=%f.n,x,y);getchar();void pointjl() /*求兩點(diǎn)之間的距離*/int x1,y1,x2,y2; 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 , y1=%d 和 x2=%d , y2=%d 之間的距離是n jl=%fn,x1,y1,x2,y2,jl); getchar();void line1() /*輸出輸入已知

13、數(shù)據(jù)的直線*/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;initgraph(&gdriver, &gmode, c:caicbgi);setbkcolor(BLUE);/*設(shè)定背景顏色為藍(lán)色*/cleardevice();setcolor(GREEN);setlinestyle(0, 0, 3);setcolor(2);setcolor(WHITE);setli

14、nestyle(4, 0xaaaa, 1);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(*n);scanf(%d,%d,%d,&x1,&y1,&r);gdriver=DETECT;initgraph(&gdriver, &gmode, c:caicbgi);setbkcolor(BLUE);cleardevic

15、e();setcolor(GREEN);circle(x1+320, y1+240, r);setlinestyle(0, 0, 3);setcolor(2);setcolor(WHITE);setlinestyle(4, 0xaaaa, 1);getch();closegraph();void menu() /*菜單函數(shù)*/printf(*n);printf(歡迎進(jìn)入簡(jiǎn)單的圖形處理系統(tǒng)!n);printf(*n);printf(*n);printf(請(qǐng)輸入 1,2,3,4:n);/*請(qǐng)輸入數(shù)字1,2,3,4*/printf(1.兩點(diǎn)之間的距離n);/*兩點(diǎn)之間的距離*/printf(2.兩直

16、線的交點(diǎn) n);/*兩直線的交點(diǎn)*/ printf(3.已知點(diǎn)和半徑形成圓n);/*已知點(diǎn)和半徑形成圓*/ printf(4.已知兩點(diǎn)形成直線 n);/*已知兩點(diǎn)形成直線*/printf(*n);int choice ()/*選擇函數(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;

17、case 0:k=0;break; printf(*n);printf(歡迎使用該系統(tǒng)n);printf(*n);return 1;int main()int gdriver, gmode, i;/*在進(jìn)入主菜單之前先形成一個(gè)已知圖形*/gdriver=DETECT;initgraph(&gdriver, &gmode, c:caicbgi);setbkcolor(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等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
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ì)自己和他人造成任何形式的傷害或損失。

相關(guān)資源

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

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

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


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