Классы, включенные в библиотеку VfpGdiPlus
Загрузить библиотеку VfpGdiPlus...
Скачать тестовые примеры
Класс GdipImages
Класс предназначен для работы с изображениями и рисования
различных графических примитивов и текстовых строк средствами GDI+.
Создание объекта — экземпляра класса:
oGP = CREATEOBJECT("GdipImages" [, lGdipInit])
Необязательный параметр логического типа lGdipInit определяет
необходимость инициализации среды GDIPlus. Если его значение «истина», то
GDIPlus инициализируется.
Свойства
InterpolationMode
Определяет режим интерполяции. Может принимать значения в интервале от 0 до
7.
JpegQuality
Определяет значение качества при сохранении изображения в формате JPEG.
Может принимать значения в интервале от 20 до 90.
Методы
ARGB
Преобразует значение цвета, возвращаемое функций RGB(), в формат, используемый в
GDIPlus.
nGdipColor = oGP.ARGB(RGB(Red, Green, Blue) [, Alpha])
Параметры:
Red, Green, Blue
―
значения цветовых компонент
Alpha ― значение прозрачности (от 0 до 255;
0 - полностью прозрачный; 255 - полностью
непрозрачный); если параметр опущен, то
подразумевается значение 255
ClipImage
Вырезает из изображения заданную прямоугольную область и либо копирует ее в
файл, либо замещает ею исходное изображение.
lReturn = oGP.ClipImage(Left, Top, Width, Height [, cOutputFileName])
Параметры:
Left, Top ―
кординаты левой верхней точки фрагмента
изображения
Width, Height
― ширина и высота фрагмента
изображения
cOutputFileName ―
(необязательный) имя и тип файла для сохранения
изображения
Если параметр
cOutputFileName опущен, то фрагмент замещает исходный образ
изображения
CopyFromClipboard
Копирует растр из буфера обмена Windows в память.
lReturn = oGP.CopyFromClipboard()
CopyToClipboard
Копирует изображение из памяти в буфер обмена Windows.
lReturn = oGP.CopyToClipboard()
CreateBitmap
Создает растр указанного размера и заливает его заданным цветом.
lReturn = oGP.CreateBitmap(width, height [, color])
Параметры:
width, height ―
размеры создаваемого растра
color ― цвет растра (в формате,
возвращаемом методом ARGB)
CreateFont
Создает шрифт заданной высоты и стиля по его имени.
lReturn = oGP.CreateFont(FontName, width [, style])
Параметры:
FontName ―
наименование шрифта (например, Arial)
width
― высота шрифта (вещественное
значение, в зависимости от установленной единицы измерения)
style ―
стиль шрифта (0 - нормальный, 1 - курсив и т.д.)
CreateGradientBrush
Создает линейную градиентную кисть.
lReturn = oGP.CreateGradientBrush(@PointArray [, WrapMode][, Mode])
Параметры:
PointArray ― массив точек,
определяющих вид градиентной кисти; если параметр Mode указан, то массив содержит четыре точки,
определяющий кисть в виде прямоугольной области; иначе
PointArray содержит две точки, определяющих
направление изменения цвета кисти.
WrapMode
―
(необязательный) может принимать значение от 0
до 3; устанавливает эффект перетекания цвета кисти
Mode
― (необязательный) может принимать значения от 0 до 3;
определение направление изменения цвета для кисти, заданной прямоугольником
CreateHatchBrush
Создает штриховую кисть.
lReturn = oGP.CreateHatchBrush([Style][, ForeColor][, BackColor])
Параметры:
Style ― (необязательный)
определяет стиль штриховой кисти; принимает значения
от 0 до 52. Если параметр опущен, то применяется стиль 2 (косая штриховка)
ForeColor
―
(необязательный)
определяет цвет фона в формате, возвращаемом методом ARGB;
если параметр опущен, то применяется белый цвет
BackColor ―
(необязательный)
определяет цвет штриха кисти в формате, возвращаемом методом
ARGB;
если параметр опущен, то создаётся кисть чёрного
цвета
CreatePen
Создает перо.
lReturn = oGP.CreatePen(width [, color])
Параметры:
width ―
толщина пера (вещественное значение, в зависимости
от установленной единицы измерения)
color
―
цвет пера в формате, возвращаемом методом ARGB; если
параметр опущен, то создаётся перо чёрного цвета
CreateSolidBrush
Создает одноцветную кисть.
lReturn = oGP.CreateSolidBrush(color)
Параметры:
color ―
цвет кисти в формате, возвращаемом методом
ARGB
CreateStringFormat
Создает объект StringFormat, управляющий форматированием текста.
lReturn = oGP.CreateStringFormat([lDirect])
Параметры:
lDirect ― (необязательный)
определяет направление вывода текста (если "истина", то текст выводится
вертикально); если параметр опущен, то текст выводится
горизонтально
CreateTextureBrush
Создает текстурированую кисть.
lReturn = oGP.CreateTextureBrush(TextureFileName [, WrapMode])
Параметры:
TextureFileName ―
имя и тип файла, используемого в
качестве текстуры
WrapMode ―
(необязательный) принимает значения
от 0 до 3; определяет взаимное расположение текстур в
случае, если размер текстуры меньше размера области рисования
DeleteBrush
Удаляет кисть.
= oGP.DeleteBrush()
DeleteFont
Удаляет шрифт.
= oGP.DeleteFont()
DeletePen
Удаляет перо.
= oGP.DeletePen()
DeleteStringFormat
Удаляет объект StringFormat. После удаления этого объекта текст не
форматируется.
= oGP.DeleteStringFormat()
DrawClosedCurve, FillClosedCurve
Рисует (закрашивает) замкнутый сплайн.
lReturn = oGP.DrawClosedCurve(@PointsArray [, ObjGraphics])
lReturn = oGP.FillClosedCurve(@PointsArray [, ObjGraphics])
Параметры:
PointArray ― массив координат
точек сплайна
ObjGraphics ― (необязательный)
дескриптор объекта
Graphics, связанного с устройством вывода; если
параметр опущен, то рисование выполняется на текущем образе изображения
DrawCurve
Рисует сплайн.
lReturn = oGP.DrawCurve(@PointsArray [, ObjGraphics])
Параметры:
PointArray ― массив координат
точек сплайна
ObjGraphics ― (необязательный)
дескриптор объекта Graphics, связанного с
устройством вывода; если параметр опущен, то рисование
выполняется на текущем образе изображения
DrawEllipse, FillEllipse
Рисует (закрашивает) эллипс (окружность).
lReturn = oGP.DrawEllipse(x, y, Diameter, Diameter1 [, ObjGraphics])
lReturn = oGP.FillEllipse(x, y, Diameter, Diameter1 [, ObjGraphics])
Параметры:
x, y ―
координаты центра эллипса (окружности)
Diameter
― горизонтальный диаметр
Diameter1 ―
вертикальный диаметр
ObjGraphics ― (необязательный)
дескриптор объекта Graphics, связанного с
устройством вывода; если параметр опущен, то рисование
выполняется на текущем образе изображения
DrawImage
Рисует изображение на внешнем устройстве графического вывода или растре.
lReturn = oGP.DrawImage(ObjGraphics, Left, Top [, Width, Height])
Параметры:
ObjGraphics ―
дескриптор объекта
Graphics, связанного с устройством вывода
Left, Top ― координаты верхней левой точки для
рисования изображения
Width, Height ― (необязательные) определяют ширину и высоту
изображения; если параметры опущены, то используются
размеры исходного изображения
DrawImageFromFile
Рисует на растре изображение, считанное из файла.
lReturn = oGP.DrawImageFromFile(FileName, Left, Top)
Параметры:
FileName ― имя
и тип файла, изображение которого будет нарисовано на существующем образе
изображения
Left, Top
―
координаты верхней левой точки, от которой будет рисоваться изображение
DrawLine
Рисует линию по заданным координатам точек ее начала и конца.
lReturn = oGP.DrawLine(x1, y1, x2, y2 [, ObjGraphics])
Параметры:
x1, y1 ―
координаты начальной точки
x2, y2
―
координаты конечной точки
ObjGraphics
― (необязательный)
дескриптор объекта Graphics, связанного с
устройством вывода; если параметр опущен, то рисование
выполняется на текущем образе изображения
DrawLines
Рисует ломаную линию по координатам, заданным в массиве точек координат.
lReturn = oGP.DrawLines(@PointsArray [, ObjGraphics])
Параметры:
PointArray ― массив координат
точек линии
ObjGraphics ― (необязательный)
дескриптор объекта Graphics, связанного с
устройством вывода; если параметр опущен, то рисование
выполняется на текущем образе изображения
DrawPie
Рисует сектор или дугу.
lReturn = oGP.DrawPie(x, y, Diameter, Diameter1, startAngle, sweepAngle [, ArcFlag][, ObjGraphics])
Параметры:
x, y ―
координаты точки центра сектора (дуги)
Diameter ―
горизонтальный диаметр
Diameter1 ―
вертикальный диаметр
StartAngle
―
вещественное значение, определяет начальный угол (в
градусах)
SweepAngle
― вещественное значение, определяет угол
сектора (дуги) (в градусах)
ArcFlag ― (необязательный) логическое значение;
"ложь" определяет, что будет нарисован сектор
ObjGraphics
― (необязательный)
дескриптор объекта Graphics, связанного с
устройством вывода; если параметр опущен, то рисование
выполняется на текущем образе изображения
FillPie
Закрашивает сектор.
lReturn = oGP.DrawPie(x, y, Diameter, Diameter1, startAngle, sweepAngle [, ObjGraphics])
Параметры:
x, y ―
координаты точки центра сектора (дуги)
Diameter ―
горизонтальный диаметр
Diameter1 ―
вертикальный диаметр
StartAngle
―
вещественное значение, определяет начальный угол (в
градусах)
SweepAngle ― вещественное значение, определяет угол
сектора (дуги) (в градусах)
ObjGraphics
― (необязательный)
дескриптор объекта Graphics, связанного с
устройством вывода; если параметр опущен, то рисование
выполняется на текущем образе изображения
DrawPolygon, FillPolygon
Рисует (закрашивает) многоугольник.
lReturn = oGP.DrawPolygon(@PoinsArray [, ObjGraphics])
lReturn = oGP.FillPolygon(@PoinsArray [, ObjGraphics])
Параметры:
PointArray ― массив координат
точек многоугольника
ObjGraphics ― (необязательный)
дескриптор объекта Graphics, связанного с
устройством вывода; если параметр опущен, то рисование
выполняется на текущем образе изображения
DrawRectangle, FillRectangle
Рисует (закрашивает) прямоугольник.
lReturn = oGP.DrawRectangle(Left, Top, Width, Height [, ObjGraphics])
lReturn = oGP.FillRectangle(Left, Top, Width, Height [, ObjGraphics])
Параметры:
Left, Top ―
координаты левой верхней точки прямоугольника
Width, Height
― ширина и высота прямоугольника
ObjGraphics ― (необязательный)
дескриптор объекта Graphics, связанного с
устройством вывода; если параметр опущен, то рисование
выполняется на текущем образе изображения
DrawRectangles, FillRectangles
Рисует (закрашивает) множество прямоугольников.
lReturn = oGP.DrawRectangles(@PointsArray [, ObjGraphics])
Параметры:
PointArray ― массив координат
точек прямоугольников
ObjGraphics ― (необязательный)
дескриптор объекта Graphics, связанного с
устройством вывода; если параметр опущен, то рисование
выполняется на текущем образе изображения
DrawString
Рисует текстовую строку в заданной прямоугольной области.
lReturn = oGP.DrawLine(Left, Top, Width, Height, TextString [, ObjGraphics])
Параметры:
Left, Top ―
координаты левой верхней точки
прямоугольной области
Width, Height
― ширина
и высота прямоугольной области; если параметры равны
нулю, текст рисуется в одну строку
TextString
― рисуемый
текст
ObjGraphics
― (необязательный)
дескриптор объекта Graphics, связанного с
устройством вывода; если параметр опущен, то рисование
выполняется на текущем образе изображения
Перед вызовом метода задайте необходимый шрифт, вызвав метод
CreateFont, и, при необходимости, вызовите метод
CreateStringFormat для задания направления вывода
текста
FillImage
Заливает растр указанным цветом.
lReturn = oGP.FillImage([Color])
Необязательный параметр Color задаёт цвет в
формате, возвращаемом методом ARGB/.
GetImageResolution
Возвращает разрешение растра (dpi).
lReturn = oGP.GetImageResolution(@HorDPI, @VertDPI)
Параметры (передаются по ссылке):
HorDPI ―
вещественное значение; возвращает
dpi по горизонтали
VertDPI
―
вещественное значение;
возвращает dpi по вертикали
GetImageSize
Возвращает размеры изображения.
lReturn = oGP.GetImageSize(@Widtch, @Height)
В параметры Width и
Height (передаются по ссылке) заносятся размеры изображения (в
пикселях)
GetMeasureString
Вычисляет размеры строки.
lReturn = oGP.GetMeasureString(String, @Width, @Height [, ObjGraphics])
Параметры:
String ―
строка, размер которой необходимо определить
Width, Height
― ширина
и высота прямоугольной области, в которой предполагается выводить строку;
передаются по ссылке и заменяются на фактические значения
ObjGraphics ― (необязательный)
дескриптор объекта Graphics, связанного с
устройством вывода; если параметр опущен, то рисование
выполняется на текущем образе изображения
GetRawFormat
Определяет графический формат файла (BMP, JPEG, GIF и
т.д.).
cFormatName = oGP.GetRawFormat()
GetStatus
Возвращает код состояния после выполнения метода класса. Положительные значения
идентифицируют ошибки, возникшие при выполнении функций GDIPlus, отрицательные —
добавленные нами в класс коды ошибок. Перечень ошибок приведен в таблицах 1 и 2.
Если метод возвращает ноль, то ошибок не было.
nStatusCode = oGP.GetStatus()
GraphicsFromImage
Создает объект Graphics, связанный с загруженным в память изображением.
lReturn = oGP.GraphicsFromImage()
LoadFromFile
Загружает изображение из файла в память.
lReturn = oGP.LoadFromFile(FileName)
Параметр FileName определяет имя и путь
загружаемого файла
LoadFromField
Загружает изображение из поля таблицы или переменной Visual FoxPro.
lReturn = oGP.LoadFromField(table.fieldname)
или
lReturn = oGP.LoadFromField(FoxVariable)
ResizeImage
Изменяет размеры изображения, либо сохраняя новое изображение в файле, либо
замещая им исходное изображение.
lReturn = oGP.ResizeImage(NewWidth, NewHeight [, OutputFileName])
Параметры:
NewWidth, NewHeight
― новые размеры изображения
OutputFileName
―
(необязательный) имя файла для сохранения изображения;
если параметр опущен, то новое изображение замещает существующее
RotateFlip
Выполняет отражения и повороты изображения на угол, кратный 90°.
lReturn = oGP.RotateFlip(RotateFlipCode)
Параметр RotateFlipCode принимает значения от 0 до 7.
SaveToFileld
Сохраняет изображение в поле таблицы или переменной Visual FoxPro.
Replace table.fieldname with oGP.SaveToField(GraphicsFormatName)
или
FoxVariable = oGP.SaveToField(GraphicsFormatName)
Параметр GraphicsFormatName содержит три символа и задаёт тип
графического формата (BMP, JPG, GIF, TIF, PNG)
SaveToFile
Сохраняет изображение в файле.
lReturn = oGP.SaveToFile(OutputFileName)
Параметр OutputFileName определяет имя и тип файла для сохранения
изображения
SetColorGradient
Изменяет начальный и конечный цвета для существующей линейной градиентной кисти.
lReturn = oGP.SetColorGragient(StartColor, EndColor)
Параметры StartColor и EndColor задают начальный и конечный
цвета градиентной кисти в формате, возвращаемом методом ARGB
SetColorSolidBrush
Изменяет цвет существующей одноцветной кисти.
lReturn = oGP.SetColorSolidBrush(NewColor)
Параметр NewColor задаёт новый цвет одноцветной кисти
SetPenColor
Изменяет цвет существующего пера.
lReturn = oGP.SetPenColor(NewColor)
Параметр NewColor задаёт новый цвет пера
SetPenStyle
Изменяет стиль существующего пера.
lReturn = oGP.SetPenStyle(StyleCode)
Параметр StyleCode определяет новый стиль
пера
SetPenWidth
Изменяет толщину существующего пера.
lReturn = oGP.SetPenWidth(Width)
Параметр Width определяет новую толщину пера
SetSmoothing
Устанавливает или отменяет антиаласинг при рисовании графических примитивов.
lReturn = oGP.SetSmoothing(Flag [, ObjGraphics])
Параметры:
Flag ―
значение логического типа;
"истина" устанавливает применение алиасинга
ObjGraphics ― (необязательный)
дескриптор объекта Graphics, связанного с
устройством вывода; если параметр опущен, то рисование
выполняется на текущем образе изображения
SetStringFormatParameter
Устанавливает режим выравнивания текста и направление вывода в заданной
прямоугольной области.
lReturn = oGP.SetStringFormatParameter(Align [, Direct])
Параметры:
Align ―
принимает значения 0, 1 и 2;
определяет выравнивание по левому краю (0), центрирование (1) или
выравнивание по правому краю
Direct ―
(необязательный) определяет направление вывода текста;
значение "истина" предполагает вертикальный вывод
Перед использованием метода должен быть создан объект
StringFormat (в методе CreateStringFormat)
SetTextRendering
Определяет качество рисования символов (например, можно установить режим Clear
Type).
lReturn = oGP.SetextRendering(mode [, ObjGraphics])
Параметры:
mode ―
принимает значения от 0 до 5
ObjGraphics ― (необязательный)
дескриптор объекта Graphics, связанного с
устройством вывода; если параметр опущен, то рисование
выполняется на текущем образе изображения
Коды ошибок
Код ошибки, возникшей при выполнении метода класса, можно получить при помощи
метода GetStatus.
Если GetStatus возвращает положительное число, то это означает, что ошибка
возникла при выполнении функции GDI+. Коды этих ошибок перечислены в таблице 1.
Если GetStatus возвращает отрицательное число, то эта ошибка обнаружена методом.
Коды этих ошибок приведены в таблице 2.
Таблица 1. Коды ошибок GDI+
Код ошибки |
Обозначение |
Описание |
0 |
OK |
Успешное завершение |
1 |
GenericError |
При обращении к методу объекта GDI+
передаваемый параметр, имеющий предопределённые значения, имеет
значение, не совпадающее с одним из значений преопределённого списка |
2 |
InvalidParameter |
Недопустимое значение передаваемого
параметра |
3 |
OutOfMemory |
Недостаточно памяти для выполнения
операции |
4 |
ObjectBusy |
Объект занят и не может выполнить
запрошенный метод |
5 |
InsufficientBuffer |
Указывает, что размер буфера,
передаваемого функции как параметр, недостаточен для размещения
получаемых (возвращаемых) функцией данных. Возникает при
неправильном занесении структуры в строковую переменную |
6 |
NotImplemented |
Попытка обратиться к несуществующему
методу объекта |
7 |
Win32Error |
Метод сгенерировал исключение Windows |
8 |
WrongState |
Объект GDI+
не может перейти в запрашиваемое состояние |
9 |
Aborted |
Указывает, что выполнение метода было
прервано |
10 |
FileNotFound |
Указанный файл не был найден |
11 |
ValueOverflow |
Указывает, что метод выполнил
арифметическую операцию, которая привела к числовому переполнению |
12 |
AccessDenied |
Невозможно использовать указанный файл
для записи |
13 |
UnknownImageFormat |
Невозможно определить графический
формат изображения |
14 |
FontFamilyNotFound |
Попытка использовать несуществующий
шрифт |
15 |
FontStyleNotFound |
Указан недопустимый стиль шрифта |
16 |
NotTrueTypeFont |
Указывает, что шрифт, используемый в
контексте устройства, не TrueType шрифт и не может использоваться в
GDI+ |
17 |
UnsupportedGdiplusVersion |
Указывает, что версия GDI+,
используемая операционной системой, не совместима с версией GDI+,
с которой компилировалось приложение |
18 |
GdiplusNotInitialized |
GDI+ не
инициализирован |
19 |
PropertyNotFound |
Запрошено несуществующее свойство
объекта |
20 |
PropertyNotSupported |
Запрошенное свойство не поддерживается
в данном контексте |
Таблица 2. Коды ошибок класса GdipImages
Код
ошибки |
Описание |
-1 |
Нет загруженного в память изображения |
-2 |
Невозможно создать поток для считывания изображения
из поля таблицы или переменной Visual FoxPro |
-3 |
Ошибка при работе с буфером обмена Windows |
-4 |
Объект Graphics не существует |
-5 |
Перо не существует |
-6 |
Кисть не существует |
-7 |
В метод должен быть передан массив (по ссылке) |
-8 |
Недопустимое количество элементов переданного в
функцию массива |
-9 |
Объект шрифта не существует |
-10 |
Объект StringFormat не существует |
-11 |
Изображение не имеет атрибутов DPI |
Класс GdipPrinter
Класс предназначен для печати изображений, графических
примитивов и текстов на принтере
Создание объекта — экземпляра класса:
oPrinter = CREATEOBJECT("GdipPrinter" [, PrinterName])
Если имя принтера опущено, то объект связывается с принтером, установленным
по умолчанию.
Объект не имеет открытых свойств.
Методы
CloseDocument
Закрывает документ принтера и отправляет его в очередь печати.
lReturn = oPrinter,CloseDocument()
GetGraphics
Возвращает дескриптор объекта Graphics, связанного с принтером.
nObjGraphics = oPrinter.etGraphics()
GetStatus
Возвращает код состояния после выполнения метода класса. Положительные значения
идентифицируют ошибки, возникшие при выполнении функций GDI+, отрицательные —
добавленные нами в класс коды ошибок. Перечень добавленных ошибок приведен в
таблице 3. Если метод возвращает ноль, то ошибок не было.
nStatus = oPrinter.GetStatus()
NewPage
Создает новую страницу в документе принтера.
lReturn = oPrinter.NewPage()
OpenDocument
Открывает документ принтера.
lReturn = oPrinter.OpenDocument([DocumentName])
Необязательный параметр DocumentName определяет имя документа, которое
будет выводиться в окне просмотра очереди печати
SetPageUnit
Устанавливает единицу измерения для печати на принтере и возвращает размеры
листа принтера в выбранных единицах.
lReturn = oPrinter(FlagUnit, @WidthPage, @HeightPage)
Параметры:
FlagUnit ―
логическое значение;
"истина" определяет, что единицами измерения являются миллиметры, "ложь"
― пиксели
WidthPage, HeightPage
― в эти передаваемые по ссылке параметры
заносятся значения размеров листа принтера для выбранной единицы измерения
Коды ошибок
Код ошибки, возникшей при выполнении метода класса, можно получить при помощи
метода GetStatus.
Если GetStatus возвращает положительное число, то это означает, что ошибка
возникла при выполнении функции GDI+. Коды этих ошибок перечислены в таблице 1.
Если GetStatus возвращает отрицательное число, то эта ошибка обнаружена методом.
Коды этих ошибок приведены в таблице 3.
Таблица 3. Коды ошибок класса
GdipPrinter
Код
ошибки |
Описание |
-1 |
Нет открытого документа принтера |
-2 |
Не удалось создать страницу в документе принтера |
-3 |
Не удается корректно закрыть документ принтера |
Класс GdipWindow
Класс предназначен для поддержки рисования в окне.
Создание объекта — экземпляра класса:
oWnd = CREATEOBJECT("GdipWindow", ObjForm)
При создании объекта ему передается ссылка на объект формы (thisform).
Для корректной работы класса форма должна иметь метод с именем ToDraw, в
котором должен быть прописан код для рисования в окне формы.
Класс не имеет открытых свойств.
Единственный открытый метод класса, GetGraphics, возвращает дескриптор
объекта Graphics, связанного с окном формы.
|