




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
圖形學上機實驗報告專業(yè):08計科一班姓名:李旺龍學號:080104011110指導老師:楊楊薇薇完成日期:2010年11月19日
DDA畫線算法//DDA.c#include<stdio.h>#include<graphics.h>voidDDALine(intx0,inty0,intx1,inty1,intcolor){ intx; floatdx,dy,y,k; dx=x1-x0; dy=y1-y0; k=dy/dx; y=y0; for(x=x0;x<=x1;x++) { putpixel(x,(int)(y+0.5),color); y=y+k; }}voidmain(){ intgdriver,gmode; gdriver=DETECT; initgraph(&gdriver,&gmode,""); clrscr(); setbkcolor(4); DDALine(20,20,600,100,5); getchar(); closegraph();}
中點畫線算法//MIdpointline.c#include<stdio.h>#include<graphics.h>voidMidpointLine(intx0,inty0,intx1,inty1,intcolor){ inta,b,d1,d2,d,x,y; a=y0-y1; b=x1-x0; d=2*a+b; d1=2*a; d2=2*(a+b); x=x0; y=y0; putpixel(x,y,color); while(x<x1) { if(d<0) { y++; d+=d2; } else { d+=d1; } x++; putpixel(x,y,color); }}voidmain(){ intgdriver,gmode; gdriver=DETECT; initgraph(&gdriver,&gmode,""); setbkcolor(9); MidpointLine(50,10,300,250,5); getchar(); closegraph();}
Bresenham畫線算法//Bresenham.c#include<stdio.h>#include<graphics.h>voidInterBresenhamline(intx0,inty0,intx1,inty1,intcolor){ intdx,dy,x,y,e,i; dx=x1-x0; dy=y1-y0; e=-dx; x=x0; y=y0; for(i=0;i<=dx;i++) { putpixel(x,y,color); x++; e=e+2*dy; if(e>=0) { y++; e=e-2*dx; } }}voidmain(){ intgdriver,gmode; gdriver=DETECT; initgraph(&gdriver,&gmode,""); clrscr(); setbkcolor(9); InterBresenhamline(20,20,300,300,5); getchar(); closegraph();}voidmain(){ intgdriver,gmode;voidmain(){ intgdriver,gmode; gdriver=DETECT; initgraph(&gdriver,&gmode,""); clrscr(); setbkcolor(9); IntMidPointCircle(20,5); getchar(); closegraph();}中點畫圓算法//Midpointcircl.c#include<stdio.h>#include<graphics.h>voidCirclePoints(intx,inty,intcolor){ putpixel(x+200,y+200,color); putpixel(y+200,x+200,color); putpixel(-x+200,y+200,color); putpixel(y+200,-x+200,color); putpixel(x+200,-y+200,color); putpixel(-y+200,x+200,color); putpixel(-x+200,-y+200,color); putpixel(-y+200,-x+200,color);}voidIntMidPointCircle(intr,intcolor){ intx,y,d; x=0; y=r; d=1-r; CirclePoints(x,y,color); while(x<=y) { if(d<0) { d+=2*x+3; } else { d+=2*(x-y)+5; y--; } x++; CirclePoints(x,y,color); }}voidmain(){voidmain(){ intgdriver,gmode; gdriver=DETECT; initgraph(&gdriver,&gmode,""); clrscr(); setbkcolor(9); IntMidPointCircle(20,5); getchar(); closegraph();}Bresenham畫圓算法//BresenhamCircle.c#include<stdio.h>#include<graphics.h>voidCirclePoints(intx,inty,intcolor){ putpixel(x+200,y+200,color); putpixel(y+200,x+200,color); putpixel(-x+200,y+200,color); putpixel(y+200,-x+200,color); putpixel(x+200,-y+200,color); putpixel(-y+200,x+200,color); putpixel(-x+200,-y+200,color); putpixel(-y+200,-x+200,color);}voidBresenhamCircle(intr,intcolor){ intx,y,d; x=0; y=r; d=3-2*r; while(x<y) { CirclePoints(x,y,color); if(d<0) { d+=4*x+6; } else { d+=4*(x-y)+10; y--; } x++; } if(x==y) { CirclePoints(x,y,color); }}
voidMidpointLine(intx0,inty0,intx1,inty1,intcolor){voidMidpointLine(intx0,inty0,intx1,inty1,intcolor){ inta,b,d1,d2,d,x,y; a=y0-y1; b=x1-x0; d=2*a+b; d1=2*a; d2=2*(a+b); x=x0; y=y0; putpixel(x,y,color); while(x<x1) { if(d<0) { y++; d+=d2; } else { d+=d1; } x++; putpixel(x,y,color); }}voidLine(intx,inty1,inty2,intcolor){inti; for(i=y1;i<=y2;i++) { putpixel(x,i,color); }} #include<stdio.h>#include<graphics.h>voidCirclePoints(intx,inty,intcolor,intsx,intsy){ putpixel(x+sx,y+sy,color); putpixel(y+sx,x+sy,color); putpixel(-x+sx,y+sy,color); putpixel(y+sx,-x+sy,color); putpixel(x+sx,-y+sy,color); putpixel(-y+sx,x+sy,color); putpixel(-x+sx,-y+sy,color); putpixel(-y+sx,-x+sy,color);}voidIntMidPointCircle(intr,intcolor,intsx,intsy){ intx,y,d; x=0; y=r; d=1-r; CirclePoints(x,y,color,sx,sy); while(x<=y) { if(d<0) { d+=2*x+3; } else { d+=2*(x-y)+5; y--; } x++; CirclePoints(x,y,color,sx,sy); }} 動畫設(shè)計:我設(shè)計的動畫程序是有兩個小球在一個矩形內(nèi)運動,當碰到矩形的邊框的時候會反彈,運動一定的時間后停止voidmain()voidmain(){ intgdriver,gmode,sx1=400,sy1=120,sx2=100,sy2=100,i,j,dx1=-20,dy1=-10,dx2=15,dy2=20; longintn=0; gdriver=DETECT; initgraph(&gdriver,&gmode,""); clrscr(); setbkcolor(9); while(n<100) { clrscr(); //畫矩形 MidpointLine(50,10,550,10,5); MidpointLine(50,350,550,350,5); Line(50,10,350,5); Line(550,10,350,5); //畫圓IntMidPointCircle(10,10,sx1,sy1);IntMidPointCircle(5,4,sx2,sy2);//延時 for(i=0;i<10000;i++) { for(j=0;j<7000;j++) { } }//判斷是否到達邊界,到達邊界移動方//向反向 if(sx1>530||sx1<70) { dx1=-dx1; } sx1=sx1+dx1; if(sy1>330||sy1<30) { dy1=-dy1; } sy1=sy1+dy1;if(sx2>530||sx2<70) { dx2=-dx2; } sx2=sx2+dx2; if(sy2>330||sy2<30) { dy2=-dy2; } sy2=sy2+dy2; n++; } getchar(); closegraph();}
實驗心得:經(jīng)過本次圖形學上機實驗,我對各種畫
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 江蘇省濱??h聯(lián)考2025年高中畢業(yè)生第二次復習統(tǒng)一檢測試題生物試題含解析
- 山西省晉城市2024-2025學年初三下學期階段性測試(四)英語試題含答案
- 江蘇省江都國際校2024-2025學年初三考前模擬(一)生物試題含解析
- 合同代理與售后服務(wù)2025年
- 山東省濟南市商河縣2024-2025學年初三第一次(5月)聯(lián)考物理試題理試題含解析
- 智慧農(nóng)業(yè)農(nóng)業(yè)科技園區(qū)的未來方向
- 江蘇省南通市海安市十校聯(lián)考2024-2025學年初三下學期周練九生物試題含解析
- 住宅購房誠意金合同正式版
- 版?zhèn)€人住宅租賃合同
- 四川省瀘州市合江縣2024-2025學年七年級下學期期中考試地理試題(含答案)
- 新教科版五下科學1.5《當環(huán)境改變了》教學設(shè)計
- 鄭州工業(yè)應(yīng)用技術(shù)學院單招《職測》參考試題庫(含答案)
- 提醒納米顆粒對環(huán)境的影響
- 血液科護士的造血干細胞移植護理
- HGE系列電梯安裝調(diào)試手冊(ELS05系統(tǒng)SW00004269,A.4 )
- 護理教學查房組織與實施
- 小學五年級家長會課件
- 機動車檢測站儀器設(shè)備日常維護和保養(yǎng)作業(yè)指導書
- 立式數(shù)控銑床工作臺(X軸)設(shè)計
- 萬千心理情緒障礙跨診斷治療的統(tǒng)一方案:治療師指南
- 藏毛竇護理業(yè)務(wù)查房課件
評論
0/150
提交評論