INFO : calcul des extensions de texte de texte en gras et italique

Traductions disponibles Traductions disponibles
Numéro d'article: 74298 - Voir les produits auxquels s'applique cet article
Cet article a été archivé. Il est proposé « en l'état » et ne sera plus mis à jour.
Agrandir tout | Réduire tout

Résumé

GetTextExtent() peut être utilisée pour calculer l'étendue d'une chaîne. La valeur renvoyée peut besoin d'être ajustés, selon le style de la police. Lorsqu'une police en italique ou gras est demandée et aucun n'est disponible, GDI (Graphics Device Interface) peut simuler ces styles à l'aide un raster existant ou les polices de vecteur.

Plus d'informations

Simulé de GDI gras et italiques polices deux inclure overhangs. Le overhang est spécifié dans une structure TEXTMETRIC obtenue en appelant la fonction GetTextMetrics . La méthode appropriée pour le calcul l'étendue d'une ligne de texte en italique ou gras est présentée ci-dessous :
   dwExtent = GetTextExtent(hDC, lpString, nCount);
   GetTextMetrics(hDC, &tm);
   xExtent = LOWORD(dwExtent) - tm.tmOverhang;
				
répertoriées ci-dessous sont des exemples d'alignement du texte en italique. Si le caractère suivant n'est pas en italique, le overhang ne doit pas être soustraite de la largeur d'avance renvoyée par la fonction GetTextExtent . Le overhang doit être soustraite uniquement lorsque la suivante pour texte Alignement caractère a le même style.
                                        GetTextExtent yields
                                        this as the extent:

                                              ||
       /   /                                  \/ 
      /   /           /   / /   /         /   /|   |
     /---/           /   / /   /         /   / |   |
    /   /           /---/ /---/         /---/  |---|
   /   /           /   / /   /         /   /   |   |
       -----      /   / /   /         /   /    |   |
         ^            /\                      /\ 
      Overhang        ||                      ||
               Because the next        Start the nonitalic H
               character is italic,    here because it does not
               start the next          slant and would partially
               character within the    overwrite the previous
               overhang of the         italic character.
               current character
				
le overhang des caractères gras synthétisés par GDI est généralement 1 car GDI synthesizes polices en gras par générer deux fois le texte, décalage le deuxième résultat d'un pixel ou efficacement augmenter la largeur de chaque caractère d'un pixel. Calcul de la largeur avance du texte en gras est similaire à la méthode pour le texte en italique. La fonction GetTextExtent renvoie toujours l'étendue de texte plus 1 pour le texte en gras. Ainsi, en soustrayant le tmOverhang(1), l'avance approprié est obtenue.
        ||   ||
        ||   ||
        ||===||
        ||   ||
        ||   ||
              ---<= This line represents the "extra" overhang of 1.
                /\ 
                ||
             GetTextExtent yields
             this as the extent of the
             bold H.
				
Remarque : Cet article s'applique uniquement aux trame et aux polices Vectory. La famille GetTextExtent() de fonctions avance toujours retour largeurs de chaînes des polices TrueType comme indiqué par structure de largeurs ABC. Pour plus d'informations sur ABC avance largeur, consultez la documentation de fonction GetCharABCWidths() .

Propriétés

Numéro d'article: 74298 - Dernière mise à jour: mercredi 26 février 2014 - Version: 3.2
Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
  • Microsoft Windows Software Development Kit 3.1
  • Microsoft Win32 Application Programming Interface sur le système suivant
    • Microsoft Windows NT Server 3.5
    • Microsoft Windows NT Server 3.51
    • Microsoft Windows NT Server 4.0 Standard Edition
    • Microsoft Windows NT Workstation 3.5
    • Microsoft Windows NT Workstation 3.51
    • Microsoft Windows NT Workstation 4.0 Édition Développeur
Mots-clés : 
kbnosurvey kbarchive kbmt kbinfo KB74298 KbMtfr
Traduction automatique
IMPORTANT : Cet article est issu du système de traduction automatique mis au point par Microsoft (http://support.microsoft.com/gp/mtdetails). Un certain nombre d?articles obtenus par traduction automatique sont en effet mis à votre disposition en complément des articles traduits en langue française par des traducteurs professionnels. Cela vous permet d?avoir accès, dans votre propre langue, à l?ensemble des articles de la base de connaissances rédigés originellement en langue anglaise. Les articles traduits automatiquement ne sont pas toujours parfaits et peuvent comporter des erreurs de vocabulaire, de syntaxe ou de grammaire (probablement semblables aux erreurs que ferait une personne étrangère s?exprimant dans votre langue !). Néanmoins, mis à part ces imperfections, ces articles devraient suffire à vous orienter et à vous aider à résoudre votre problème. Microsoft s?efforce aussi continuellement de faire évoluer son système de traduction automatique.
La version anglaise de cet article est la suivante: 74298
L'INFORMATION CONTENUE DANS CE DOCUMENT EST FOURNIE PAR MICROSOFT SANS GARANTIE D'AUCUNE SORTE, EXPLICITE OU IMPLICITE. L'UTILISATEUR ASSUME LE RISQUE DE L'UTILISATION DU CONTENU DE CE DOCUMENT. CE DOCUMENT NE PEUT ETRE REVENDU OU CEDE EN ECHANGE D'UN QUELCONQUE PROFIT.

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com