真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

c語言改函數(shù)結(jié)構(gòu)圖,c語言算法結(jié)構(gòu)圖

關(guān)于C語言中函數(shù)修改結(jié)構(gòu)體的值的問題

這個(gè)就是實(shí)參和形參的問題。

公司主營業(yè)務(wù):做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)、移動(dòng)網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。成都創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會用頭腦與智慧不斷的給客戶帶來驚喜。成都創(chuàng)新互聯(lián)推出邯山免費(fèi)做網(wǎng)站回饋大家。

可以直接傳入指針。

你說的typedef成指針是一種方式。

也可以還是typedef

struct

xxx

List;

然后傳入List*類型的參數(shù)。

效果是一樣的。

c語言函數(shù)的一般結(jié)構(gòu)形式

返回值類型函數(shù)名(參數(shù)1類型 參數(shù)1變量名,參數(shù)2類型 參數(shù)2變量名,...,參數(shù)n類型 參數(shù)n變量名) { 函數(shù)體 }

c語言 圖形函數(shù)

圖形函數(shù) 1. 圖形模式的初始化

不同的顯示器適配器有不同的圖形分辨率。即是同一顯示器適配器, 在不同

模式下也有不同分辨率。因此, 在屏幕作圖之前, 必須根據(jù)顯示器適配器種類將

顯示器設(shè)置成為某種圖形模式, 在未設(shè)置圖形模式之前, 微機(jī)系統(tǒng)默認(rèn)屏幕為文

本模式(80列, 25行字符模式), 此時(shí)所有圖形函數(shù)均不能工作。設(shè)置屏幕為圖形

模式, 可用下列圖形初始化函數(shù):

void far initgraph(int far *gdriver, int far *gmode, char *path);

其中g(shù)driver和gmode分別表示圖形驅(qū)動(dòng)器和模式, path是指圖形驅(qū)動(dòng)程序所

在的目錄路徑。有關(guān)圖形驅(qū)動(dòng)器、圖形模式的符號常數(shù)及對應(yīng)的分辨率見表2。

圖形驅(qū)動(dòng)程序由Turbo C出版商提供, 文件擴(kuò)展名為.BGI。根據(jù)不同的圖形

適配器有不同的圖形驅(qū)動(dòng)程序。例如對于EGA、 VGA 圖形適配器就調(diào)用驅(qū)動(dòng)程序

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;

}

有時(shí)編程者并不知道所用的圖形顯示器適配器種類, 或者需要將編寫的程序

用于不同圖形驅(qū)動(dòng)器, Turbo C提供了一個(gè)自動(dòng)檢測顯示器硬件的函數(shù), 其調(diào)用

格式為:

void far detectgraph(int *gdriver, *gmode);

其中g(shù)driver和gmode的意義與上面相同。

例5. 自動(dòng)進(jìn)行硬件測試后進(jìn)行圖形初始化

#include graphics.h

int main()

{

int gdriver, gmode;

detectgraph(gdriver, gmode); /*自動(dòng)測試硬件*/

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;

}

上例程序中先對圖形顯示器自動(dòng)檢測, 然后再用圖形初始化函數(shù)進(jìn)行初始化

設(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)而進(jìn)入文本方式(Turbo C 默認(rèn)方式), 并釋放

用于保存圖形驅(qū)動(dòng)程序和字體的系統(tǒng)內(nèi)存。

2. 獨(dú)立圖形運(yùn)行程序的建立

Turbo C對于用initgraph()函數(shù)直接進(jìn)行的圖形初始化程序, 在編譯和鏈接

時(shí)并沒有將相應(yīng)的驅(qū)動(dòng)程序(*.BGI)裝入到執(zhí)行程序, 當(dāng)程序進(jìn)行到intitgraph()

語句時(shí), 再從該函數(shù)中第三個(gè)形式參數(shù)char *path中所規(guī)定的路徑中去找相應(yīng)的

驅(qū)動(dòng)程序。若沒有驅(qū)動(dòng)程序, 則在C:\TC中去找, 如C:\TC中仍沒有或TC不存在,

將會出現(xiàn)錯(cuò)誤:

BGI Error: Graphics not initialized (use 'initgraph')

因此, 為了使用方便, 應(yīng)該建立一個(gè)不需要驅(qū)動(dòng)程序就能獨(dú)立運(yùn)行的可執(zhí)行

圖形程序,Turbo C中規(guī)定用下述步驟(這里以EGA、VGA顯示器為例):

1. 在C:\TC子目錄下輸入命令:BGIOBJ EGAVGA

此命令將驅(qū)動(dòng)程序EGAVGA.BGI轉(zhuǎn)換成EGAVGA.OBJ的目標(biāo)文件。

2. 在C:\TC子目錄下輸入命令:TLIB LIB\GRAPHICS.LIB+EGAVGA

此命令的意思是將EGAVGA.OBJ的目標(biāo)模塊裝到GRAPHICS.LIB庫文件中。

3. 在程序中initgraph()函數(shù)調(diào)用之前加上一句:

registerbgidriver(EGAVGA_driver):

該函數(shù)告訴連接程序在連接時(shí)把EGAVGA的驅(qū)動(dòng)程序裝入到用戶的執(zhí)行程序中。

經(jīng)過上面處理,編譯鏈接后的執(zhí)行程序可在任何目錄或其它兼容機(jī)上運(yùn)行。

假設(shè)已作了前兩個(gè)步驟,若再向例6中加 registerbgidriver()函數(shù)則變成:

例7:

#includestdio.h

#includegraphics.h

int main()

{

int gdriver=DETECT,gmode;

registerbgidriver(EGAVGA_driver): / *建立獨(dú)立圖形運(yùn)行程序 */

initgraph( gdriver, gmode,"c:\\tc");

bar3d(50,50,250,150,20,1);

getch();

closegraph();

return 0;

}

上例編譯鏈接后產(chǎn)生的執(zhí)行程序可獨(dú)立運(yùn)行。

如不初始化成EGA或CGA分辨率, 而想初始化為CGA分辨率, 則只需要將上述

步驟中有EGAVGA的地方用CGA代替即可。

3.屏幕顏色的設(shè)置和清屏函數(shù)

對于圖形模式的屏幕顏色設(shè)置, 同樣分為背景色的設(shè)置和前景色的設(shè)置。在

Turbo C中分別用下面兩個(gè)函數(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也提供了幾個(gè)獲得現(xiàn)行顏色設(shè)置情況的函數(shù)。

int far getbkcolor(void); 返回現(xiàn)行背景顏色值。

int far getcolor(void); 返回現(xiàn)行作圖顏色值。

int far getmaxcolor(void); 返回最高可用的顏色值。

4. 基本圖形函數(shù)

基本圖形函數(shù)包括畫點(diǎn), 線以及其它一些基本圖形的函數(shù)。本節(jié)對這些函數(shù)

作一全面的介紹。

一、畫點(diǎn)

1. 畫點(diǎn)函數(shù)

void far putpixel(int x, int y, int color);

該函數(shù)表示有指定的象元畫一個(gè)按color所確定顏色的點(diǎn)。對于顏色color的

值可從表3中獲得而對x, y是指圖形象元的坐標(biāo)。

在圖形模式下, 是按象元來定義坐標(biāo)的。對VGA適配器, 它的最高分辨率為

640x480, 其中640為整個(gè)屏幕從左到右所有象元的個(gè)數(shù), 480 為整個(gè)屏幕從上到

下所有象元的個(gè)數(shù)。屏幕的左上角坐標(biāo)為(0, 0), 右下角坐標(biāo)為(639, 479), 水

平方向從左到右為x軸正向, 垂直方向從上到下為y軸正向。TURBO C 的圖形函數(shù)

都是相對于圖形屏幕坐標(biāo), 即象元來說的。

關(guān)于點(diǎn)的另外一個(gè)函數(shù)是:

int far getpixel(int x, int y);

它獲得當(dāng)前點(diǎn)(x, y)的顏色值。

2. 有關(guān)坐標(biāo)位置的函數(shù)

int far getmaxx(void);

返回x軸的最大值。

int far getmaxy(void);

返回y軸的最大值。

int far getx(void);

返回游標(biāo)在x軸的位置。

void far gety(void);

返回游標(biāo)有y軸的位置。

void far moveto(int x, int y);

移動(dòng)游標(biāo)到(x, y)點(diǎn), 不是畫點(diǎn), 在移動(dòng)過程中亦畫點(diǎn)。

void far moverel(int dx, int dy);

移動(dòng)游標(biāo)從現(xiàn)行位置(x, y)移動(dòng)到(x+dx, y+dy)的位置, 移動(dòng)過程中不畫點(diǎn)。

二、畫線

1. 畫線函數(shù)

TURBO C提供了一系列畫線函數(shù), 下面分別敘述:

void far line(int x0, int y0, int x1, int y1);

畫一條從點(diǎn)(x0, y0)到(x1, y1)的直線。

void far lineto(int x, int y);

畫一作從現(xiàn)行游標(biāo)到點(diǎn)(x, y)的直線。

void far linerel(int dx, int dy);

畫一條從現(xiàn)行游標(biāo)(x, y)到按相對增量確定的點(diǎn)(x+dx, y+dy)的直線。

void far circle(int x, int y, int radius);

以(x, y)為圓心, radius為半徑, 畫一個(gè)圓。

void far arc(int x, int y, int stangle, int endangle, int radius);

以(x, y)為圓心, radius為半徑, 從stangle開始到endangle結(jié)束(用度表示)

畫一段圓弧線。在TURBO C中規(guī)定x軸正向?yàn)?度, 逆時(shí)針方向旋轉(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é)束畫一段橢圓線, 當(dāng)stangle=0, endangle=360時(shí), 畫出一個(gè)完整的

橢圓。

void far rectangle(int x1, int y1, int x2, inty2);

以(x1, y1)為左上角, (x2, y2)為右下角畫一個(gè)矩形框。

void far drawpoly(int numpoints, int far *polypoints);

畫一個(gè)頂點(diǎn)數(shù)為numpoints, 各頂點(diǎn)坐標(biāo)由polypoints 給出的多邊形。

polypoints整型數(shù)組必須至少有2倍頂點(diǎn)數(shù)個(gè)無素。每一個(gè)頂點(diǎn)的坐標(biāo)都定義為x,

y, 并且x在前。值得注意的是當(dāng)畫一個(gè)封閉的多邊形時(shí), numpoints 的值取實(shí)際

多邊形的頂點(diǎn)數(shù)加一, 并且數(shù)組polypoints中第一個(gè)和最后一個(gè)點(diǎn)的坐標(biāo)相同。

下面舉一個(gè)用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ù)

在沒有對線的特性進(jìn)行設(shè)定之前, TURBO C用其默認(rèn)值, 即一點(diǎn)寬的實(shí)線,

但TURBO C也提供了可以改變線型的函數(shù)。線型包括:寬度和形狀。其中寬度只有

兩種選擇: 一點(diǎn)寬和三點(diǎn)寬。而線的形狀則有五種。下面介紹有關(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 實(shí)線

DOTTED_LINE 1 點(diǎn)線

CENTER_LINE 2 中心線

DASHED_LINE 3 點(diǎn)畫線

USERBIT_LINE 4 用戶定義線

━━━━━━━━━━━━━━━━━━━━━━━━━

thickness是線的寬度, 見表6。

表6. 有關(guān)線寬(thickness)

━━━━━━━━━━━━━━━━━━━━━━━━━

符號常數(shù) 數(shù)值 含義

—————————————————————————

NORM_WIDTH 1 一點(diǎn)寬

THIC_WIDTH 3 三點(diǎn)寬

━━━━━━━━━━━━━━━━━━━━━━━━━

對于upattern, 只有l(wèi)inestyle選USERBIT_LINE 時(shí)才有意義( 選其它線型,

uppattern取0即可)。此進(jìn)uppattern的16位二進(jìn)制數(shù)的每一位代表一個(gè)象元, 如

果那位為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;

}

例如下面兩句程序可以讀出當(dāng)前線的特性

struct linesettingstype *info;

getlinesettings(info);

void far setwritemode(int mode);

該函數(shù)規(guī)定畫線的方式。如果mode=0, 則表示畫線時(shí)將所畫位置的原來信息

覆蓋了(這是TURBO C的默認(rèn)方式)。如果mode=1, 則表示畫線時(shí)用現(xiàn)在特性的線

與所畫之處原有的線進(jìn)行異或(XOR)操作, 實(shí)際上畫出的線是原有線與現(xiàn)在規(guī)定

的線進(jìn)行異或后的結(jié)果。因此, 當(dāng)線的特性不變, 進(jìn)行兩次畫線操作相當(dāng)于沒有

畫線。

有關(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è)置三點(diǎn)寬實(shí)線*/

setcolor(2);

rectangle(220, 140, 420, 340);

setcolor(WHITE);

setlinestyle(4, 0xaaaa, 1); /*設(shè)置一點(diǎn)寬用戶定義線*/

line(220, 240, 420, 240);

line(320, 140, 320, 340);

getch();

closegraph();

return 0;

}

5. 封閉圖形的填充

填充就是用規(guī)定的顏色和圖模填滿一個(gè)封閉圖形。

一、先畫輪廓再填充

TURBO C提供了一些先畫出基本圖形輪廓, 再按規(guī)定圖模和顏色填充整個(gè)封

閉圖形的函數(shù)。在沒有改變填充方式時(shí), TURBO C以默認(rèn)方式填充。 下面介紹這

些函數(shù)。

void far bar(int x1, int y1, int x2, int y2);

確定一個(gè)以(x1, y1)為左上角, (x2, y2)為右下角的矩形窗口, 再按規(guī)定圖

模和顏色填充。

說明: 此函數(shù)不畫出邊框, 所以填充色為邊框。

void far bar3d(int x1, int y1, int x2, int y2, int depth, int

topflag);

當(dāng)topflag為非0時(shí), 畫出一個(gè)三維的長方體。當(dāng)topflag為0時(shí), 三維圖形不

封頂, 實(shí)際上很少這樣使用。

說明: bar3d()函數(shù)中, 長方體第三維的方向不隨任何參數(shù)而變, 即始終為

45度的方向。

void far pieslice(int x, int y, int stangle, int endangle, int

radius);

畫一個(gè)以(x, y)為圓心, radius為半徑, stangle為起始角度, endangle 為

終止角度的扇形, 再按規(guī)定方式填充。當(dāng)stangle=0, endangle=360 時(shí)變成一個(gè)

實(shí)心圓, 并在圓內(nèi)從圓點(diǎn)沿X軸正向畫一條半徑。

void far sector(int x, int y, int stanle, intendangle, int

xradius, int yradius);

畫一個(gè)以(x, y)為圓心分別以xradius, yradius為x軸和y軸半徑, stangle

為起始角, endangle為終止角的橢圓扇形, 再按規(guī)定方式填充。

二、設(shè)定填充方式

TURBO C有四個(gè)與填充方式有關(guān)的函數(shù)。下面分別介紹:

void far setfillstyle(int pattern, int color);

color的值是當(dāng)前屏幕圖形模式時(shí)顏色的有效值。pattern的值及與其等價(jià)的

符號常數(shù) 除USER_FILL(用戶定義填充式樣)以外, 其它填充式樣均可由setfillstyle()

函數(shù)設(shè)置。當(dāng)選用USER_FILL時(shí), 該函數(shù)對填充圖模和顏色不作任何改變。 之所

以定義USER_FILL主要因?yàn)樵讷@得有關(guān)填充信息時(shí)用到此項(xiàng)。

void far setfillpattern(char * upattern,int color);

設(shè)置用戶定義的填充圖模的顏色以供對封閉圖形填充。

其中upattern是一個(gè)指向8個(gè)字節(jié)的指針。這8個(gè)字節(jié)定義了8x8點(diǎn)陣的圖形。

每個(gè)字節(jié)的8位二進(jìn)制數(shù)表示水平8點(diǎn), 8個(gè)字節(jié)表示8行, 然后以此為模型向個(gè)封

閉區(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)行填充模式 * /

};

三、任意封閉圖形的填充

截止目前為止, 我們只能對一些特定形狀的封閉圖形進(jìn)行填充, 但還不能對

任意封閉圖形進(jìn)行填充。為此, TURBO C 提供了一個(gè)可對任意封閉圖形填充的函

數(shù), 其調(diào)用格式如下:

void far floodfill(int x, int y, int border);

其中: x, y為封閉圖形內(nèi)的任意一點(diǎn)。border為邊界的顏色, 也就是封閉圖

形輪廓的顏色。調(diào)用了該函數(shù)后, 將用規(guī)定的顏色和圖模填滿整個(gè)封閉圖形。例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); /*填充長方體另外兩個(gè)面*/

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)圖形操作都將以這個(gè)窗口的

左上角(0,0)作為坐標(biāo)原點(diǎn), 而且可為通過設(shè)置使窗口之外的區(qū)域?yàn)椴豢山佑|。

這樣, 所有的圖形操作就被限定在窗口內(nèi)進(jìn)行。

void far setviewport(int xl,int yl,int x2, int y2,int clipflag);

設(shè)定一個(gè)以(xl,yl)象元點(diǎn)為左上角, (x2,y2)象元為右下角的圖形窗口, 其

中x1,y1,x2,y2是相對于整個(gè)屏幕的坐標(biāo)。若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);

這兩個(gè)函數(shù)只用于EGA,VGA 以及HERCULES圖形適配器。setctivepage() 函數(shù)

是為圖形輸出選擇激活頁。 所謂激活頁是指后續(xù)圖形的輸出被寫到函數(shù)選定的

pagenum頁面, 該頁面并不一定可見。setvisualpage()函數(shù)才使pagenum 所指定

的頁面變成可見頁。頁面從0開始(Turbo C默認(rèn)頁)。如果先用setactivepage()

函數(shù)在不同頁面上畫出一幅幅圖像,再用setvisualpage()函數(shù)交替顯示, 就可以

實(shí)現(xiàn)一些動(dòng)畫的效果。

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);

這三個(gè)函數(shù)用于將屏幕上的圖像復(fù)制到內(nèi)存,然后再將內(nèi)存中的圖像送回到

屏幕上。首先通過函數(shù)imagesize()測試要保存左上角為(xl,yl), 右上角為(x2,

y2)的圖形屏幕區(qū)域內(nèi)的全部內(nèi)容需多少個(gè)字節(jié), 然后再給mapbuf 分配一個(gè)所測

數(shù)字節(jié)內(nèi)存空間的指針。通過調(diào)用getimage()函數(shù)就可將該區(qū)域內(nèi)的圖像保存在

內(nèi)存中, 需要時(shí)可用putimage()函數(shù)將該圖像輸出到左上角為點(diǎn)(x, y)的位置上,

其中g(shù)etimage()函數(shù)中的參數(shù)op規(guī)定如何釋放內(nèi)存中圖像。

對于imagesize()函數(shù), 只能返回字節(jié)數(shù)小于64K字節(jié)的圖像區(qū)域, 否則將會

出錯(cuò), 出錯(cuò)時(shí)返回-1。

本節(jié)介紹的函數(shù)在圖像動(dòng)畫處理、菜單設(shè)計(jì)技巧中非常有用。

例13: 下面程序模擬兩個(gè)小球動(dòng)態(tài)碰撞過程。

7. 圖形模式下的文本輸出

在圖形模式下, 只能用標(biāo)準(zhǔn)輸出函數(shù), 如printf(), puts(), putchar() 函

數(shù)輸出文本到屏幕。除此之外, 其它輸出函數(shù)(如窗口輸出函數(shù))不能使用, 即是

可以輸出的標(biāo)準(zhǔn)函數(shù), 也只以前景色為白色, 按80列, 25行的文本方式輸出。

Turbo C2.0也提供了一些專門用于在圖形顯示模式下的文本輸出函數(shù)。下面

將分別進(jìn)行介紹。

一、文本輸出函數(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為象元坐標(biāo)。

說明:

這兩個(gè)函數(shù)都是輸出字符串, 但經(jīng)常會遇到輸出數(shù)值或其它類型的數(shù)據(jù),

此時(shí)就必須使用格式化輸出函數(shù)sprintf()。

sprintf()函數(shù)的調(diào)用格式為:

int sprintf(char *str, char *format, variable-list);

它與printf()函數(shù)不同之處是將按格式化規(guī)定的內(nèi)容寫入str 指向的字符串

中, 返回值等于寫入的字符個(gè)數(shù)。

例如:

sprintf(s, "your TOEFL score is %d", mark);

這里s應(yīng)是字符串指針或數(shù)組, mark為整型變量。

c語言版數(shù)據(jù)結(jié)構(gòu)圖的一些基本操作函數(shù)如下,有三個(gè)地方不了解,請各位幫幫忙?

(1)問題三:

i=LocateVex(*G,va);

j=LocateVex(*G,vb);

*G不是指針,是指針G所指對象,就是ALGraph類型。程序中多處使用變量G,但是不同的地方,含義不同。在void CreateGraph(ALGraph *G)里面,G是一個(gè)指針,因此,引用其所指對象,要用*G。其他情況下,ALGraph G,G不是指針。

(2)第一:這個(gè)void DFSTraverse(ALGraph G,void(*print)(char*)) 為什么不能直接調(diào)用print函數(shù),像調(diào)用DFS函數(shù)一樣?可以的,使用函數(shù)指針是為以后任意擴(kuò)展輸出程序,以適應(yīng)不同需要,并且可以作為參數(shù)傳遞。

(3)第二:FirstAdjVex(G,G.vertices[v].data)為什么要用頂點(diǎn),用了之后又取位置,而不直接用位置,會有什么漏洞嗎?不會

int FirstAdjVex(ALGraph G,VertexType v)

{

ArcNode *p;

int v1;

v1=LocateVex(G,v);

p=G.vertices[v1].firstarc;

if(p)

return p-adjvex;

else

return -1;

}

利用已經(jīng)定義的定位函數(shù)LocateVex直接定位頂點(diǎn)v,然后直接讀取其firstarc,很自然的過程。

C語言可以對函數(shù)輸入一個(gè)結(jié)構(gòu)體嗎

可以的,不過傳入的是改結(jié)構(gòu)體的一個(gè)副本

如果需要在函數(shù)中更改結(jié)構(gòu)體內(nèi)容,可以把這個(gè)結(jié)構(gòu)體的指針作為參數(shù)傳入函數(shù),返回的也是該結(jié)構(gòu)體的指針


分享名稱:c語言改函數(shù)結(jié)構(gòu)圖,c語言算法結(jié)構(gòu)圖
網(wǎng)頁地址:http://weahome.cn/article/dssscph.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部