Класс TCanvas
16.4.4. Класс TCanvas
Этот класс создает “канву”, на которой можно рисовать чертежными инструментами - пером, кистью и шрифтом. Объекты класса ЕСаnvas автоматически создаются для всех видимых компонентов, которые должны уметь нарисовать себя. Они инкапсулируют объекты Font, pen, Brush, а также многочисленные методы, использующие эти объекты.
Свойства класса:
property Brush: TBrush; property ClipRect: TRect; | Объект-кисть Определяет текущие размеры области, нуждающейся в прорисовке |
property CopyMode: TCopyMode; | Устанавливает способ взаимодействия растрового изображения с цветом фона |
property Font: TFont; | Объект-шрифт |
property Handle: Integer; | Дескриптор канвы. Используется при непосредственном обращении к API-функциям Windows |
property LockCount: In
tegers; |
Счетчик блокировок канвы. Увеличивается на единицу при каждом обращении к методу Lock и уменьшается на единицу при обращении к Unlock |
property Pen: TPen; | Объект-перо |
property PenPos:TPoint; | Определяет текущее положение пера в пикселях относительно левого верхнего угла канвы |
property Pixels[X,Y:Integer]: TColor; | Массив пикселей канвы |
Свойство copyMode используется при копировании части одной канвы (источника) в другую (приемник) методом copyRect и может иметь одно из следующих значений:
cmBlackness | Заполняет область рисования черным цветом |
cmDestInvert | Заполняет область рисования инверсным цветом фона |
cmMergeCopy | Объединяет изображение на канве и копируемое изображение операцией and |
cmMergePaint | Объединяет изображение на канве и копируемое изображение операцией OR |
cmNotSrcCopy | Копирует на канву инверсное изображение источника |
cmNotSrcErase | Объединяет изображение на канве и копируемое изображение операцией OR и инвертирует полученное |
cmPatCopy | Копирует образец источника |
cmPatInvert | Комбинирует образец источника с изображением на канве с
помощью операции XOR |
cmPatPaint | Комбинирует изображение источника с его образцом с помощью операции OR, затем полученное объединяется с изображением на канве также с помощью OR |
cmSrcAnd | Объединяет изображение источника и канвы с помощью операции AND |
cmSrcCopy | Копирует изображение источника на канву |
cmSrcErase | Инвертирует изображение на канве и объединяет результат с изображением источника операцией AND |
cmSrcInvert | Объединяет изображение на канве и источник операцией XOR |
cmSrcPaint | Объединяет изображение на канве и источник операцией OR |
cmWhitness | Заполняет область рисования белым цветом |
С помощью свойства pixels все пиксели канвы представляются в виде двухмерного массива точек. Изменяя цвет пикселей, можно прорисовывать изображение по отдельным точкам.
Методы класса:
procedure Arc(X1, Y1, X2, Y2, ХЗ, Y3, Х4, Y4: Integer); | Чертит дугу эллипса в охватывающем прямоугольнике (Xl,Yl)-(X2,Y2). Начало дуги лежит на пересечении эллипса и луча, проведенного из его центра в точку (ХЗ, Y3), а конец - на пересечении с лучом из центра в точку (Х4, Y4). Дуга чертится против часовой стрелки (см. Рисунок 16.4, а) |
procedure BrushCopy
(const Dest: TRect; Bitmap: TBitmap; const Source: TRect; Color: TColor); |
Копирует часть изображения Source на участок канвы Dest. Color указывает цвет в Dest, который должен заменяться на цвет кисти канвы. Метод введен для совместимости с ранними версиями Delphi. Вместо него следует пользоваться классом Т Image List |
procedure Chord(XI,
Yl, X2, Y2, X3, Y3, |
Чертит сегмент эллипса в охватывающем прямоуголь нике (XI, У1) - (X2, Y2). Начало дуги сегмента лежит на пересечении эллипса и луча, проведенного из его центра в точку (X3, Y3), а конец - на пересечении с лучом из центра в точку (X4, Y4). Дуга сегмента чертится против часовой стрелки, а начальная и конечная точки дуги соединяются прямой (см. Рисунок 16.4, б) |
procedure CopyRect (Dest: TRect; Canvas: TCanvas;Source: TRect) ; | Копирует изображение Source канвы Canvas в участок Dest текущей канвы. При этом разнообразные специальные эффекты достигаются с помощью свойства CopyMode |
procedure Draw(X, Y:Integer; Graphic:TGraphic) ; | Осуществляет прорисовку графического объекта Graphic так, чтобы левый верхний угол объекта расположился в точке (X, Y) |
procedure DrawFocusRect (const Rect:TRect) ; | Прорисовывает прямоугольник с помощью операции XOR, поэтому повторная прорисовка уничтожает ранее вычерченный прямоугольник. Используется в основном для прорисовки нестандартных интерфейсных элементов при получении ими фокуса ввода и при потере его |
procedure Ellipse(XI, Yl, X2,
Y2: Integers; |
Чертит эллипс в охватывающем прямоугольнике (XI, Yl) - (X2, Y2). Заполняет внутреннее пространство эллипса текущей кистью |
procedure FillRect(const Rect: TRect); | Заполняет текущей кистью прямоугольную область Rect, включая ее левую и верхнюю границы, но не затрагивая правую и нижнюю границы |
procedure Flood-
Fill(X, Y: Integer; Color: TColor; Fill Style: TFillStyle); |
Производит заливку канвы текущей кистью. Залив
ка начинается с точки (X, Y) и распространяется вовсе стороны от нее. Если FillStyle=fsSurface, заливка распространяется на все соседние точки с цветом Color. Если FillStyle=fsBorder, наоборот, заливка прекращается на точках с этим цветом |
procedure FrameRect(const Rect: TRect); | Очерчивает границы прямоугольника Rect текущей кистью толщиной в 1 пиксель без заполнения внутренней части прямоугольника |
procedure LineTo(X,
Y: Integer); |
Чертит линию от текущего положения пера до точки
(X,Y) |
procedure Lock; | Блокирует канву в многопоточных приложениях для предотвращения использования канвы в других по токах команд |
procedure MoveTo(X,Y: Integer); | Перемещает перо в положение (X, Y) без вычерчивания линий |
procedure Pie(XI,
Yl, X2, Y2, X3, Y3, X4, Y4: Longint); |
Рисует сектор эллипса в охватывающем прямоугольнике (XI, Yl) - (X2, Y2). Начало дуги лежит на пересечении эллипса и луча, проведенного из его центра в точку (X3, Y3), а конец - на пересечении случом из центра в точку (X4, Y4). Дуга чертится против часовой стрелки. Начало и конец дуги соединяются прямыми с ее центром (см. Рисунок 16.4, в) |
procedure Polygon.
(Points: array of TPoint) ; |
Вычерчивает пером многоугольник по точкам, заданным в массиве Points. Конечная точка соединяется с начальной и многоугольник заполняется кистью. Без заполнения используйте - Polyline |
procedure Polyline
(Points: array of TPoint); |
Вычерчивает пером ломаную прямую по точкам, заданным в массиве Points |
procedure Rectan
gle(XI, Yl, X2, Y2: Integer); |
Вычерчивает и заполняет прямоугольник (XI, Yl) -S(X2, Y2). Для вычерчивания без заполнения используйте FrameRect или Polyline |
procedure Refresh; | Устанавливает в канве умалчиваемые шрифт и кисть |
procedure RoundRect(Xl, Yl, X2,Y2, X3, Y3: Inte ger) ; | Вычерчивает и заполняет прямоугольник (XI,Yl)- (X2, Y2) со скругленными углами. Прямоугольник (XI, Yl) - (X3, Y3) определяет дугу эллипса для округления углов (см. Рисунок 16.4, г) |
procedure Stretch Draw (const Rect:TRect; Graphic:
TGraphic ); |
Вычерчивает и при необходимости масштабирует графический объект Graphic так, чтобы он полностью занял прямоугольник Rect |
function TextExtent
(const Text:String): TSize; |
Возвращает ширину и высоту прямоугольника, охватывающего текстовую строку Text |
function TextHeight
(const Text: String): Integer; |
Возвращает высоту прямоугольника, охватывающего текстовую строку Text |
procedure TextOut(X,
Y: Integer; const Text: String) ; |
Выводит текстовую строку Text так, чтобы левый
верхний угол прямоугольника, охватывающего текст, располагался в точке (X, Y) |
procedure TextRect(Rect: TRect; X, Y:
Integer; const Text: String) ; |
Выводит текстовую строку Text так, чтобы левый верхний угол прямоугольника, охватывающего текст, располагался в точке (х, Y). Если при этом какая-либо часть надписи выходит из границ прямоугольника Rect, она отсекается и не будет видна |
function TextWidth
(const Text:String): Integer; |
Возвращает ширину прямоугольника, охватывающего текстовую строку Text |
function TryLock:
Boolean; |
Пытается заблокировать канву. Если она не заблокирована другим потоком команд, - True, в противном случае ничего не делает и возвращает False |
procedure Unlock; | Уменьшает на 1 счетчик блокировок канвы |