Metodo PathGradientBrush::GetFocusScales (gdipluspath.h)
Il metodo PathGradientBrush::GetFocusScales ottiene le scale dello stato attivo del pennello sfumatura del percorso.
Sintassi
Status GetFocusScales(
[out] REAL *xScale,
[out] REAL *yScale
);
Parametri
[out] xScale
Tipo: REAL*
Puntatore a un valore REAL che riceve il valore della scala dello stato attivo x.
[out] yScale
Tipo: REAL*
Puntatore a un valore REAL che riceve il valore della scala dello stato attivo y.
Valore restituito
Tipo: Stato
Se il metodo ha esito positivo, restituisce Ok, ovvero un elemento dell'enumerazione Status .
Se il metodo ha esito negativo, restituisce uno degli altri elementi dell'enumerazione Status .
Commenti
Per impostazione predefinita, il colore centrale di una sfumatura del percorso è al punto centrale. Chiamando PathGradientBrush::SetFocusScales, è possibile specificare che il colore centrale deve essere visualizzato lungo un percorso che circonda il punto centrale. Si supponga, ad esempio, che il percorso del limite sia un triangolo e che il punto centrale sia al centro del triangolo. Si supponga inoltre che il colore del limite sia rosso e il colore centrale sia blu. Se si imposta la scala dello stato attivo su (0,2, 0,2), il colore è blu lungo il limite di un piccolo triangolo che circonda il punto centrale. Questo triangolo piccolo è il percorso limite principale scalato da un fattore pari a 0,2 nella direzione x e 0,2 nella direzione y. Quando si dipinge con il pennello sfumatura percorso, il colore cambierà gradualmente dal rosso al blu mentre si sposta dal limite del triangolo grande al limite del piccolo triangolo. L'area all'interno del triangolo piccolo verrà riempita con blu.
Esempio
Nell'esempio seguente viene creato un oggetto PathGradientBrush basato su un percorso triangolare. Il codice imposta le scalabilità dello stato attivo del pennello sfumatura percorso su (0.2, 0.2) e quindi usa il pennello sfumatura del percorso per riempire un'area contenente il percorso triangolare. Infine, il codice chiama il metodo PathGradientBrush::GetFocusScales dell'oggetto PathGradientBrush per ottenere i valori della scala dello stato attivo x e della scala dello stato attivo y.
VOID Example_GetFocusScales(HDC hdc)
{
Graphics graphics(hdc);
Point points[] = {Point(100, 0), Point(200, 200), Point(0, 200)};
// No GraphicsPath object is created. The PathGradientBrush
// object is constructed directly from the array of points.
PathGradientBrush pthGrBrush(points, 3);
Color colors[] = {
Color(255, 255, 0, 0), // red
Color(255, 0, 0, 255)}; // blue
REAL relativePositions[] = {
0.0f, // red at the boundary of the outer triangle
1.0f}; // blue at the boundary of the inner triangle
pthGrBrush.SetInterpolationColors(colors, relativePositions, 2);
// The inner triangle is formed by scaling the outer triangle
// about its centroid. The scaling factor is 0.2 in both
// the x and y directions.
pthGrBrush.SetFocusScales(0.2f, 0.2f);
// Fill a rectangle that is larger than the triangle
// specified in the Point array. The portion of the
// rectangle outside the triangle will not be painted.
graphics.FillRectangle(&pthGrBrush, 0, 0, 200, 200);
// Obtain information about the path gradient brush.
REAL xScale = 0.0f;
REAL yScale = 0.0f;
pthGrBrush.GetFocusScales(&xScale, &yScale);
// The value of xScale is now 0.2.
// The value of yScale is now 0.2.
}
Requisiti
Client minimo supportato | Windows XP, Windows 2000 Professional [solo app desktop] |
Server minimo supportato | Windows 2000 Server [solo app desktop] |
Piattaforma di destinazione | Windows |
Intestazione | gdipluspath.h (include Gdiplus.h) |
Libreria | Gdiplus.lib |
DLL | Gdiplus.dll |