Графический интерфейс - BGI-графика. (BGI GRAPHIC)
Инициализация.
detectgraph(Graphdriver,Graphmode) (integer,integer) - (o,o)
Тестирование аппаратуры видеоадаптера и автоматический выбор подходящего драйвера и графического режима. Возвращается номер графического драйвера Graphdriver и номер графического режима Graphmode.
Графические драйверы:
DETECT = 0 - автоустановка
CGA = 1
MCGA = 2
EGA = 3
EGA64 = 4
EGAMONO = 5
RESERVED = 6
HERCMONO = 7
ATT400 = 8
VGA = 9
PC3270 = 10
Графические режимы:
Имя режима Номер Размер Количество Количество страницы цветов страниц
CGAC0 = 0 320x200 С1 1
CGAC1 = 1 320x200 С2 1
CGAC2 = 2 320x200 С3 1
CGAC3 = 3 320x200 С4 1
CGAHI = 4 640x200 2 1
Графические режимы: (продолжение)
Имя режима Номер Размер Количество Количество страницы цветов страниц
MCGAC0 = 0 320x200 С1 1
MCGAC1 = 1 320x200 С2 1
MCGAC2 = 2 320x200 С3 1
MCGAC3 = 3 320x200 С4 1
MCGAMED = 4 640x200 2 1
MCGAHI = 5 640x480 2 1
EGALO = 0 640x200 16 4
EGAHI = 1 640x350 16 2
EGA64LO = 0 640x200 16 1
EGA64HI = 1 640x350 4 1
EGAMONOHI = 3 640x350 2 1
HERCMONOHI = 0 720x348 2 2
ATT400C0 = 0 320x200 С1 1
ATT400C1 = 1 320x200 С2 1
ATT400C2 = 2 320x200 С3 1
ATT400C3 = 3 320x200 С4 1
ATT400MED = 4 640x200 2 1
ATT400HI = 5 640x400 2 1
VGALO = 0 640x200 16 4
VGAMED = 1 640x350 16 2
VGAHI = 2 640x480 16 1
VGAHI2 = 3 640x480 2 1
PC3270HI = 0 720x350 2 1
С1, С2, С3, С4 - фиксированные палитры, наборы цветов которых определяются конкретным адаптором и программно не изменяются.
initgraph(Graphdriver,Graphmode,NewDriver,NewMode,Pathtodriver) (integer,integer,integer,integer,string) - (i,i,o,o,i)
Инициализация графического режима с драйвером Graphdriver, в режиме Graphmode и директорией (путь) Pathtodriver, где находится BGI-файл драйвера. При Graphdriver=DETECT значения NewDriver, NewMode устанавливаются по умолчанию (автоматический выбор).
setgraphbufsize(BufSize) (integer) - (i)
Установка желаемого размера BufSize внутреннего графического буфера (по умолчанию он выбирается в 4К)
getdrivername(DriverName) (string) - (o)
Запрос имени DriverName текущего графического драйвера.
getmaxmode(MaxMode) (integer) - (o)
Запрос максимального значения MaxMode номера графического режима.
getgraphmode(GraphMode) (integer) - (o)
Запрос текущего значения GraphMode номера графического режима для активного драйвера.
getmodename(DriverMode,ModeName) (integer,string) - (i,o)
Для активного графического драйвера запрос имени ModeName
графического режима по его номеру DriverMode.
getmoderange(Graphdriver,Lomode,Himode) (integer,integer,integer) - (i,o,o)
Запрос минимального Lomode и максимального Himode допустимых значений номеров графического режима для графического драйвера Graphdriver.
setgraphmode(Mode) (integer) - (i)
Переход в указанный графический режим Mode.
restorecrtmode
Временный переход в текстовый режим.
graphdefaults
Восстановление характеристик графической системы, установленных при ее инициализации.
closegraph
Прекращение работы графической системы.
Работа с растром точек.
setvisualpage(Pagenum) (integer) - (i)
Отображение на экране страницы видеопамяти. Pagenum - номер отображаемой страницы (нумерация страниц начинается с нуля).
setactivepage(Page) (integer) - (i)
Установка активной страницы видеопамяти. Переотображения страницы не происходит, но весь последующий графический вывод направляется на эту страницу.
getmaxx(X) (integer) - (o)
getmaxy(Y) (integer) - (o)
Определение максимальных значений координат точек растра,
допустимых в данном графическом режиме.
setviewport(Left,Top,Right,Bottom,Clip) (integer,integer,integer,integer,integer) - (i,i,i,i,i)
Динамическое управление размером и расположением графического окна. Left,Top,Right,Bottom - координаты левой, верхней, правой и нижней границ окна в системе координат страницы, Clip - определяет установку режима отсечения: если Clip не нулевой, то любой графический вывод обрезается на границах заданного окна.
getviewsettings(Left,Top,Right,Bottom,Clip) (integer,integer,integer,integer,integer) - (o,o,o,o,o) Запрос текущей установки графического окна.
moveto(X,Y) (integer,integer) - (i,i)
Перемещение текущей графической позиции в указанные координаты графического окна.
moverel(Dx,Dy) (integer,integer) - (i,i)
Перемещение текущей графической позиции на вектор (Dx,Dy).
getx(X) (integer) - (o)
gety(Y) (integer) - (o)
Запрос координат текущей графической позиции.
clearviewport
Очистка графического окна на активной странице.
cleardevice
Очистка всей активной страницы.
getaspectratio(Xasp,Yasp) (integer,integer) - (o,o)
Определение коэффициента пропорциональности растра. Xasp,
Yasp - соответствуют визуально одинаковым отрезкам по вертикали и горизонтали в данном растре графического режима.
setaspectratio(Xasp,Yasp) (integer,integer) - (i,i)
Корректировка коэффициента пропорциональности.
Управление цветом. getpalettesize(PaletteSize) (integer) - (o)
Определение количества динамически управляемых векторов карты цветов для текущего графического режима.
getmaxcolor(MaxColor) (integer) - (o)
Максимальное значение атрибута пиксела, которое разрешается использовать функциям графических примитивов и генераторов графических текстов.
setpalette(Index,Actual_color) (integer,integer) - (i,i)
Изменение одного из цветов внутренней палитры. Переназначаемый цвет задается номером входа палитры Index, который должен лежать в пределах от 0 до Size-1. Actual_color - назначаемый цвет.
setallpalette(PaletteList) (bgi_ilist) - (i)
Полное изменение внутренней палитры цветов. PaletteList - список целых, описывающий палитру: [Size, перечень из Size цветов], где перечень содержит задаваемые цвета палитры.
setbkcolor(Color) (integer) - (i)
Изменение цвета фона на заданный Color.
getbkcolor(BkColor) (integer) - (o)
Определение установленного текущей палитрой цвета фона.
getpalette(PaletteList) (bgi_ilist) - (o)
Возвращает список целых PaletteList, определяющий текущую палитру цветов.
getdefaultpalette(DefaultPalette) (bgi_ilist) - (o)
Возвращает список целых DefaultPalette, определяющий установленную по умолчанию при инициализации графики палитру цветов.
setcolor(Color) (integer) - (i)
Изменение текущего значения рисующего цвета. Color может принимать значения от 0 до MaxColor.
getcolor(Color) (integer) - (o)
Определение текущего значения рисующего цвета.
Доступ в видеопамяти.
getpixel(X,Y,Color) (integer,integer,integer) - (i,i,o)
Чтение точки с координатами (X,Y) в системе координат графического окна.
putpixel(X,Y,Pixelcolor) (integer,integer,integer) - (i,i,i)
Запись точки на экран с координатами (X,Y) в системе координат графического окна.
imagesize(Left,Top,Right,Bottom,Size) (integer,integer,integer,integer,integer) - (i,i,i,i,o)
Определение необходимого размера Size оперативной памяти для сохранения графического окна с координатами Left, Top, Right, Bottom.
getimage(Left,Top,Right,Bottom,BitMap) (integer,integer,integer,integer,string) - (i,i,i,i,o)
Сохранение графического окна с координатами Left, Top, Right, Bottom в строке BitMap.
putimage(X,Y,Bitmap,Op)
(integer,integer,string,integer) - (i,i,i,i)
Запись сохраненного в строке Bitmap графического окна на активную страницу, начиная с координат X, Y (левого верхнего угла)
в режиме Op. Op принимает значения, определяя соответствующую логическую операцию между атрибутами пиксела видеопамяти и пиксела
из Bitmap: COPY_PUT = 0 /* MOV */ XOR_PUT = 1 /* XOR */ OR_PUT = 2 /* OR */ AND_PUT = 3 /* AND */ NOT_PUT = 4 /* NOT */
Графические примитивы. line(X0,Y0,X1,Y1)
(integer,integer,integer,integer) - (i,i,i,i)
Линия, соединяющая две точки с координатами (X0,Y0) и
(X1,Y1).
linerel(Dx,Dy) (integer,integer) - (i,i)
Линия, соединяющая текущую графическую позицию и точку, заданную через приращение координат.
lineto(X,Y) (integer,integer) - (i,i)
Линия, соединяющая текущую графическую позицию и точку, заданную координатами (X,Y).
rectangle(Left,Top,Right,Bottom) (integer,integer,integer,integer) - (i,i,i,i)
Прямоугольник, заданный координатами левого верхнего и правого нижнего углов.
drawpoly(PolyPointsList) (bgi_ilist) - (i)
Ломаная линия, состоящая из отрезков прямых, заданных координатами точек из списка целых чисел PolyPointsList. Первый элемент списка определяет количество точек, остальные координаты самих точек.
circle(X,Y,Radius) (integer,integer,integer) - (i,i,i)
Окружность с радиусом Radius и центром (X,Y).
arc(X,Y,StAngle,EndAngle,Radius) (integer,integer,integer,integer,integer) - (i,i,i,i,i)
Дуга окружности с радиусом Radius и центром (X,Y), ограниченная углами StAngle, EndAngle. Углы выражаются в градусах и отмеряются против часовой стрелки от направления, задаваемого осью
X графической страницы. Дуга проводится от угла StAngle к углу
EndAngle против часовой стрелки.
ellipse(X,Y,StAngle,EndAngle,Xradius,YRadius) (integer,integer,integer,integer,integer,integer) - (i,i,i,i,i,i)
Дуга эллипса с центром в точке (X,Y), радиусами осей XRadius, YRadius, ограниченная углами StAngle, EndAngle. Оси эллипса параллельны осям координат страницы.
getarccoords(X,Y,Xstart,Ystart,Xend,Yend) (integer,integer,integer,integer,integer,integer) - (o,o,o,o,o,o)
Определение характеристик дуги окружности, построенной при последнем использовании предиката arc. Дуга характеризуется тремя точками: (X,Y) - центр окружности, (Xstart,Ystart) - координаты
начала дуги и (Xend,Yend) - координаты ее конца.
setwritemode(WriteMode) (integer) - (i)
Установка режима прорисовки. Число WriteMode определяет логическую операцию между атрибутами пиксела видеопамяти и пиксела рисуемого объекта. Допустимы только операции:
COPY_PUT = 0 /* MOV */ и
XOR_PUT = 1 /* XOR */.
setlinestyle(Linestyle,Upattern,Thickness) (integer,integer,integer) - (i,i,i)
Установка характера и толщины Thickness линий геометрических объектов. Тип линии Linestyle определяется следующими значениями:
SOLID_LINE = 0 сплошная, DOTTED_LINE = 1 точечная,
CENTER_LINE = 2 осевая штрих-пунктирная, DASHED_LINE = 3 пунктирная,
USERBIT_LINE = 4 определяемая пользователем, через аргумент Upattern.
Upattern задает шаблон линии. Это целое число, каждый бит которого, равный 1, определяет рисование пиксела, равный 0, - нет. Толщина задается двумя значениями:
NORM_WIDTH = 1 в один пиксел, THICK_WIDTH = 3 в 3 пиксела.
getlinesettings(LineStyle,Upattern,Thickness) (integer,integer,integer) - (o,o,o)
Определение текущих характеристик линии.
bar(Left,Top,Right,Bottom) (integer,integer,integer,integer) - (i,i,i,i)
Построение закрашенного плоского прямоугольника по двум точкам.
bar3d(Left,Top,Right,Bottom,Depth,Topflag) (integer,integer,integer,integer,integer,integer) - (i,i,i,i,i,i)
Построение закрашенного объемного прямоугольника по двум точкам (прямоугольник), Depth - глубина проекции 3-го измерения, Topflag определяет прорисовку (=1) верхних ребер параллелепипеда.
fillpoly(PolyPointsList) (bgi_ilist) - (i)
Построение закрашенного многоугольника (см. drawpoly).
fillellipse(X,Y,Xradius,YRadius) (integer,integer,integer,integer) - (i,i,i,i)
Построение закрашенного эллипса.
pieslice(X,Y,Stangle,Endangle,Radius) (integer,integer,integer,integer,integer) - (i,i,i,i,i)
Построение закрашенного кругового сектора.
floodfill(X,Y,Border) (integer,integer,integer) - (i,i,i)
Закрашивание области внутри существующего замкнутого контура. Точка (X,Y) должна находится внутри контура. Border определяет цвет пикселов ограничивающего область закраски контура.
setfillstyle(Pattern,Color) (integer,integer) - (i,i)
Установка цвета Color и кода заполнения Pattern для закрашиваемых фигур. Pattern может принимать следующие значения: EMPTY_FILL = 0 заполнить цветом фона
SOLID_FILL = 1 заполнить текущим цветом
LINE_FILL = 2 --- LTSLASH_FILL = 3 ///
SLASH_FILL = 4 /// толстыми линиями BKSLASH_FILL = 5 \\\ толстыми линиями LTBKSLASH_FILL = 6 \\\
HATCH_FILL = 7 light hatch fill XHATCH_FILL = 8 heavy cross hatch fill INTERLEAVE_FILL = 9 interleaving line fill WIDE_DOT_FILL = 10 Widely spaced dot fill CLOSE_DOT_FILL = 11 Closely spaced dot fill USER_FILL = 12 user defined fill
setfillpattern(UpatternList,Color) (bgi_ilist,integer) - (i,i)
Определение своего шаблона закраски. Шаблон представляет собой бинарную матрицу 8х8, состоящую из 8 последовательных целых чисел, образующих список UpatternList.
getfillsettings(FillPattern,FillColor) (integer,integer) - (o,o)
Запрос текущей установки шаблона и кода заполнения.
getfillpattern(PatternList) (bgi_ilist) - (o)
Запрос описания шаблона пользователя.
Вывод графических текстов. settextstyle(Font,Direction,Charsize)
(integer,integer,integer) - (i,i,i)
Инициализация знакогенератора для работы с конкретным графическим шрифтом. Устанавливаются шрифт Font, направление строк Direction и размер символов Charsize.
Шрифт задается следующими значениями:
DEFAULT_FONT = 0 - матричный шрифт, размер символов 8x8
TRIPLEX_FONT = 1 остальные шрифты векторные
SMALL_FONT = 2
SANS_SERIF_FONT = 3
GOTHIC_FONT = 4
Направление строк HORIZ_DIR = 0 - слева направо
VERT_DIR = 1 - снизу вверх
Размер символов управляет масштабом выводимых символов, диапазон допустимых значений от 1 до 10.
setusercharsize(Multx,Divx,Multy,Divy) (integer,integer,integer,integer) - (i,i,i,i)
Установка новых размеров символов путем умножения ширины и высоты базового варианта каждого символа на значения выражений (Multx/Divx) и (Multy/Divy) соответственно.
settextjustify(Horiz,Vert) (integer,integer) - (i,i)
Управление расположением выводимой строки относительно опорной точки (Horiz,Vert). Аргументы могут принимать значения: Расположение по горизонтали Расположение по вертикали LEFT_TEXT = 0 слева BOTTOM_TEXT = 0 внизу CENTER_TEXT = 1 по центру CENTER_TEXT = 1 в центре RIGHT_TEXT = 2 справа TOP_TEXT = 2 вверху
gettextsettings(Font,Direction,CharSize,Horiz,Vert) (integer,integer,integer,integer,integer) - (o,o,o,o,o)
Определение характеристик текущего режима вывода графических текстовых сообщений.
textheight(Textstring,Height) (string,integer) - (i,o)
Определение высоты Height в пикселах текстовой строки
Textstring.
textwidth(Textstring,Width) (string,integer) - (i,o)
Определение ширины Width в пикселах текстовой строки
Textstring.
outtext(Textstring) (string) - (i)
Вывод текста Textstring в текущую графическую позицию.
outtextxy(X,Y,Textstring) (integer,integer,string) - (i,i,i)
Вывод текста Textstring в позицию с координатами (X,Y).