




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、-作者xxxx-日期xxxx畫圖軟件C程序代碼【精品文檔】#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
2、鍵*/#define ESC 0x011b /*左移鍵*/#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 25926/*定義全局變量*/int Rx,Ry,R;int TOPx,TOPy,BOTTOMx,BOTTOMy;int Centx,Centy;int lineS
3、tartx,lineStarty,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,0
4、x08,0x40,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、 以下是 '矩' 的 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,0x
6、08,0x12,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
7、,0x24,0x48,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 ping16
8、K=/* 以下是 '屏' 的 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
9、,0x10,0x12,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,0x
10、A0,0xC8,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 zai16
11、K=/* 以下是 '載' 的 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,0x1
12、C,0x48,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,0
13、x88,0x38,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);vo
14、id DrawMouse(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)/*依次:字模指針、點陣大小、起始坐標(
15、x,y)、顏色*/ 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,
16、j; for(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 Us
17、e UP,DOWN,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
18、Press left 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); out
19、textxy(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 b
20、utton to 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 *f
21、p; char 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 t
23、he file 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,
24、"loading over !"); /*打開失敗*/ else fill(0,447,630,477,2); outtextxy(260,455,"Failed to open file!"); fclose(fp);/*獲取鼠標狀態(tài)函數(shù)*/int mouseStatus(int* x,int* y) /*定義兩個寄存器變量,分別存儲入口參數(shù)和出口參數(shù)*/ union REGS inregs,outregs; int status; status=NO_PRESSED; /*入口參數(shù)AH3,讀取鼠標位置及其按鈕狀態(tài)*/ inregs.x.ax=3; i
25、nt86(0x33,&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è)置鼠標指針位置函數(shù)*/int setMousePos(int x,int y) union REGS inregs,outregs; /*入口參數(shù)AH4,設(shè)置鼠標
26、指針位置*/ inregs.x.ax=4; inregs.x.cx=x; inregs.x.dx=y; int86(0x33,&inregs,&outregs);/*繪制鼠標函數(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()
27、int x0,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; /*鼠標移動,沒有單擊,僅僅畫移動的鼠標*/ while(mo
28、useStatus(&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; /*拉動過程中,畫直線和鼠標*/ while(mouseStatus(&am
29、p;x1, &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)*
30、/ if(key=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(lineS
31、tartx=lineEndx) 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) /*清除原有的直線*/ setwritemo
32、de(XOR_PUT); line(lineStartx,lineStarty,lineEndx,lineEndy); /*計算旋轉(zhuǎn)30度后的起點坐標*/ 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度后的終點坐標*/ lineStarty=(temStartx-Centx)*sin(pi/6)+(temStarty-Centy)*cos(p
33、i/6)+Centy; 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 &&am
34、p; lineEndx <=620 && lineEndy <=445) setwritemode(XOR_PUT); line(lineStartx,lineStarty,lineEndx,lineEndy); /*起始的橫坐標減小*/ lineStartx-=5; lineEndx-=5; line(lineStartx,lineStarty,lineEndx,lineEndy); /*右移直線*/ if(key=RIGHT) if(lineStartx>=10 && lineStarty>=40 && lineEnd
35、x <=620 && lineEndy <=445) setwritemode(XOR_PUT); line(lineStartx,lineStarty,lineEndx,lineEndy); /*起始的橫坐標增加*/ lineStartx+=5; lineEndx+=5; line(lineStartx,lineStarty,lineEndx,lineEndy); /*下移直線*/ if(key=DOWN) if(lineStartx>=10 && lineStarty>=40 && lineEndx <=620
36、&& lineEndy <=445) setwritemode(XOR_PUT); line(lineStartx,lineStarty,lineEndx,lineEndy); /*起始的縱坐標增加*/ lineStarty+=5; lineEndy+=5; line(lineStartx,lineStarty,lineEndx,lineEndy); /*上移直線*/ if(key=UP) if(lineStartx>=10 && lineStarty>=40 && lineEndx <=620 && li
37、neEndy <=445) setwritemode(XOR_PUT); line(lineStartx,lineStarty,lineEndx,lineEndy); /*起始的縱坐標減小*/ lineStarty-=5; lineEndy-=5; line(lineStartx,lineStarty,lineEndx,lineEndy); /*放大直線*/ if(key=PAGEUP) if(lineStartx>=10 && lineStarty>=40 && lineEndx <=620 && lineEndy &l
38、t;=445) 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、/*計算放大后的起始坐標*/ 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-=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
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- T-ZSM 0057-2024“領(lǐng)跑者”評價技術(shù)要求 石油、石化及相關(guān)工業(yè)用的鋼制球閥
- T-ZJZYC 010-2024 中藥材產(chǎn)業(yè)合規(guī)管理規(guī)范
- 二零二五年度個人向新能源車輛制造商借款購買電動車的合同
- 歷年合同法司考備考輔導班師資聘用合同2025年度
- 2025年度集體土地租賃與特色小鎮(zhèn)建設(shè)合同
- 二零二五年度互聯(lián)網(wǎng)廣告聯(lián)盟合作協(xié)議合同
- 2025年度砂石場勞務(wù)人員薪酬及福利待遇合同
- 二零二五年度網(wǎng)紅獨家經(jīng)紀合作協(xié)議模板
- 二零二五年度電子商務(wù)平臺支付清算合同范本
- 新能源汽車項目買賣合同
- 國企治理三會一層詳解
- 公司企業(yè)生產(chǎn)安全事故應急預案演練計劃
- 人教鄂教版科學六年級下冊全冊教案
- 鋁合金鑄造基礎(chǔ)知識(課堂PPT)
- 診斷學課件:臨床常用免疫學檢測
- jw甲級設(shè)計院十六層醫(yī)院綜合樓全套電氣施工圖紙103張含多大樣圖
- 港股通開戶測評答案
- 廣東專插本高等數(shù)學真題
- 云南省普通初中學生成長記錄
- 仿真技術(shù)在車架防腐性能開發(fā)中的應用
- 初一平面直角坐標系集體備課
評論
0/150
提交評論