C语言图形函数(1)
副标题#e#
Turbo C提供了很是富厚的图形函数,所有图形函数的原型均在graphics. h中,本节主要先容图形模式的初始化、独立图形措施的成立、根基图形成果、图形窗口以及图形模式下的文本输出等函数。别的,利用图形函数时要确保有显示器图形驱动措施*BGI,同时将集成开拓情况Options/Linker中的Graphics lib选为on,只有这样才气担保正确利用图形函数。
1. 图形模式的初始化
差异的显示器适配器有差异的图形判别率。等于同一显示器适配器,在差异模式下也有差异判别率。因此,在屏幕作图之前,必需按照显示器适配器种类将显示器配置成为某种图形模式,在未配置图形模式之前,微机系统默认屏幕为文本模式(80列,25行字符模式),此时所有图形函数均不能事情。配置屏幕为图形模式,可用下列图形初始化函数:
void far initgraph(int far *gdriver,int far *gmode,char *path);
个中gdriver和gmode别离暗示图形驱动器和模式,path是指图形驱动措施地址的目次路径。有关图形驱动器、图形模式的标记常数及对应的判别率见表2。
图形驱动措施由Turbo C出书商提供,文件扩展名为.BGI。按照差异的图形适配器有差异的图形驱动措施。譬喻对付EGA、 VGA 图形适配器就挪用驱动措施EGAVGA.BGI。
表2. 图形驱动器、模式的标记常数及数值
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
图形驱动器(gdriver) 图形模式(gmode)
─────────── ─────────── 色调 判别率
标记常数 数值 标记常数 数值
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
CGA 1 CGAC0 0 C0 320*200
CGAC1 1 C1 320*200
CGAC2 2 C2 320*200
CGAC3 3 C3 320*200
CGAHI 4 2色 640*200
───────────────────────────────────
MCGA 2 MCGAC0 0 C0 320*200
MCGAC1 1 C1 320*200
MCGAC2 2 C2 320*200
MCGAC3 3 C3 320*200
MCGAMED 4 2色 640*200
MCGAHI 5 2色 640*480
───────────────────────────────────
EGA 3 EGALO 0 16色 640*200
EGAHI 1 16色 640*350
───────────────────────────────────
EGA64 4 EGA64LO 0 16色 640*200
EGA64HI 1 4色 640*350
───────────────────────────────────
EGAMON 5 EGAMONHI 0 2色 640*350
───────────────────────────────────
IBM8514 6 IBM8514LO 0 256色 640*480
IBM8514HI 1 256色 1024*768
───────────────────────────────────
HERC 7 HERCMONOHI 0 2色 720*348
───────────────────────────────────
ATT400 8 ATT400C0 0 C0 320*200
ATT400C1 1 C1 320*200
ATT400C2 2 C2 320*200
ATT400C3 3 C3 320*200
ATT400MED 4 2色 320*200
ATT400HI 5 2色 320*200
───────────────────────────────────
VGA 9 VGALO 0 16色 640*200
VGAMED 1 16色 640*350
VGAHI 2 16色 640*480
───────────────────────────────────
PC3270 10 PC3270HI 0 2色 720*350
───────────────────────────────────
DETECT 0 用于硬件测试
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
#p#副标题#e#
例4. 利用图形初始化函数配置VGA高判别率图形模式
#p#分页标题#e#
#include <graphics.h>
int main()
{
int gdriver,gmode;
gdriver=VGA;
gmode=VGAHI;
initgraph(&gdriver,&gmode,"c:\tc");
bar3d(100,100,300,250,50,1); /*画一长方体*/
getch();
closegraph();
return 0;
}
有时编程者并不知道所用的图形显示器适配器种类,可能需要将编写的措施用于差异图形驱动器,Turbo C提供了一个自动检测显示器硬件的函数,其挪用名目为:
void far detectgraph(int *gdriver,*gmode);
个中gdriver和gmode的意义与上面沟通。
例5. 自动举办硬件测试后举办图形初始化
#include <graphics.h>
int main()
{
int gdriver,gmode;
detectgraph(&gdriver,&gmode); /*自动测试硬件*/
printf("the graphics driver is %d,mode is %d ",gdriver,gmode); /*输出测试功效*/
getch();
initgraph(&gdriver,&gmode,"c:\tc");
/* 按照测试功效初始化图形*/
bar3d(10,10,130,250,20,1);
getch();
closegraph();
return 0;
}
上例措施中先对图形显示器自动检测,然后再用图形初始化函数举办初始化配置,但Turbo C提供了一种更简朴的要领,即用gdriver= DETECT 语句后再跟initgraph()函数就行了。回收这种要领后,上例可改为:
例6.
#include <graphics.h>
int main()
{
int gdriver=DETECT,gmode;
initgraph(&gdriver,&gmode,"c:\tc");
bar3d(50,50,150,30,1);
getch();
closegraph();
return 0;
}
别的,Turbo C提供了退出图形状态的函数closegraph(),其挪用名目为:
void far closegraph(void);
挪用该函数后可退出图形状态而进入文本方法(Turbo C 默认方法),并释放用于生存图形驱动措施和字体的系统内存。
2. 独立图形运行措施的成立
Turbo C对付用initgraph()函数直接举办的图形初始化措施,在编译和链接时并没有将相应的驱动措施(*.BGI)装入到执行措施,当措施举办到intitgraph()语句时,再从该函数中第三个形式参数char *path中所划定的路径中去找相应的驱动措施。若没有驱动措施,则在C:\TC中去找,如C:\TC中仍没有或TC不存在,将会呈现错误:
BGI Error: Graphics not initialized (use ‘initgraph’)
因此,为了利用利便,应该成立一个不需要驱动措施就能独立运行的可执行图形措施,Turbo C中划定用下述步调(这里以EGA、VGA显示器为例):
1. 在C:\TC子目次下输入呼吁:BGIOBJ EGAVGA
此呼吁将驱动措施EGAVGA.BGI转换成EGAVGA.OBJ的方针文件。
2. 在C:\TC子目次下输入呼吁:TLIB LIBGRAPHICS.LIB+EGAVGA
此呼吁的意思是将EGAVGA.OBJ的方针模块装到GRAPHICS.LIB库文件中。
3. 在措施中initgraph()函数挪用之前加上一句:
registerbgidriver(EGAVGA_driver):
该函数汇报毗连措施在毗连时把EGAVGA的驱动措施装入到用户的执行措施中。
颠末上面处理惩罚,编译链接后的执行措施可在任何目次或其它兼容机上运行。
假设已作了前两个步调,若再向例6中加 registerbgidriver()函数则酿成:
例7:
#p#分页标题#e#
#include<stdio.h>
#include<graphics.h>
int main()
{
int gdriver=DETECT,gmode;
registerbgidriver(EGAVGA_driver): / *成立独立图形运行措施 */
initgraph( gdriver,gmode,"c:\tc");
bar3d(50,50,250,150,20,1);
getch();
closegraph();
return 0;
}
上例编译链接后发生的执行措施可独立运行。
如不初始化成EGA或CGA判别率,而想初始化为CGA判别率,则只需要将上述步调中有EGAVGA的处所用CGA取代即可。
3.屏幕颜色的配置和清屏函数
对付图形模式的屏幕颜色配置,同样分为配景致的配置和前景致的配置。在Turbo C中别离用下面两个函数。
配置配景致: void far setbkcolor( int color);
配置作图色: void far setcolor(int color);
个中color 为图形方法下颜色的划定命值,对EGA,VGA显示器适配器,有关颜色的标记常数及数值见下表所示。
表3 有关屏幕颜色的标记常数表
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
标记常数 数值 寄义 标记常数 数值 寄义
───────────────────────────────────
BLACK 0 玄色 DARKGRAY 8 深灰
BLUE 1 兰色 LIGHTBLUE 9 深兰
GREEN 2 绿色 LIGHTGREEN 10 淡绿
CYAN 3 青色 LIGHTCYAN 11 淡青
RED 4 赤色 LIGHTRED 12 淡红
MAGENTA 5 洋红 LIGHTMAGENTA 13 淡洋红
BROWN 6 棕色 YELLOW 14 黄色
LIGHTGRAY 7 淡灰 WHITE 15 白色
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
对付CGA适配器,配景致可觉得表3中16种颜色的一种,但前景致依赖于差异的调色板。共有四种调色板,每种调色板上有四种颜色可供选择。差异调色板所对应的原色见表4。
表4 CGA调色板与颜色值表
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
调色板 颜色值
─────────── ──────────────────
标记常数 数值 0 1 2 3
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
C0 0 配景 绿 红 黄
C1 1 配景 青 洋红 白
C2 2 配景 淡绿 淡红 黄
C3 3 配景 淡青 淡洋红 白
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
排除图形屏幕内容利用清屏函数,其挪用名目如下:
voide far cleardevice(void);
有关颜色配置、清屏函数的利用请看例8。
例8:
#include<stdio.h>
#include<graphics.h>
int main()
{
int gdriver,gmode,i;
gdriver=DETECT;
registerbgidriver(EGAVGA_DRIVER);/*成立独立图形运行措施*/
initgraph(&gdriver,&gmode","");/*图形初始化*/
setbkcolor(0); /*配置图形配景*/
cleardevice();
for(i=0; i<=15; i++)
{
setcolor(i); /*配置差异作图色*/
circle(320,240,20+i*10); /*画半径差异的圆*/
delay(100); /*延迟100毫秒*/
}
for(i=0; i<=15; i++)
{
setbkcolor(i); /*配置差异配景致*/
cleardevice();
circle(320,240,20+i*10);
delay(100);
}
closegraph();
return 0;
}
别的,TURBO C也提供了几个得到现行颜色配置环境的函数。
int far getbkcolor(void); 返回现行配景颜色值。
int far getcolor(void); 返回现行作图颜色值。
int far getmaxcolor(void); 返回最高可用的颜色值。
4. 根基图形函数
根基图形函数包罗画点,线以及其它一些根基图形的函数。本节对这些函数作一全面的先容。
一、画点
1. 画点函数
void far putpixel(int x,int y,int color);
该函数暗示有指定的象元画一个按color所确定颜色的点。对付颜色color的值可从表3中得到而对x,y是指图形象元的坐标。
#p#分页标题#e#
在图形模式下,是按象元来界说坐标的。对VGA适配器,它的最高判别率为640×480,个中640为整个屏幕从左到右所有象元的个数,480 为整个屏幕从上到下所有象元的个数。屏幕的左上角坐标为(0,0),右下角坐标为(639,479),程度偏向从左到右为x轴正向,垂直偏向从上到下为y轴正向。TURBO C 的图形函数都是相对付图形屏幕坐标,即象元来说的。
关于点的别的一个函数是:
int far getpixel(int x,int y);
它获恰当前点(x,y)的颜色值。
2. 有关坐标位置的函数
int far getmaxx(void);
返回x轴的最大值。
int far getmaxy(void);
返回y轴的最大值。
int far getx(void);
返回游标在x轴的位置。
void far gety(void);
返回游标有y轴的位置。
void far moveto(int x,int y);
移动游标到(x,y)点,不是画点,在移动进程中亦画点。
void far moverel(int dx,int dy);
移动游标从现行位置(x,y)移动到(x+dx,y+dy)的位置,移动进程中不画点。
二、画线
1. 画线函数
TURBO C提供了一系列画线函数,下面别离论述:
void far line(int x0,int y0,int x1,int y1);
画一条从点(x0,y0)到(x1,y1)的直线。
void far lineto(int x,int y);
画一作从现行游标到点(x,y)的直线。
void far linerel(int dx,int dy);
画一条从现行游标(x,y)到按相对增量确定的点(x+dx,y+dy)的直线。
void far circle(int x,int y,int radius);
以(x,y)为圆心,radius为半径,画一个圆。
void far arc(int x,int y,int stangle,int endangle,int radius);
以(x,y)为圆心,radius为半径,从stangle开始到endangle竣事(费用暗示)画一段圆弧线。在TURBO C中划定x轴正向为0度,逆时针偏向旋转一周,依次为90,180,270和360度(其它有关函数也按此划定,不再重述)。
void ellipse(int x,int y,int stangle,int endangle,int xradius,int yradius);
以(x,y)为中心,xradius,yradius为x轴和y轴半径,从角stangle 开始到endangle竣事画一段椭圆线,当stangle=0,endangle=360时,画出一个完整的椭圆。
void far rectangle(int x1,int y1,int x2,inty2);
以(x1,y1)为左上角,(x2,y2)为右下角画一个矩形框。
void far drawpoly(int numpoints,int far *polypoints);
画一个极点数为numpoints,各极点坐标由polypoints 给出的多边形。polypoints整型数组必需至少有2倍极点数个无素。每一个极点的坐标都界说为x,y,而且x在前。值得留意的是当画一个关闭的多边形时,numpoints 的值取实际多边形的极点数加一,而且数组polypoints中第一个和最后一个点的坐标沟通。
下面举一个用drawpoly()函数画箭头的例子。
例9:
#include<stdlib.h>
#include<graphics.h>
int main()
{
int gdriver,gmode,i;
int arw[16]={200,102,300,102,300,107,330,100,300,93,300,98,200,98,200,102};
gdriver=DETECT;
registerbgidriver(EGAVGA_driver);
initgraph(&gdriver,&gmode,"");
setbkcolor(BLUE);
cleardevice();
setcolor(12); /*配置作图颜色*/
drawpoly(8,arw); /*画一箭头*/
getch();
closegraph();
return 0;
}
2. 设定线型函数
在没有对线的特性举办设定之前,TURBO C用其默认值,即一点宽的实线,但TURBO C也提供了可以改变线型的函数。线型包罗:宽度和形状。个中宽度只有两种选择: 一点宽和三点宽。而线的形状则有五种。下面先容有关线型的配置函数。
void far setlinestyle(int linestyle,unsigned upattern,int thickness);
该函数用来配置线的有关信息,个中linestyle是线形状的划定,见表5。
表5. 有关线的形状(linestyle)
━━━━━━━━━━━━━━━━━━━━━━━━━
标记常数 数值 寄义
─────────────────────────
SOLID_LINE 0 实线
DOTTED_LINE 1 点线
CENTER_LINE 2 中心线
DASHED_LINE 3 点画线
USERBIT_LINE 4 用户界说线
━━━━━━━━━━━━━━━━━━━━━━━━━
thickness是线的宽度,见表6。
#p#分页标题#e#
表6. 有关线宽(thickness)
━━━━━━━━━━━━━━━━━━━━━━━━━
标记常数 数值 寄义
─────────────────────────
NORM_WIDTH 1 一点宽
THIC_WIDTH 3 三点宽
━━━━━━━━━━━━━━━━━━━━━━━━━
对付upattern,只有linestyle选USERBIT_LINE 时才有意义( 选其它线型,uppattern取0即可)。此进uppattern的16位二进制数的每一位代表一个象元,假如那位为1,则该象元打开,不然该象元封锁。
void far getlinesettings(struct linesettingstype far *lineinfo);
该函数将有关线的信息存放到由lineinfo 指向的布局中,表中linesettingstype的布局如下:
struct linesettingstype{
int linestyle;
unsigned upattern;
int thickness;
}
譬喻下面两句措施可以读出当前线的特性
struct linesettingstype *info;
getlinesettings(info);
void far setwritemode(int mode);
该函数划定画线的方法。假如mode=0,则暗示画线时将所画位置的本来信息包围了(这是TURBO C的默认方法)。假如mode=1,则暗示画线时用此刻特性的线与所画之处原有的线举办异或(XOR)操纵,实际上画出的线是原有线与此刻划定的线举办异或后的功效。因此,当线的特性稳定,举办两次画线操纵相当于没有画线。
有关线型设定和画线函数的例子如下所示。
例10.
#include<stdlib.h>
#include<graphics.h>
int main()
{
int gdriver,gmode,i;
gdriver=DETECT;
registerbgidriver(EGAVGA_driver);
initgraph(&gdriver,&gmode,"");
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();
return 0;
}
5. 关闭图形的填充
填充就是用划定的颜色和图模填满一个关闭图形。
一、先画表面再填充
TURBO C提供了一些先画出根基图形表面,再按划定图模和颜色填充整个关闭图形的函数。在没有改变填充方法时,TURBO C以默认方法填充。下面先容这些函数。
void far bar(int x1,int y1,int x2,int y2);
确定一个以(x1,y1)为左上角,(x2,y2)为右下角的矩形窗口,再按划定图模和颜色填充。
说明: 此函数不画出边框,所以填充色为边框。
void far bar3d(int x1,int y1,int x2,int y2,int depth,int topflag);
当topflag为非0时,画出一个三维的长方体。当topflag为0时,三维图形不封顶,实际上很少这样利用。
说明: bar3d()函数中,长方体第三维的偏向不随任何参数而变,即始终为45度的偏向。
void far pieslice(int x,int y,int stangle,int endangle,int radius);
画一个以(x,y)为圆心,radius为半径,stangle为起始角度,endangle 为终止角度的扇形,再按划定方法填充。当stangle=0,endangle=360 时酿成一个实心圆,并在圆内从圆点沿X轴正向画一条半径。
void far sector(int x,int y,int stanle,intendangle,int xradius,int yradius);
画一个以(x,y)为圆心别离以xradius,yradius为x轴和y轴半径,stangle为起始角,endangle为终止角的椭圆扇形,再按划定方法填充。