WithForm1.Canvas do

Begin

Ellipse(10,10,100,100);

MoveTo(10,10);

LineTo(100,100);

Brush.Color:=clRed;

FloodFill(30, 55, clBlack, fsBorder);

end;

Кривые Безье

 

Кривые (сплайны) Безье названы в честь

французского математика Пьера Безье,

предложившего в 60-х годах XX века автомобилестроительной фирме Renault

набор математических выражений, позволяющих проектировать кузова автомобилей с использованием вычислительной техники.

Для задания простейшего сплайна Безье достаточно четырех точек. Две точки несут привычную нагрузку: задают начальные и конечные координаты кривой. Изюминка заключается в роли оставшихся точек: они оттягивают кривую от прямой, соединяющей две крайние точки. От расположения отклоняющих точек зависит, где и каким образом кривая сменит направление. Для построения кривой Безье (кубического сплайна) воспользуйтесь методом:

procedurePolyBezier(constPoints: array ofTPoint);

 

Для задания первого сплайна необходимо 4 точки. Каждому последующему сплайну достаточно 3-х новых точек, поскольку начальная точка новой кривой есть конечная точка предыдущей. Координатами конечных точек первой кривой служат первый и четвертый элементы массива Points. В качестве точек смещения выступают второй и третий элементы массива.

varpArr : array [1..4] ofTPoint;

Begin

// 1 и 4 элементы массива - конечные точки кривой

pArr[1]:=Point(10,100); pArr[4]:=Point(200,100);

// 2 и 3 - отклоняющие точки

pArr[2]:=Point(100,0); pArr[3]:=Point(400,200);

Form1.Canvas.PolyBezier(pArr);

end;

В арсенале холста есть еще один метод, строящий кубический сплайн:

procedurePolyBezierTo(constPoints: array ofTPoint);

 

Единственное отличие от процедуры PolyBezier() заключается в том, что в качестве первой точки кривой Безье используется текущая позиция пера, следовательно, количество элементов массива должно быть кратно трем.

Класс TGraphic

 

Назначение класса TGraphic – поддержка основных графических форматов Windows. TGraphic является основополагающим абстрактным классом для таких графических объектов, как растровые изображения, пиктограммы и метафайлы, а также для разновидности растровых изображений – сжатой растровой картинки (формат JPEG). Перечисленные графические объекты наследуют от TGraphic основные свойства и методы, обеспечивающие загрузку и сохранение изображений, установку размеров и некоторые другие.

Свойство Empty принимает значение true, если графический объект не содержит данных.

propertyEmpty: Boolean;

 

Свойство Modified показывает, изменялся ли данный графический объект.

Свойство используется совместно с обработчиком события OnChange().

propertyModified: Boolean;

 

Состояние цветовой палитры графического изображения определяется свойством Palette. Если палитра не используется изображением, значение свойства равно 0.

propertyPalette: HPALETTE;

 

При изменении цветовой палитры изменяется состояние свойства:

propertyPaletteModified: Boolean;

Свойство используется совместно с обработчиком события OnChange(). За прозрачность графического объекта отвечает свойство:

propertyTransparent: Boolean;

 

Максимальные размеры графического объекта по вертикали и горизонтали:

propertyHeight: Integer;

propertyWidth: Integer;

Класс TGraphic поддерживает операции по работе с потоком, файлом и буфером обмена Windows. Нижеприведенные методы осуществляют загрузку или сохранение графических объектов. В поток:

procedureLoadFromStream(Stream: TStream);

procedureSaveToStream(Stream: TStream);

 

В файл:

procedureLoadFromFile(const FileName: string);

procedureSaveToFile(const FileName: string);

 

В буфер обмена Windows:

 

procedureLoadFromClipboardFormat(AFormat: Word; AData: THandle; APalette: HPALETTE);

procedureSaveToClipboardFormat(varAFormat: Word; varAData: THandle; varAPalette: HPALETTE);

 

В качестве параметров при работе с буфером обмена выступают: AFormat – зарегистрированный графический формат буфера обмена Windows (см. главу 22 «Обмен данными между процессами»), AData – указатель на данные, APalette – указатель на цветовую палитру. Для полиморфного присваивания графических объектов воспользуйтесь методом:

 

procedureAssign(Source: TPersistent);

Например:

Bitmap2.Assign(Bitmap1);

 

Загрузка графических объектов больших размеров занимает много времени. В классе TGraphic предусмотрена возможность информировать пользователя о процессе загрузки данных благодаря использованию события:

propertyOnProgress: TProgressEvent;

TProgressEvent = procedure(Sender: TObject; Stage: TProgressStage; PercentDone: Byte; RedrawNow: Boolean; constRct: TRect; constMsg: string) of object;

typeTProgressStage = (psStarting, psRunning, psEnding);

 

Параметры обработчика события описаны в табл. 10.4.

 

Таблица 10.4. Параметры события TProgressEvent()

Параметры Описание
Sender Элемент- источник сообщения.
Stage Сигнализирует о стадии процесса: psStarting - начало процесса, psRunning - процесс в работе, psEnding - окончание процесса.
PercentDone Процент выполненной работы.
RedrawNow Состояние прорисовки изображения.
Rct Прямоугольник, содержащий координаты области изображения, нуждающегося в прорисовке.
Msg Может содержать текстовое сообщение, описывающее текущую операцию.

procedureTForm1.Image1Progress(Sender: TObject; Stage: TProgressStage;

PercentDone: Byte; RedrawNow: Boolean; constR: TRect; constMsg: string);

Begin

CaseStage of

psStarting: frmProgress.Show;

psRunning : frmProgress.ProgressBar1.Position:=PercentDone;

psEnding : frmProgress.Close;

end;

end;

 

В листинге приведен пример использования события OnProgress().

Состоянием параметра Stage определяется поведение формы frmProgress (показ/закрытие).

Не все графические объекты способны использовать обработчик события OnProgress(). Такой возможностью обладает сжатая растровая картинка (формат JPEG).








Дата добавления: 2016-03-15; просмотров: 577;


Поиск по сайту:

При помощи поиска вы сможете найти нужную вам информацию.

Поделитесь с друзьями:

Если вам перенёс пользу информационный материал, или помог в учебе – поделитесь этим сайтом с друзьями и знакомыми.
helpiks.org - Хелпикс.Орг - 2014-2024 год. Материал сайта представляется для ознакомительного и учебного использования. | Поддержка
Генерация страницы за: 0.014 сек.