




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、精選優(yōu)質(zhì)文檔-傾情為你奉上#include <graphics.h>#include <stdlib.h>#include <conio.h>#include <stdio.h>#include <dos.h>#include <bios.h>#include <math.h>#include <alloc.h>/*定義常量*/*向上翻頁移鍵*/#define PAGEUP 0x4900/*向下翻頁移鍵*/#define PAGEDOWN 0x5100/*Escape鍵*/#define ESC 0
2、x011b /*左移鍵*/#define LEFT 0x4b00/*右移鍵*/#define RIGHT 0x4d00 /*下移鍵*/#define DOWN 0x5000 /*上移鍵*/#define UP 0x4800/*空格鍵*/#define SPACE 0x3920#define NO_PRESSED 0#define LEFT_PRESSED 1#define RIGHT_PRESSED 2#define pi 3./*定義全局變量*/int Rx,Ry,R;int TOPx,TOPy,BOTTOMx,BOTTOMy;int Centx,Centy;int lineStartx,l
3、ineStarty,lineEndx,lineEndy;int linePoint_x20,linePoint_y20;/*這里的字模數(shù)組均由“點陣字模工具”生成,你可以用你自己需要的點陣信息來替換示例中的字模信息,注意字模大小要一致,否則顯示會出問題。*/char zhi16K=/* 以下是 '直' 的 16點陣楷體_GB2312 字模,32 byte */ 0x01,0x00,0x01,0x00,0x01,0xF0,0x1E,0x00, 0x02,0x00,0x07,0xC0,0x08,0x40,0x0F,0x40, 0x08,0x40,0x0F,0x40,0x08,0x4
4、0,0x0F,0x40, 0x08,0x40,0x0F,0xFC,0x70,0x00,0x00,0x00,;char xian16K=/* 以下是 '線' 的 16點陣楷體_GB2312 字模,32 byte */ 0x00,0x80,0x00,0x90,0x08,0x88,0x10,0x80, 0x24,0xF0,0x45,0x80,0x78,0xB0,0x11,0xC0, 0x2C,0x88,0x70,0x50,0x04,0x60,0x18,0xA4, 0x63,0x14,0x00,0x0C,0x00,0x04,0x00,0x00,;char ju16K=/* 以下是
5、39;矩' 的 16點陣楷體_GB2312 字模,32 byte */ 0x00,0x00,0x08,0x00,0x08,0x78,0x10,0x80, 0x1E,0x80,0x28,0xF8,0x48,0x88,0x0E,0x88, 0xF8,0xF0,0x08,0x80,0x14,0x80,0x12,0x9E, 0x20,0xE0,0x40,0x00,0x00,0x00,0x00,0x00,;char xing16K=/* 以下是 '形' 的 16點陣楷體_GB2312 字模,32 byte */ 0x00,0x00,0x07,0x88,0x3A,0x08,0x12
6、,0x10, 0x12,0x20,0x17,0x48,0xFA,0x10,0x12,0x20, 0x12,0xC8,0x12,0x08,0x22,0x10,0x42,0x20, 0x00,0x40,0x00,0x80,0x03,0x00,0x00,0x00,;char yuan16K=/* 以下是 '圓' 的 16點陣楷體_GB2312 字模,32 byte */ 0x00,0xF8,0x3F,0x08,0x23,0x88,0x24,0x88, 0x27,0x08,0x21,0xC8,0x2E,0x48,0x29,0x48, 0x29,0x48,0x22,0x88,0x24,0
7、x48,0x28,0x08, 0x3F,0xE8,0x00,0x10,0x00,0x00,0x00,0x00,;char qing16K=/* 以下是 '清' 的 16點陣楷體_GB2312 字模,32 byte */ 0x00,0x80,0x00,0xE0,0x33,0x80,0x10,0xE0, 0x03,0x80,0x40,0xFC,0x2F,0x00,0x01,0xE0, 0x12,0x20,0x13,0xA0,0x22,0x20,0x63,0xA0, 0x42,0x20,0x02,0x60,0x00,0x20,0x00,0x00,;char ping16K=/* 以下
8、是 '屏' 的 16點陣楷體_GB2312 字模,32 byte */ 0x00,0xF0,0x0F,0x30,0x08,0x60,0x0F,0x80, 0x0A,0x20,0x09,0x40,0x08,0xF8,0x17,0x20, 0x11,0x3E,0x2F,0xE0,0x21,0x20,0x42,0x20, 0x82,0x20,0x04,0x20,0x08,0x20,0x00,0x00,;char bao16K=/* 以下是 '保' 的 16點陣楷體_GB2312 字模,32 byte */ 0x00,0x00,0x09,0xF0,0x0A,0x10,0
9、x12,0x10, 0x13,0xE0,0x30,0x80,0x50,0xFC,0x9F,0x80, 0x11,0xC0,0x12,0xA0,0x14,0x98,0x18,0x8E, 0x10,0x80,0x10,0x80,0x00,0x00,0x00,0x00,;char cun16K=/* 以下是 '存' 的 16點陣楷體_GB2312 字模,32 byte */ 0x01,0x00,0x01,0x00,0x01,0xF0,0x1E,0x00, 0x02,0x70,0x05,0x90,0x08,0x20,0x08,0x40, 0x18,0x7E,0x2B,0xA0,0xC8
10、,0x20,0x08,0x20, 0x08,0x20,0x08,0xA0,0x00,0x40,0x00,0x00,;char jia16K=/* 以下是 '加' 的 16點陣楷體_GB2312 字模,32 byte */ 0x00,0x00,0x08,0x00,0x08,0x00,0x08,0x00, 0x0F,0x00,0x79,0x3C,0x09,0x44,0x11,0x44, 0x11,0x44,0x22,0x44,0x22,0x78,0x4A,0x00, 0x84,0x00,0x00,0x00,0x00,0x00,0x00,0x00,;char zai16K=/* 以下
11、是 '載' 的 16點陣楷體_GB2312 字模,32 byte */ 0x00,0x80,0x08,0xA0,0x08,0x90,0x0E,0x80, 0x38,0xF0,0x0F,0x80,0x78,0x50,0x0E,0x50, 0x34,0x20,0x1E,0x20,0x34,0x50,0x0E,0x92, 0x75,0x0A,0x04,0x06,0x04,0x02,0x00,0x00,;char bang16K=/* 以下是 '幫' 的 16點陣楷體_GB2312 字模,32 byte */ 0x04,0x00,0x07,0x38,0x1C,0x48,
12、0x06,0x50, 0x1C,0x50,0x07,0x48,0x78,0x58,0x11,0x40, 0x21,0xF0,0x4F,0x10,0x09,0x10,0x09,0x50, 0x09,0x20,0x01,0x00,0x01,0x00,0x00,0x00,;char zhu16K=/* 以下是 '助' 的 16點陣楷體_GB2312 字模,32 byte */ 0x00,0x00,0x00,0x20,0x0C,0x20,0x34,0x20, 0x24,0x20,0x34,0x38,0x25,0xC8,0x34,0x48, 0x24,0x48,0x26,0x88,0x3
13、8,0x88,0xE1,0x28, 0x02,0x10,0x04,0x00,0x00,0x00,0x00,0x00,;/*自定義函數(shù)*/void outChinese(char *mat,int matsize,int x,int y,int color);void fill(int startx,int starty,int endx,int endy,int color);void showHelp();void save();void load();int mouseStatus(int* x,int* y);int setMousePos(int x, int y);void Draw
14、Mouse(float x,float y);void DrawLine();void DrawRectangle();void LineToCircle(int x0,int y0,int r);void DrawCircle();long factorial(int n);float berFunction(int i,int n,double t);void DrawBezier();/*根據(jù)點陣信息顯示中文函數(shù)*/void outChinese(char *mat,int matsize,int x,int y,int color)/*依次:字模指針、點陣大小、起始坐標(biāo)(x,y)、顏色
15、*/ int i, j, k, n; n = (matsize - 1) / 8 + 1; for(j = 0; j < matsize; j+) for(i = 0; i < n; i+) for(k = 0;k < 8; k+) if(matj * n + i & (0x80 >> k) /*測試為1的位則顯示*/ putpixel(x + i * 8 + k, y + j, color);/*填充函數(shù)*/void fill(int startx,int starty,int endx,int endy,int color) int i,j; for(
16、i=startx;i<=endx;i+) for(j=starty;j<=endy;j+) /*在指定位置以指定顏色畫一像素*/ putpixel(i,j,color); /*顯示用戶幫助函數(shù)*/void showHelp() setcolor(14); outtextxy(45,50,"Line:"); setcolor(WHITE); outtextxy(45,50," 1 Press left button to start until to line end."); outtextxy(45,65," 2 Use UP,DO
17、WN,LEFT,RIGHT keys to move it."); outtextxy(45,80," 3 Use PAGEUP key to enlarge it, and PAGEDOWN key to shrink it."); outtextxy(45,95," 4 Use SPACE key to rotate it."); setcolor(14); outtextxy(45,120,"Rectangle:"); setcolor(WHITE); outtextxy(45,120," 1 Press l
18、eft button to start until to right corner."); outtextxy(45,135," 2 Use UP,DOWN,LEFT,RIGHT keys to move it."); outtextxy(45,150," 3 Use PAGEUP key to enlarge it, and PAGEDOWN key to shrink it."); setcolor(14); outtextxy(45,170,"Circle:"); setcolor(WHITE); outtextxy(
19、45,170," 1 Press left button to start until to end."); outtextxy(45,185," 2 Use PAGEUP key to enlarge it, and PAGEDOWN key to shrink it."); setcolor(14); outtextxy(45,205,"Bezier:"); setcolor(WHITE); outtextxy(45,205," Press left button to start, and right button t
20、o end."); outtextxy(45,230,"Press ESC key to stop the operation function."); outtextxy(45,245,"Press right button to end the drawing works."); outtextxy(45,260,"Press any key to continue."); getch(); fill(40,40,625,270,0);/*保存函數(shù)*/void save() int i,j; FILE *fp; char
21、 fileName20; fill(0,447,630,477,2); gotoxy(1,25); printf("nnnn Input the file name.dat:"); scanf("%s",fileName); fill(0,447,630,477,2); /*以讀寫的方式打開文件*/ if(fp=fopen(fileName,"w+")=NULL) outtextxy(260,455,"Failed to open file!"); exit(0); outtextxy(280,455,"
22、saving."); /*保存像素到文件*/ for(i=5;i<630;i+) for(j=30;j<=445;j+) fputc(getpixel(i,j),fp); fclose(fp); fill(0,447,630,477,2); outtextxy(260,455,"save over!"); /*打開函數(shù)*/void load() int i,j; char fileName20; FILE *fp; fill(0,447,630,477,2); gotoxy(1,25); printf("nnnn Input the file
23、 name.dat:"); scanf("%s",fileName); /*打開指定的文件*/ if(fp=fopen(fileName,"r+")!=NULL) fill(0,447,630,477,2); outtextxy(280,455,"loading."); /*從文件中讀出像素*/ for(i=5;i<630;i+) for(j=30;j<=445;j+) putpixel(i,j,fgetc(fp); fill(0,447,630,477,2); outtextxy(280,455,"l
24、oading over !"); /*打開失敗*/ else fill(0,447,630,477,2); outtextxy(260,455,"Failed to open file!"); fclose(fp);/*獲取鼠標(biāo)狀態(tài)函數(shù)*/int mouseStatus(int* x,int* y) /*定義兩個寄存器變量,分別存儲入口參數(shù)和出口參數(shù)*/ union REGS inregs,outregs; int status; status=NO_PRESSED; /*入口參數(shù)AH3,讀取鼠標(biāo)位置及其按鈕狀態(tài)*/ inregs.x.ax=3; int86(0x
25、33,&inregs,&outregs); /*CX表示水平位置,DX表示垂直位置*/ *x=outregs.x.cx; *y=outregs.x.dx; /*BX表示按鍵狀態(tài)*/ if(outregs.x.bx&1) status=LEFT_PRESSED; else if(outregs.x.bx&2) status=RIGHT_PRESSED; return (status);/*設(shè)置鼠標(biāo)指針位置函數(shù)*/int setMousePos(int x,int y) union REGS inregs,outregs; /*入口參數(shù)AH4,設(shè)置鼠標(biāo)指針位置*/
26、inregs.x.ax=4; inregs.x.cx=x; inregs.x.dx=y; int86(0x33,&inregs,&outregs);/*繪制鼠標(biāo)函數(shù)*/void DrawMouse(float x,float y) line(x,y,x+5,y+15); line(x,y,x+15,y+5); line(x+5,y+15,x+15,y+5); line(x+11,y+9,x+21,y+19); line(x+9,y+11,x+19,y+21); line(x+22,y+19,x+20,y+21);/*繪制直線函數(shù)*/void DrawLine() int x0,
27、y0,x1,y1; int last_x=0,last_y=0; int endFlag=0; int key; int temStartx,temStarty,temEndx,temEndy; int increment_x,increment_y,angle; DrawMouse(last_x,last_y); while(1) /*右鍵結(jié)束畫直線*/ while(mouseStatus(&x1,&y1)=RIGHT_PRESSED) endFlag=1; if(endFlag=1) break; /*鼠標(biāo)移動,沒有單擊,僅僅畫移動的鼠標(biāo)*/ while(mouseStat
28、us(&x1,&y1) = NO_PRESSED) if(last_x!=x1|last_y!=y1) DrawMouse(last_x,last_y); DrawMouse(x1,y1); last_x=x1; last_y=y1; /*單擊左鍵后,開始畫直線*/ if(mouseStatus(&x0,&y0)=LEFT_PRESSED) DrawMouse(last_x,last_y); line(x0,y0,x1,y1); last_x=x1; last_y=y1; /*拉動過程中,畫直線和鼠標(biāo)*/ while(mouseStatus(&x1, &
29、amp;y1)=LEFT_PRESSED) if(last_x!=x1|last_y!=y1) line(x0,y0,last_x,last_y); line(x0,y0,x1,y1); last_x=x1; last_y=y1; /*松開左鍵后,畫直線完成,記錄直線的起始位置*/ lineStartx=x0; lineStarty=y0; lineEndx=x1; lineEndy=y1; while(1) /*從鍵盤獲取鍵值,開始操作(移動、放大、縮小、旋轉(zhuǎn))直線*/ key=bioskey(0); /*ESC鍵,退出操作*/ if(key=ESC) break; /*旋轉(zhuǎn)*/ if(ke
30、y=SPACE) /*計算旋轉(zhuǎn)中心*/ /*如果直線示傾斜的*/ if(lineStarty!=lineEndy)&& (lineStartx!=lineEndx) Centx=(lineEndx-lineStartx)/2+lineStartx; Centy=(lineEndy-lineStarty)/2+lineStarty; /*如果直線是豎直的*/ if(lineStarty=lineEndy) Centx=(lineEndx-lineStartx)/2+lineStartx; Centy=lineStarty; /*如果直線是水平的*/ if(lineStartx=l
31、ineEndx) Centx=lineStartx; Centy=(lineEndy-lineStarty)/2+lineStarty; temStartx=lineStartx; temStarty=lineStarty; temEndx=lineEndx; temEndy=lineEndy; /*旋轉(zhuǎn)不能超過邊界*/ if(lineStartx>=10 && lineStarty>=40 && lineEndx <=620 && lineEndy <=445) /*清除原有的直線*/ setwritemode(XOR_
32、PUT); line(lineStartx,lineStarty,lineEndx,lineEndy); /*計算旋轉(zhuǎn)30度后的起點坐標(biāo)*/ lineStartx=(temStartx-Centx)*cos(pi/6)-(temStarty-Centy)*sin(pi/6)+Centx; lineEndx=(temEndx-Centx)*cos(pi/6)-(temEndy-Centy)*sin(pi/6)+Centx; /*計算旋轉(zhuǎn)30度后的終點坐標(biāo)*/ lineStarty=(temStartx-Centx)*sin(pi/6)+(temStarty-Centy)*cos(pi/6)+Ce
33、nty; lineEndy=(temEndx-Centx)*sin(pi/6)+(temEndy-Centy)*cos(pi/6)+Centy; temStartx=lineStartx; temStarty=lineStarty; temEndx=lineEndx; temEndy=lineEndy; /*繪制旋轉(zhuǎn)后的直線*/ line(lineStartx,lineStarty,lineEndx,lineEndy); /*左移直線*/ if(key=LEFT) if(lineStartx>=10 && lineStarty>=40 && line
34、Endx <=620 && lineEndy <=445) setwritemode(XOR_PUT); line(lineStartx,lineStarty,lineEndx,lineEndy); /*起始的橫坐標(biāo)減小*/ lineStartx-=5; lineEndx-=5; line(lineStartx,lineStarty,lineEndx,lineEndy); /*右移直線*/ if(key=RIGHT) if(lineStartx>=10 && lineStarty>=40 && lineEndx <=
35、620 && lineEndy <=445) setwritemode(XOR_PUT); line(lineStartx,lineStarty,lineEndx,lineEndy); /*起始的橫坐標(biāo)增加*/ lineStartx+=5; lineEndx+=5; line(lineStartx,lineStarty,lineEndx,lineEndy); /*下移直線*/ if(key=DOWN) if(lineStartx>=10 && lineStarty>=40 && lineEndx <=620 &&a
36、mp; lineEndy <=445) setwritemode(XOR_PUT); line(lineStartx,lineStarty,lineEndx,lineEndy); /*起始的縱坐標(biāo)增加*/ lineStarty+=5; lineEndy+=5; line(lineStartx,lineStarty,lineEndx,lineEndy); /*上移直線*/ if(key=UP) if(lineStartx>=10 && lineStarty>=40 && lineEndx <=620 && lineEndy
37、<=445) setwritemode(XOR_PUT); line(lineStartx,lineStarty,lineEndx,lineEndy); /*起始的縱坐標(biāo)減小*/ lineStarty-=5; lineEndy-=5; line(lineStartx,lineStarty,lineEndx,lineEndy); /*放大直線*/ if(key=PAGEUP) if(lineStartx>=10 && lineStarty>=40 && lineEndx <=620 && lineEndy <=445)
38、 setwritemode(XOR_PUT); line(lineStartx,lineStarty,lineEndx,lineEndy); /*如果直線是傾斜的*/ if(lineStarty!=lineEndy)&& (lineStartx!=lineEndx) /*計算直線的傾角*/ angle=atan(fabs(lineEndy-lineStarty)/(fabs(lineEndx-lineStartx); /*計算水平增量*/ increment_x=cos(angle)*2; /*計算垂直增量*/ increment_y=sin(angle)*2; /*計算放大后
39、的起始坐標(biāo)*/ if(lineStartx<lineEndx) lineStartx-=increment_x; lineStarty-=increment_y; lineEndx+=increment_x; lineEndy+=increment_y; if(lineStartx>lineEndx) lineEndx-=increment_x; lineEndy-=increment_y; lineStartx+=increment_x; lineStarty+=increment_y; /*如果直線豎直的*/ if(lineStarty=lineEndy) lineStartx
40、-=5; lineEndx+=5; /*如果直線是水平的*/ if(lineStartx=lineEndx) lineStarty-=5; lineEndy+=5; line(lineStartx,lineStarty,lineEndx,lineEndy); /*縮小直線*/ if(key=PAGEDOWN) if(lineStartx>=10 && lineStarty>=40 && lineEndx <=620 && lineEndy <=445) setwritemode(XOR_PUT); line(lineStartx,lineSt
溫馨提示
- 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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 西華大學(xué)《數(shù)值計算》2023-2024學(xué)年第二學(xué)期期末試卷
- 江陰職業(yè)技術(shù)學(xué)院《計算機(jī)操作系統(tǒng)》2023-2024學(xué)年第二學(xué)期期末試卷
- 包頭鋼鐵職業(yè)技術(shù)學(xué)院《國際會展實務(wù)》2023-2024學(xué)年第二學(xué)期期末試卷
- 鶴崗師范高等??茖W(xué)?!恫僮飨到y(tǒng)原理與應(yīng)用》2023-2024學(xué)年第二學(xué)期期末試卷
- 遼寧廣告職業(yè)學(xué)院《中小學(xué)音樂教學(xué)設(shè)計》2023-2024學(xué)年第二學(xué)期期末試卷
- 內(nèi)蒙古商貿(mào)職業(yè)學(xué)院《生化工程》2023-2024學(xué)年第二學(xué)期期末試卷
- 浙江音樂學(xué)院《管理學(xué)全英》2023-2024學(xué)年第二學(xué)期期末試卷
- 河北機(jī)電職業(yè)技術(shù)學(xué)院《國際貿(mào)易概論》2023-2024學(xué)年第二學(xué)期期末試卷
- 成都師范學(xué)院《工程測量課程設(shè)計》2023-2024學(xué)年第二學(xué)期期末試卷
- 范梅南現(xiàn)象學(xué)教育學(xué)理論體系
- 學(xué)前教育法培訓(xùn)
- 人工智能設(shè)計倫理(浙江大學(xué))知到智慧樹章節(jié)答案
- 中藥材質(zhì)量追溯管理制度
- 《結(jié)構(gòu)式家庭療法提升“喪偶式育兒”家庭親密度的個案研究》
- 公司員工手冊(最完整)
- 化學(xué)實驗室廢物處理管理制度
- 3D數(shù)字游戲藝術(shù)-3-測量分評分表-展開UV與貼圖繪制-15分
- 聯(lián)合經(jīng)營合同協(xié)議樣本
- 雅馬哈便攜式擴(kuò)聲系統(tǒng)STAGEPAS 600i使用說明書
- 2024年六西格瑪黃帶認(rèn)證考試練習(xí)題庫(含答案)
- 文藝學(xué)名著導(dǎo)讀學(xué)習(xí)通超星期末考試答案章節(jié)答案2024年
評論
0/150
提交評論