Vous pouvez utiliser les fonctions courbe et courbe pour dessiner un graphique à secteurs. La fonction principale utilisée pour dessiner des graphiques en secteurs est la fonction AngleArc , qui vous oblige à fournir les coordonnées du centre du secteur, le rayon du secteur, un angle de début et un angle de balayage. La capture d’écran suivante montre une boîte de dialogue que l’utilisateur peut utiliser pour entrer ces valeurs.
Les valeurs indiquées ci-dessus produisent le graphique à secteurs suivant.
Modèle de boîte de dialogue trouvé dans le script de ressources de l’application (. LE fichier RC) spécifie les caractéristiques de la boîte de dialogue précédente (sa hauteur, les contrôles qu’il contient et son style), comme suit.
La procédure de boîte de dialogue, qui se trouve dans le fichier source de l’application, récupère les données (coordonnées du centre, rayon d’arc et angles de démarrage et de balayage) en procédant comme suit :
La fonction ClearBits définie par l’application initialise le tableau qui reçoit l’entrée utilisateur à zéro.
La fonction GetStrLngth définie par l’application récupère la longueur de la chaîne entrée par l’utilisateur.
La fonction RetrieveInput définie par l’application récupère la valeur entrée par l’utilisateur.
L’exemple de code suivant illustre la procédure de boîte de dialogue.
void ClearBits(LPTSTR, int);
int GetStrLngth(LPTSTR);
DWORD RetrieveInput(LPTSTR, int);
BOOL CALLBACK ArcDlgProc(HWND hdlg, UINT uMsg, WPARAM wParam,
LPARAM lParam)
{
CHAR chInput[4]; // receives control-window input
int cch; // array-size and count variable
switch (uMsg)
{
case WM_INITDIALOG:
return FALSE;
case WM_COMMAND:
switch (wParam)
{
// If the user pressed the OK button, retrieve the
// data that was entered in the various AngleArc
// controls.
case IDD_OK:
// Retrieve the x-coordinate of the arc's center.
ClearBits(chInput, sizeof(chInput));
GetDlgItemText(hdlg, IDD_X, chInput,
sizeof(chInput));
cch = GetStrLngth(chInput);
nX = (int)RetrieveInput(chInput, cch);
// Retrieve the y-coordinate of the arc's center.
ClearBits(chInput, sizeof(chInput));
GetDlgItemText(hdlg, IDD_Y, chInput,
sizeof(chInput));
cch = GetStrLngth(chInput);
nY = (int)RetrieveInput(chInput, cch);
// Retrieve the radius of the arc.
ClearBits(chInput, sizeof(chInput));
GetDlgItemText(hdlg, IDD_RADIUS, chInput,
sizeof(chInput));
cch = GetStrLngth(chInput);
dwRadius = (DWORD) RetrieveInput(chInput, cch);
// Retrieve the start angle.
ClearBits(chInput, sizeof(chInput));
GetDlgItemText(hdlg, IDD_STARTANGLE, chInput,
sizeof(chInput));
cch = GetStrLngth(chInput);
xStartAngle = (float) RetrieveInput(chInput, cch);
// Retrieve the sweep angle.
ClearBits(chInput, sizeof(chInput));
GetDlgItemText(hdlg, IDD_SWEEPANGLE, chInput,
sizeof(chInput));
cch = GetStrLngth(chInput);
xSweepAngle = (float) RetrieveInput(chInput, cch);
EndDialog(hdlg, FALSE);
return TRUE;
// If user presses the CANCEL button, close the
// dialog box.
case IDD_CANCEL:
EndDialog(hdlg, FALSE);
return TRUE;
} // end switch (wParam)
break;
default:
return FALSE;
} // end switch (message)
UNREFERENCED_PARAMETER(lParam);
}
void ClearBits(LPTSTR cArray, int iLength)
{
int i;
for (i = 0; i < iLength; i++)
cArray[i] = 0;
}
int GetStrLngth(LPTSTR cArray)
{
int i = 0;
while (cArray[i++] != 0);
return i - 1;
}
DWORD RetrieveInput(LPTSTR cArray, int iLength)
{
int i, iTmp;
double dVal, dCount;
dVal = 0.0;
dCount = (double) (iLength - 1);
// Convert ASCII input to a floating-point value.
for (i = 0; i < iLength; i++)
{
iTmp = cArray[i] - 0x30;
dVal = dVal + (((double)iTmp) * pow(10.0, dCount--));
}
return (DWORD) dVal;
}
Pour dessiner chaque section du graphique à secteurs, transmettez les valeurs entrées par l’utilisateur à la fonction AngleArc . Pour remplir le graphique à secteurs à l’aide du pinceau actuel, incorporez l’appel à AngleArc dans un crochet de chemin. L’exemple de code suivant montre le crochet de chemin défini et l’appel à AngleArc.
Une ligne est un ensemble de pixels mis en surbrillance sur un affichage raster (ou un ensemble de points sur une page imprimée) identifiés par deux points : un point de départ et un point de fin.
La fonction Chord dessine un accord (une région délimitée par l’intersection d’une ellipse et d’un segment de ligne, appelé sécant). L’accord est tracé à l’aide du stylet actuel et rempli à l’aide du pinceau actuel.