На главную

On-line справка по Win32 API

Написать письмо
БЕСПЛАТНАЯ ежедневная online лотерея! Выигрывай каждый день БЕСПЛАТНО!
Список всех статей A-B-C-D-E-F-G-H-I-J-K-L-M-N-O-P-Q-R-S-T-U-V-W-X-Y-Z | Скачать Вниз

GetPath



The GetPath function retrieves the coordinates defining the endpoints of lines and the control points of curves found in the path that is selected into the specified device context.

int GetPath(

HDC hdc, // handle of device context
LPPOINT lpPoints, // address of array receiving path vertices
LPBYTE lpTypes, // address of array of path vertex types
int nSize // count of points defining path
);


Parameters

hdc

Identifies a device context that contains a closed path.

lpPoints

Points to an array of POINT structures that contains the line endpoints and curve control points.

lpTypes

Points to an array of bytes where the vertex types are placed. Values are one of the following:

Type Description
PT_MOVETO Specifies that the corresponding point in the lpPoints parameter starts a disjoint figure.
PT_LINETO Specifies that the previous point and the corresponding point in lpPoints are the endpoints of a line.
PT_BEZIERTO Specifies that the corresponding point in lpPoints is a control point or ending point for a Bйzier curve.
PT_BEZIERTO values always occur in sets of three. The point in the path immediately preceding them defines the starting point for the Bйzier curve. The first two PT_BEZIERTO points are the control points, and the third PT_BEZIERTO point is the ending (if hard-coded) point.


A PT_LINETO or PT_BEZIERTO value may be combined with the following value (by using the bitwise operator OR) to indicate that the corresponding point is the last point in a figure and the figure should be closed:

Flag Description
PT_CLOSEFIGURE Specifies that the figure is automatically closed after the corresponding line or curve is drawn. The figure is closed by drawing a line from the line or curve endpoint to the point corresponding to the last PT_MOVETO.


nSize

Specifies the total number of POINT structures that may be placed in the array pointed to by lpPoints. This value must be the same as the number of bytes that may be placed in the array pointed to by lpTypes.



Return Values

If the nSize parameter is nonzero, the return value is the number of points enumerated. If nSize is 0, the return value is the total number of points in the path (and GetPath writes nothing to the buffers). If nSize is nonzero and is less than the number of points in the path, the return value is -1. To get extended error information, call GetLastError. GetLastError may return one of the following error codes:

ERROR_CAN_NOT_COMPLETE
ERROR_INVALID_PARAMETER
ERROR_BUFFER_OVERFLOW

Remarks

The device context identified by the hdc parameter must contain a closed path.
The points of the path are returned in logical coordinates. Points are stored in the path in device coordinates, so GetPath changes the points from device coordinates to logical coordinates by using the inverse of the current transformation.
The FlattenPath function may be called before GetPath to convert all curves in the path into line segments.

See Also

FlattenPath, POINT, PolyDraw, WidenPath


Пригласи друзей и счет твоего мобильника всегда будет положительным!
Предыдущая статья
 
Сайт Народ.Ру Интернет
Следующая статья
Пригласи друзей и счет твоего мобильника всегда будет положительным!

GetPath



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

int GetPath(

HDC hdc, // РУЧКА контекста устройства LPPOINT lpPoints, // адреса массива, получающие грани пути LPBYTE lpTypes, // адрес массива вершины пути набирает счет int nSize // точек, определяющих путь
);


Параметры

hdc

Идентифицирует контекст устройства, который содержит закрытый путь.

lpPoints

Точки на массив структур ТОЧКИ, которые содержат линию конечных точек и изгибают управляющие точки.

lpTypes

Точки на массив байтов где типы вершины установлены. Величины - одно из следующего:

Описание Типа
PT_MOVETO Определяет, что соответствующая точка в параметре lpPoints начинает с непересекающегося фигуры.
PT_LINETO Определяет, что предшествующая точка и соответствующая точка в lpPoints - конечные точки линии.
PT_BEZIERTO Определяет, что соответствующая точка в lpPoints - управляющая точка или выходной для кривой Bйzier.
величины PT_BEZIERTO всегда происходят в комплектах трех. Точка в пути немедленно предшествующем их определяет отправной пункт для кривой Bйzier. Первые две точки PT_BEZIERTO - управляющие точки, и третья точка PT_BEZIERTO является окончанием точки (если трудно-закодированное).


PT_LINETO Или величина PT_BEZIERTO может быть объединена следующим величины (используя поразрядного оператора ИЛИ), чтобы указывать, что соответствующая точка является последней точкой в фигуре и фигура должен быть закрыт:

Описание Флага
PT_CLOSEFIGURE Определяет, что фигура автоматически закрыт после того, как соответствующая линия или кривая будут сделаны. Фигура близко рисуя линию из линии или конечной точки кривой по существу, соответствующих на последний PT_MOVETO.


nSize

Определяет общее число структур ТОЧКИ, которая может быть установлена в массиве указанном, чтобы lpPoints. Эта величина должна быть такой же как и количество байтов, которые могут быть установлены в массиве указанном, чтобы lpTypes.



Обратные Величины

Если параметр nSize ненулевой, обратная величина является количеством перечисленных точек. Если nSize - 0, обратная величина является общим числом точек в пути (и GetPath пишет ничто в буферы). Если nSize ненулевой и - менее чем количество точек в пути, обратная величина - -1. Для того, чтобы расширять информацию ошибки, назовите GetLastError. GetLastError МОЖЕТ возвращать один из следующих кодов ошибки:

ERROR_CAN_NOT_COMPLETE ERROR_INVALID_PARAMETER ERROR_BUFFER_OVERFLOW

Замечания

Контекст устройства идентифицированный hdc параметром должен содержать закрытый путь.
Точки пути возвращаны в логические координаты. Точки загружены в путь в координатах устройства, так что GetPath изменяет точки из координат устройства, чтобы логично координирует используя инверсию текущего преобразования.
Функция FlattenPath может быть названа перед GetPath, чтобы преобразовывать все кривые в путь в сегменты строки.

Смотри Также

FlattenPath, POINT, PolyDraw, WidenPath


Вверх Version 1.3, Oct 26 2010 © 2007, 2010, mrhx Вверх
 mrhx software  Русский перевод OpenGL  Русский перевод Win32 API
 
Используются технологии uCoz