圖形函數(shù) 1. 圖形模式的初始化
創(chuàng)新互聯(lián)專注于企業(yè)成都全網(wǎng)營銷、網(wǎng)站重做改版、橋西網(wǎng)站定制設(shè)計、自適應(yīng)品牌網(wǎng)站建設(shè)、H5開發(fā)、成都做商城網(wǎng)站、集團公司官網(wǎng)建設(shè)、外貿(mào)營銷網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為橋西等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
不同的顯示器適配器有不同的圖形分辨率。即是同一顯示器適配器, 在不同
模式下也有不同分辨率。因此, 在屏幕作圖之前, 必須根據(jù)顯示器適配器種類將
顯示器設(shè)置成為某種圖形模式, 在未設(shè)置圖形模式之前, 微機系統(tǒng)默認屏幕為文
本模式(80列, 25行字符模式), 此時所有圖形函數(shù)均不能工作。設(shè)置屏幕為圖形
模式, 可用下列圖形初始化函數(shù):
void far initgraph(int far *gdriver, int far *gmode, char *path);
其中g(shù)driver和gmode分別表示圖形驅(qū)動器和模式, path是指圖形驅(qū)動程序所
在的目錄路徑。有關(guān)圖形驅(qū)動器、圖形模式的符號常數(shù)及對應(yīng)的分辨率見表2。
圖形驅(qū)動程序由Turbo C出版商提供, 文件擴展名為.BGI。根據(jù)不同的圖形
適配器有不同的圖形驅(qū)動程序。例如對于EGA、 VGA 圖形適配器就調(diào)用驅(qū)動程序
EGAVGA.BGI。 例4. 使用圖形初始化函數(shù)設(shè)置VGA高分辨率圖形模式
#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;
}
有時編程者并不知道所用的圖形顯示器適配器種類, 或者需要將編寫的程序
用于不同圖形驅(qū)動器, Turbo C提供了一個自動檢測顯示器硬件的函數(shù), 其調(diào)用
格式為:
void far detectgraph(int *gdriver, *gmode);
其中g(shù)driver和gmode的意義與上面相同。
例5. 自動進行硬件測試后進行圖形初始化
#include graphics.h
int main()
{
int gdriver, gmode;
detectgraph(gdriver, gmode); /*自動測試硬件*/
printf("the graphics driver is %d, mode is %d\n", gdriver,
gmode); /*輸出測試結(jié)果*/
getch();
initgraph(gdriver, gmode, "c:\\tc");
/* 根據(jù)測試結(jié)果初始化圖形*/
bar3d(10, 10, 130, 250, 20, 1);
getch();
closegraph();
return 0;
}
上例程序中先對圖形顯示器自動檢測, 然后再用圖形初始化函數(shù)進行初始化
設(shè)置, 但Turbo C提供了一種更簡單的方法, 即用gdriver= DETECT 語句后再跟
initgraph()函數(shù)就行了。采用這種方法后, 上例可改為:
例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提供了退出圖形狀態(tài)的函數(shù)closegraph(), 其調(diào)用格式為:
void far closegraph(void);
調(diào)用該函數(shù)后可退出圖形狀態(tài)而進入文本方式(Turbo C 默認方式), 并釋放
用于保存圖形驅(qū)動程序和字體的系統(tǒng)內(nèi)存。
2. 獨立圖形運行程序的建立
Turbo C對于用initgraph()函數(shù)直接進行的圖形初始化程序, 在編譯和鏈接
時并沒有將相應(yīng)的驅(qū)動程序(*.BGI)裝入到執(zhí)行程序, 當程序進行到intitgraph()
語句時, 再從該函數(shù)中第三個形式參數(shù)char *path中所規(guī)定的路徑中去找相應(yīng)的
驅(qū)動程序。若沒有驅(qū)動程序, 則在C:\TC中去找, 如C:\TC中仍沒有或TC不存在,
將會出現(xiàn)錯誤:
BGI Error: Graphics not initialized (use 'initgraph')
因此, 為了使用方便, 應(yīng)該建立一個不需要驅(qū)動程序就能獨立運行的可執(zhí)行
圖形程序,Turbo C中規(guī)定用下述步驟(這里以EGA、VGA顯示器為例):
1. 在C:\TC子目錄下輸入命令:BGIOBJ EGAVGA
此命令將驅(qū)動程序EGAVGA.BGI轉(zhuǎn)換成EGAVGA.OBJ的目標文件。
2. 在C:\TC子目錄下輸入命令:TLIB LIB\GRAPHICS.LIB+EGAVGA
此命令的意思是將EGAVGA.OBJ的目標模塊裝到GRAPHICS.LIB庫文件中。
3. 在程序中initgraph()函數(shù)調(diào)用之前加上一句:
registerbgidriver(EGAVGA_driver):
該函數(shù)告訴連接程序在連接時把EGAVGA的驅(qū)動程序裝入到用戶的執(zhí)行程序中。
經(jīng)過上面處理,編譯鏈接后的執(zhí)行程序可在任何目錄或其它兼容機上運行。
假設(shè)已作了前兩個步驟,若再向例6中加 registerbgidriver()函數(shù)則變成:
例7:
#includestdio.h
#includegraphics.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;
}
上例編譯鏈接后產(chǎn)生的執(zhí)行程序可獨立運行。
如不初始化成EGA或CGA分辨率, 而想初始化為CGA分辨率, 則只需要將上述
步驟中有EGAVGA的地方用CGA代替即可。
3.屏幕顏色的設(shè)置和清屏函數(shù)
對于圖形模式的屏幕顏色設(shè)置, 同樣分為背景色的設(shè)置和前景色的設(shè)置。在
Turbo C中分別用下面兩個函數(shù)。
設(shè)置背景色: void far setbkcolor( int color);
設(shè)置作圖色: void far setcolor(int color);
其中color 為圖形方式下顏色的規(guī)定數(shù)值, 對EGA, VGA顯示器適配器, 有關(guān)
顏色的符號常數(shù)及數(shù)值見下表所示。
表3 有關(guān)屏幕顏色的符號常數(shù)表
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
符號常數(shù) 數(shù)值 含義 符號常數(shù) 數(shù)值 含義
———————————————————————————————————
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種顏色的一種, 但前景色依賴于不同
的調(diào)色板。共有四種調(diào)色板, 每種調(diào)色板上有四種顏色可供選擇。不同調(diào)色板所
對應(yīng)的原色見表4。
表4 CGA調(diào)色板與顏色值表
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
調(diào)色板 顏色值
——————————— ——————————————————
符號常數(shù) 數(shù)值 0 1 2 3
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
C0 0 背景 綠 紅 黃
C1 1 背景 青 洋紅 白
C2 2 背景 淡綠 淡紅 黃
C3 3 背景 淡青 淡洋紅 白
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
清除圖形屏幕內(nèi)容使用清屏函數(shù), 其調(diào)用格式如下:
voide far cleardevice(void);
另外, TURBO C也提供了幾個獲得現(xiàn)行顏色設(shè)置情況的函數(shù)。
int far getbkcolor(void); 返回現(xiàn)行背景顏色值。
int far getcolor(void); 返回現(xiàn)行作圖顏色值。
int far getmaxcolor(void); 返回最高可用的顏色值。
4. 基本圖形函數(shù)
基本圖形函數(shù)包括畫點, 線以及其它一些基本圖形的函數(shù)。本節(jié)對這些函數(shù)
作一全面的介紹。
一、畫點
1. 畫點函數(shù)
void far putpixel(int x, int y, int color);
該函數(shù)表示有指定的象元畫一個按color所確定顏色的點。對于顏色color的
值可從表3中獲得而對x, y是指圖形象元的坐標。
在圖形模式下, 是按象元來定義坐標的。對VGA適配器, 它的最高分辨率為
640x480, 其中640為整個屏幕從左到右所有象元的個數(shù), 480 為整個屏幕從上到
下所有象元的個數(shù)。屏幕的左上角坐標為(0, 0), 右下角坐標為(639, 479), 水
平方向從左到右為x軸正向, 垂直方向從上到下為y軸正向。TURBO C 的圖形函數(shù)
都是相對于圖形屏幕坐標, 即象元來說的。
關(guān)于點的另外一個函數(shù)是:
int far getpixel(int x, int y);
它獲得當前點(x, y)的顏色值。
2. 有關(guān)坐標位置的函數(shù)
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);
移動游標從現(xiàn)行位置(x, y)移動到(x+dx, y+dy)的位置, 移動過程中不畫點。
二、畫線
1. 畫線函數(shù)
TURBO C提供了一系列畫線函數(shù), 下面分別敘述:
void far line(int x0, int y0, int x1, int y1);
畫一條從點(x0, y0)到(x1, y1)的直線。
void far lineto(int x, int y);
畫一作從現(xiàn)行游標到點(x, y)的直線。
void far linerel(int dx, int dy);
畫一條從現(xiàn)行游標(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結(jié)束(用度表示)
畫一段圓弧線。在TURBO C中規(guī)定x軸正向為0度, 逆時針方向旋轉(zhuǎn)一周, 依次為
90, 180, 270和360度(其它有關(guān)函數(shù)也按此規(guī)定, 不再重述)。
void ellipse(int x, int y, int stangle, int endangle, int xradius,
int yradius);
以(x, y)為中心, xradius, yradius為x軸和y軸半徑, 從角stangle 開始到
endangle結(jié)束畫一段橢圓線, 當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);
畫一個頂點數(shù)為numpoints, 各頂點坐標由polypoints 給出的多邊形。
polypoints整型數(shù)組必須至少有2倍頂點數(shù)個無素。每一個頂點的坐標都定義為x,
y, 并且x在前。值得注意的是當畫一個封閉的多邊形時, numpoints 的值取實際
多邊形的頂點數(shù)加一, 并且數(shù)組polypoints中第一個和最后一個點的坐標相同。
下面舉一個用drawpoly()函數(shù)畫箭頭的例子。
例9:
#includestdlib.h
#includegraphics.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); /*設(shè)置作圖顏色*/
drawpoly(8, arw); /*畫一箭頭*/
getch();
closegraph();
return 0;
}
2. 設(shè)定線型函數(shù)
在沒有對線的特性進行設(shè)定之前, TURBO C用其默認值, 即一點寬的實線,
但TURBO C也提供了可以改變線型的函數(shù)。線型包括:寬度和形狀。其中寬度只有
兩種選擇: 一點寬和三點寬。而線的形狀則有五種。下面介紹有關(guān)線型的設(shè)置函
數(shù)。
void far setlinestyle(int linestyle, unsigned upattern, int
thickness);
該函數(shù)用來設(shè)置線的有關(guān)信息, 其中l(wèi)inestyle是線形狀的規(guī)定, 見表5。
表5. 有關(guān)線的形狀(linestyle)
━━━━━━━━━━━━━━━━━━━━━━━━━
符號常數(shù) 數(shù)值 含義
—————————————————————————
SOLID_LINE 0 實線
DOTTED_LINE 1 點線
CENTER_LINE 2 中心線
DASHED_LINE 3 點畫線
USERBIT_LINE 4 用戶定義線
━━━━━━━━━━━━━━━━━━━━━━━━━
thickness是線的寬度, 見表6。
表6. 有關(guān)線寬(thickness)
━━━━━━━━━━━━━━━━━━━━━━━━━
符號常數(shù) 數(shù)值 含義
—————————————————————————
NORM_WIDTH 1 一點寬
THIC_WIDTH 3 三點寬
━━━━━━━━━━━━━━━━━━━━━━━━━
對于upattern, 只有l(wèi)inestyle選USERBIT_LINE 時才有意義( 選其它線型,
uppattern取0即可)。此進uppattern的16位二進制數(shù)的每一位代表一個象元, 如
果那位為1, 則該象元打開, 否則該象元關(guān)閉。
void far getlinesettings(struct linesettingstype far *lineinfo);
該函數(shù)將有關(guān)線的信息存放到由lineinfo 指向的結(jié)構(gòu)中, 表中
linesettingstype的結(jié)構(gòu)如下:
struct linesettingstype{
int linestyle;
unsigned upattern;
int thickness;
}
例如下面兩句程序可以讀出當前線的特性
struct linesettingstype *info;
getlinesettings(info);
void far setwritemode(int mode);
該函數(shù)規(guī)定畫線的方式。如果mode=0, 則表示畫線時將所畫位置的原來信息
覆蓋了(這是TURBO C的默認方式)。如果mode=1, 則表示畫線時用現(xiàn)在特性的線
與所畫之處原有的線進行異或(XOR)操作, 實際上畫出的線是原有線與現(xiàn)在規(guī)定
的線進行異或后的結(jié)果。因此, 當線的特性不變, 進行兩次畫線操作相當于沒有
畫線。
有關(guān)線型設(shè)定和畫線函數(shù)的例子如下所示。
例10.
#includestdlib.h
#includegraphics.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); /*設(shè)置三點寬實線*/
setcolor(2);
rectangle(220, 140, 420, 340);
setcolor(WHITE);
setlinestyle(4, 0xaaaa, 1); /*設(shè)置一點寬用戶定義線*/
line(220, 240, 420, 240);
line(320, 140, 320, 340);
getch();
closegraph();
return 0;
}
5. 封閉圖形的填充
填充就是用規(guī)定的顏色和圖模填滿一個封閉圖形。
一、先畫輪廓再填充
TURBO C提供了一些先畫出基本圖形輪廓, 再按規(guī)定圖模和顏色填充整個封
閉圖形的函數(shù)。在沒有改變填充方式時, TURBO C以默認方式填充。 下面介紹這
些函數(shù)。
void far bar(int x1, int y1, int x2, int y2);
確定一個以(x1, y1)為左上角, (x2, y2)為右下角的矩形窗口, 再按規(guī)定圖
模和顏色填充。
說明: 此函數(shù)不畫出邊框, 所以填充色為邊框。
void far bar3d(int x1, int y1, int x2, int y2, int depth, int
topflag);
當topflag為非0時, 畫出一個三維的長方體。當topflag為0時, 三維圖形不
封頂, 實際上很少這樣使用。
說明: bar3d()函數(shù)中, 長方體第三維的方向不隨任何參數(shù)而變, 即始終為
45度的方向。
void far pieslice(int x, int y, int stangle, int endangle, int
radius);
畫一個以(x, y)為圓心, radius為半徑, stangle為起始角度, endangle 為
終止角度的扇形, 再按規(guī)定方式填充。當stangle=0, endangle=360 時變成一個
實心圓, 并在圓內(nèi)從圓點沿X軸正向畫一條半徑。
void far sector(int x, int y, int stanle, intendangle, int
xradius, int yradius);
畫一個以(x, y)為圓心分別以xradius, yradius為x軸和y軸半徑, stangle
為起始角, endangle為終止角的橢圓扇形, 再按規(guī)定方式填充。
二、設(shè)定填充方式
TURBO C有四個與填充方式有關(guān)的函數(shù)。下面分別介紹:
void far setfillstyle(int pattern, int color);
color的值是當前屏幕圖形模式時顏色的有效值。pattern的值及與其等價的
符號常數(shù) 除USER_FILL(用戶定義填充式樣)以外, 其它填充式樣均可由setfillstyle()
函數(shù)設(shè)置。當選用USER_FILL時, 該函數(shù)對填充圖模和顏色不作任何改變。 之所
以定義USER_FILL主要因為在獲得有關(guān)填充信息時用到此項。
void far setfillpattern(char * upattern,int color);
設(shè)置用戶定義的填充圖模的顏色以供對封閉圖形填充。
其中upattern是一個指向8個字節(jié)的指針。這8個字節(jié)定義了8x8點陣的圖形。
每個字節(jié)的8位二進制數(shù)表示水平8點, 8個字節(jié)表示8行, 然后以此為模型向個封
閉區(qū)域填充。
void far getfillpattern(char * upattern);
該函數(shù)將用戶定義的填充圖模存入upattern指針指向的內(nèi)存區(qū)域。
void far getfillsetings(struct fillsettingstype far * fillinfo);
獲得現(xiàn)行圖模的顏色并將存入結(jié)構(gòu)指針變量fillinfo中。其中fillsettingstype
結(jié)構(gòu)定義如下:
struct fillsettingstype{
int pattern; /* 現(xiàn)行填充模式 * /
int color; /* 現(xiàn)行填充模式 * /
};
三、任意封閉圖形的填充
截止目前為止, 我們只能對一些特定形狀的封閉圖形進行填充, 但還不能對
任意封閉圖形進行填充。為此, TURBO C 提供了一個可對任意封閉圖形填充的函
數(shù), 其調(diào)用格式如下:
void far floodfill(int x, int y, int border);
其中: x, y為封閉圖形內(nèi)的任意一點。border為邊界的顏色, 也就是封閉圖
形輪廓的顏色。調(diào)用了該函數(shù)后, 將用規(guī)定的顏色和圖模填滿整個封閉圖形。例12:
#includestdlib.h
#includegraphics.h
main()
{
int gdriver, gmode;
strct fillsettingstype save;
gdriver=DETECT;
initgraph(gdriver, gmode, "");
setbkcolor(BLUE);
cleardevice();
setcolor(LIGHTRED);
setlinestyle(0,0,3);
setfillstyle(1,14); /*設(shè)置填充方式*/
bar3d(100,200,400,350,200,1); /*畫長方體并填充*/
floodfill(450,300,LIGHTRED); /*填充長方體另外兩個面*/
floodfill(250,150, LIGHTRED);
rectanle(450,400,500,450); /*畫一矩形*/
floodfill(470,420, LIGHTRED); /*填充矩形*/
getch();
closegraph();
}
6. 有關(guān)圖形窗口和圖形屏幕操作函數(shù)
一、圖形窗口操作
象文本方式下可以設(shè)定屏幕窗口一樣, 圖形方式下也可以在屏幕上某一區(qū)域
設(shè)定窗口, 只是設(shè)定的為圖形窗口而已, 其后的有關(guān)圖形操作都將以這個窗口的
左上角(0,0)作為坐標原點, 而且可為通過設(shè)置使窗口之外的區(qū)域為不可接觸。
這樣, 所有的圖形操作就被限定在窗口內(nèi)進行。
void far setviewport(int xl,int yl,int x2, int y2,int clipflag);
設(shè)定一個以(xl,yl)象元點為左上角, (x2,y2)象元為右下角的圖形窗口, 其
中x1,y1,x2,y2是相對于整個屏幕的坐標。若clipflag為非0, 則設(shè)定的圖形以外
部分不可接觸, 若clipflag為0, 則圖形窗口以外可以接觸。
void far clearviewport(void);
清除現(xiàn)行圖形窗口的內(nèi)容。
void far getviewsettings(struct viewporttype far * viewport);
獲得關(guān)于現(xiàn)行窗口的信息,并將其存于viewporttype定義的結(jié)構(gòu)變量viewport
中, 其中viewporttype的結(jié)構(gòu)說明如下:
struct viewporttype{
int left, top, right, bottom;
int cliplag;
};
二、屏幕操作
除了清屏函數(shù)以外, 關(guān)于屏幕操作還有以下函數(shù):
void far setactivepage(int pagenum);
void far setvisualpage(int pagenum);
這兩個函數(shù)只用于EGA,VGA 以及HERCULES圖形適配器。setctivepage() 函數(shù)
是為圖形輸出選擇激活頁。 所謂激活頁是指后續(xù)圖形的輸出被寫到函數(shù)選定的
pagenum頁面, 該頁面并不一定可見。setvisualpage()函數(shù)才使pagenum 所指定
的頁面變成可見頁。頁面從0開始(Turbo C默認頁)。如果先用setactivepage()
函數(shù)在不同頁面上畫出一幅幅圖像,再用setvisualpage()函數(shù)交替顯示, 就可以
實現(xiàn)一些動畫的效果。
void far getimage(int xl,int yl, int x2,int y2, void far *mapbuf);
void far putimge(int x,int,y,void * mapbuf, int op);
unsined far imagesize(int xl,int yl,int x2,int y2);
這三個函數(shù)用于將屏幕上的圖像復(fù)制到內(nèi)存,然后再將內(nèi)存中的圖像送回到
屏幕上。首先通過函數(shù)imagesize()測試要保存左上角為(xl,yl), 右上角為(x2,
y2)的圖形屏幕區(qū)域內(nèi)的全部內(nèi)容需多少個字節(jié), 然后再給mapbuf 分配一個所測
數(shù)字節(jié)內(nèi)存空間的指針。通過調(diào)用getimage()函數(shù)就可將該區(qū)域內(nèi)的圖像保存在
內(nèi)存中, 需要時可用putimage()函數(shù)將該圖像輸出到左上角為點(x, y)的位置上,
其中g(shù)etimage()函數(shù)中的參數(shù)op規(guī)定如何釋放內(nèi)存中圖像。
對于imagesize()函數(shù), 只能返回字節(jié)數(shù)小于64K字節(jié)的圖像區(qū)域, 否則將會
出錯, 出錯時返回-1。
本節(jié)介紹的函數(shù)在圖像動畫處理、菜單設(shè)計技巧中非常有用。
例13: 下面程序模擬兩個小球動態(tài)碰撞過程。
7. 圖形模式下的文本輸出
在圖形模式下, 只能用標準輸出函數(shù), 如printf(), puts(), putchar() 函
數(shù)輸出文本到屏幕。除此之外, 其它輸出函數(shù)(如窗口輸出函數(shù))不能使用, 即是
可以輸出的標準函數(shù), 也只以前景色為白色, 按80列, 25行的文本方式輸出。
Turbo C2.0也提供了一些專門用于在圖形顯示模式下的文本輸出函數(shù)。下面
將分別進行介紹。
一、文本輸出函數(shù)
void far outtext(char far *textstring);
該函數(shù)輸出字符串指針textstring所指的文本在現(xiàn)行位置。
void far outtextxy(int x, int y, char far *textstring);
該函數(shù)輸出字符串指針textstring所指的文本在規(guī)定的(x, y)位置。 其中x
和y為象元坐標。
說明:
這兩個函數(shù)都是輸出字符串, 但經(jīng)常會遇到輸出數(shù)值或其它類型的數(shù)據(jù),
此時就必須使用格式化輸出函數(shù)sprintf()。
sprintf()函數(shù)的調(diào)用格式為:
int sprintf(char *str, char *format, variable-list);
它與printf()函數(shù)不同之處是將按格式化規(guī)定的內(nèi)容寫入str 指向的字符串
中, 返回值等于寫入的字符個數(shù)。
例如:
sprintf(s, "your TOEFL score is %d", mark);
這里s應(yīng)是字符串指針或數(shù)組, mark為整型變量。
有
這些你都看看吧: (怎么用 去百度一下)
圖形和圖像函數(shù)包含在graphics.h里面
(一) 像素函數(shù)
56. putpiel() 畫像素點函數(shù)
57. getpixel()返回像素色函數(shù)
(二) 直線和線型函數(shù)
58. line() 畫線函數(shù)
59. lineto() 畫線函數(shù)
60. linerel() 相對畫線函數(shù)
61. setlinestyle() 設(shè)置線型函數(shù)
62. getlinesettings() 獲取線型設(shè)置函數(shù)
63. setwritemode() 設(shè)置畫線模式函數(shù)
(三)、多邊形函數(shù)
64. rectangle() 畫矩形函數(shù)
65. bar() 畫條函數(shù)
66. bar3d() 畫條塊函數(shù)
67. drawpoly() 畫多邊形函數(shù)
(四)、 圓、弧和曲線函數(shù)
68. getaspectratio()獲取縱橫比函數(shù)
69. circle()畫圓函數(shù)
70. arc() 畫圓弧函數(shù)
71. ellipse()畫橢圓弧函數(shù)
72. fillellipse() 畫橢圓區(qū)函數(shù)
73. pieslice() 畫扇區(qū)函數(shù)
74. sector() 畫橢圓扇區(qū)函數(shù)
75. getarccoords()獲取圓弧坐標函數(shù)
(五)、 填充函數(shù)
76. setfillstyle() 設(shè)置填充圖樣和顏色函數(shù)
77. setfillpattern() 設(shè)置用戶圖樣函數(shù)
78. floodfill() 填充閉域函數(shù)
79. fillpoly() 填充多邊形函數(shù)
80. getfillsettings() 獲取填充設(shè)置函數(shù)
81. getfillpattern() 獲取用戶圖樣設(shè)置函數(shù)
(六)、圖像函數(shù)
82. imagesize() 圖像存儲大小函數(shù)
83. getimage() 保存圖像函數(shù)
84. putimage() 輸出圖像函數(shù)
在形參是數(shù)組的情況下,只要是數(shù)組,無論維數(shù),實際上在調(diào)用函數(shù)時,傳給函數(shù)的將是一個數(shù)組的首地址,以及維數(shù)等相關(guān)信息
也就是說,在函數(shù)執(zhí)行過程中,并不會新開辟內(nèi)存空間,而是形參實參共用同一段內(nèi)存空間
所以,在這種情況下,函數(shù)內(nèi)部對數(shù)組進行修改,其值會返回給實參
你的例子中調(diào)用部分有問題,不能這樣
shuru(a[10][2])
而是
shuru(a)
因為a[10][2]代表數(shù)組a中的一個元素,而且是越界的
而a才是數(shù)組名