欧美精品一二区,性欧美一级,国产免费一区成人漫画,草久久久久,欧美性猛交ⅹxxx乱大交免费,欧美精品另类,香蕉视频免费播放

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

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

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

15 積分

下載資源

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

資源描述:

《C語言課程設(shè)計(jì)簡單圖形處理》由會(huì)員分享,可在線閱讀,更多相關(guān)《C語言課程設(shè)計(jì)簡單圖形處理(17頁珍藏版)》請?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)試通過; 注重算法運(yùn)用,優(yōu)化存儲(chǔ)效率與運(yùn)

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

3、中又通過菜單函數(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.2流程圖 進(jìn)入選擇菜單 輸入數(shù)字0~4 0 退出系統(tǒng) 開始 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;/*請輸入直線的系數(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ù)個(gè)交點(diǎn)。\n"); else printf("兩直線平行,無交點(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),輸出通過該兩點(diǎn)的直線。 void line1() /*輸出輸入已知數(shù)據(jù)

7、的直線*/ { int x1,y1,x2,y2; int gdriver, gmode, i; printf("*********************************************************\n"); printf("請輸入兩點(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è)示例圖片。通過查找資料并以此圖來調(diào)試我們知道畫面中心的坐標(biāo)是(320,240),我們就在程序中每個(gè)輸入的橫坐標(biāo)加上320,縱坐標(biāo)加上240,以防輸入坐標(biāo)偏離中心太遠(yuǎn)導(dǎo)致顯示不理想。同時(shí)該圓的半徑是98,這樣我們就對數(shù)字

11、代表的長度有了一個(gè)大概的了解。 下面是對輸出直線功能的調(diào)試。 輸入數(shù)據(jù):0,0,200,200;顯示出的圖形如下圖所示。我們可以看出,X軸正方向向左,Y軸正方向向下。為了進(jìn)一步驗(yàn)證Y軸正方向向下,我做了第二次輸入。 如下圖,此次輸入的數(shù)據(jù)為:0,0,0,-200;由此可以斷定,Y軸的正方向向下。 接下來是對求兩直線交點(diǎn)的調(diào)試。 由下圖可以看出當(dāng)輸入數(shù)據(jù)為1,2,3,3,2,1時(shí)得出交點(diǎn)為(1,-2)。對于直線x+2y+3=0與直線3x+2y+1=0,我們直接將x=1,y=-2帶入,發(fā)現(xiàn)均成立,于是所求交點(diǎ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)成功! 下面是對選擇功能的調(diào)試。 輸入1,結(jié)果如下: 沒有問題。 輸入2,結(jié)果如下: 沒有問題。 輸入3,結(jié)果如下: 沒有問題。 輸入4,結(jié)果如下: 沒有問題。 至此,調(diào)試完畢! 5. 總結(jié)與心得 每一個(gè)簡單的功能的實(shí)現(xiàn)實(shí)際上背后都有一個(gè)繁重的工程。盡管這是一個(gè)很簡單的圖形的輸出、處理系統(tǒng),但是每一個(gè)函數(shù)的設(shè)計(jì)、每一個(gè)功能的實(shí)現(xiàn)都來之不易。尤其是當(dāng)每一個(gè)模塊的程序編寫好后的試運(yùn)行

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

14、利出版社.2006 附:源代碼: #include #include "stdio.h" #include "math.h" #include "stdlib.h" #include "conio.h" void linejd()/*求兩直線交點(diǎn)*/ { 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ù)個(gè)交點(diǎn)。\n"); else printf("兩直線平行,無交點(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("請輸入兩點(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("請輸入兩點(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("請輸入圓心 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)入簡單的圖形處理系統(tǒng)!\n"); printf("*********************************************************\n"); printf("*********************************************************\n");

23、 printf("請輸入 1,2,3,4:\n");/*請輸入數(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: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(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ǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

相關(guān)資源

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

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

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


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