CMFCKeyMapDialog, classe
La CMFCKeyMapDialog
classe prend en charge un contrôle qui mappe les commandes aux touches du clavier.
Syntaxe
class CMFCKeyMapDialog : public CDialogEx
Membres
Constructeurs publics
Nom | Description |
---|---|
CMFCKeyMapDialog ::CMFCKeyMapDialog | Construit un objet CMFCKeyMapDialog . |
Méthodes publiques
Nom | Description |
---|---|
CMFCKeyMapDialog ::D oModal | Affiche une boîte de dialogue de mappage de clavier. |
Méthodes protégées
Nom | Description |
---|---|
CMFCKeyMapDialog ::FormatItem | Appelé par l’infrastructure pour générer une chaîne qui décrit un mappage de clé. Par défaut, la chaîne contient le nom de la commande, les touches de raccourci utilisées et la description de la touche de raccourci. |
CMFCKeyMapDialog ::GetCommandKeys | Récupère une chaîne qui contient une liste de touches de raccourci associées à la commande spécifiée. |
CMFCKeyMapDialog ::OnInsertItem | Appelé par l’infrastructure avant qu’un nouvel élément soit inséré dans le contrôle de liste interne qui prend en charge le contrôle de mappage de clavier. |
CMFCKeyMapDialog ::OnPrintHeader | Appelé par l’infrastructure pour imprimer l’en-tête de la carte clavier sur une nouvelle page. |
CMFCKeyMapDialog ::OnPrintItem | Appelé par l’infrastructure pour imprimer un élément de mappage de clavier. |
CMFCKeyMapDialog ::OnSetColumns | Appelé par l’infrastructure pour définir des légendes pour les colonnes du contrôle de liste interne qui prend en charge le contrôle de mappage de clavier. |
CMFCKeyMapDialog ::P rintKeyMap | Appelé par l’infrastructure lorsqu’un utilisateur clique sur le bouton Imprimer . |
CMFCKeyMapDialog ::SetColumnsWidth | Appelé par l’infrastructure pour définir la largeur des colonnes dans le contrôle de liste interne qui prend en charge le contrôle de mappage de clavier. |
Notes
Utilisez la CMFCKeyMapDialog
classe pour implémenter une boîte de dialogue de mappage de clavier redimensionnable. La boîte de dialogue utilise un contrôle d’affichage de liste pour afficher les raccourcis clavier et leurs commandes associées.
Pour utiliser la CMFCKeyMapDialog
classe dans une application, passez un pointeur vers la fenêtre de cadre principale en tant que paramètre du CMFCKeyMapDialog
constructeur. Appelez ensuite la DoModal
méthode pour démarrer une boîte de dialogue modale.
Hiérarchie d'héritage
Spécifications
En-tête : afxkeymapdialog.h
CMFCKeyMapDialog ::CMFCKeyMapDialog
Construit un objet CMFCKeyMapDialog
.
CMFCKeyMapDialog(
CFrameWnd* pWndParentFrame,
BOOL bEnablePrint=FALSE);
Paramètres
pWndParentFrame
[in] Pointeur vers la fenêtre parente de l’objet CMFCKeyMapDialog
.
bEnablePrint
[in] TRUE si la liste des touches d’accélérateur peut être imprimée ; sinon, FALSE. La valeur par défaut est FALSE.
Notes
Exemple
L’exemple suivant montre comment construire un objet de la CMFCKeyMapDialog
classe. Cet exemple fait partie de l’exemple de démonstration Visual Studio.
// this points to a CMainFrame class which extends the
// CMDIFrameWndEx class
CMFCKeyMapDialog dlg(this, TRUE /* Enable Print */);
CMFCKeyMapDialog ::D oModal
Affiche une boîte de dialogue de mappage de clavier.
virtual INT_PTR DoModal();
Valeur de retour
Entier signé, tel que IDOK ou IDCANCEL, transmis à la méthode CDialog ::EndDialog . La méthode, à son tour, ferme la boîte de dialogue. Pour plus d’informations, consultez CDialog ::D oModal.
Notes
La boîte de dialogue mappage de clavier vous permet de sélectionner et d’affecter des touches d’accélérateur à différentes catégories de commandes. En outre, vous pouvez copier les touches d’accélérateur sélectionnées et leur description dans le Presse-papiers.
CMFCKeyMapDialog ::FormatItem
Appelé par l’infrastructure pour générer une chaîne qui décrit un mappage de clé. Par défaut, la chaîne contient le nom de la commande, les touches de raccourci utilisées et la description de la touche de raccourci.
virtual CString FormatItem(int nItem) const;
Paramètres
nItem
[in] Index de base zéro d’un élément dans la liste interne des mappages de clés.
Valeur de retour
Objet CString
qui contient le texte de l’élément mis en forme.
Notes
CMFCKeyMapDialog ::GetCommandKeys
Récupère une valeur de chaîne. La chaîne contient une liste de touches de raccourci associées à une commande spécifiée.
virtual CString GetCommandKeys(UINT uiCmdID) const;
Paramètres
uiCmdID
[in] ID de commande.
Valeur de retour
Liste délimitée (';') par des points-virgules des touches de raccourci associée à la commande spécifiée.
Notes
CMFCKeyMapDialog ::OnInsertItem
Appelé par l’infrastructure avant qu’un nouvel élément soit inséré dans un contrôle de liste interne qui prend en charge le contrôle de mappage de clavier.
virtual void OnInsertItem(
CMFCToolBarButton* pButton,
int nItem);
Paramètres
pButton
[in] Pointeur vers un bouton de barre d’outils utilisé pour mapper une combinaison de touches clavier à un nom de commande et une description. L’élément de mappage de clés est stocké dans un contrôle de liste interne.
nItem
[in] Index de base zéro qui spécifie où insérer le nouvel élément de mappage de clé dans le contrôle de liste interne.
Notes
CMFCKeyMapDialog ::OnPrintHeader
Appelé par l’infrastructure pour imprimer l’en-tête de la carte clavier sur une nouvelle page.
virtual int OnPrintHeader(
CDC& dc,
int nPage,
int cx) const;
Paramètres
dc
[in] Contexte de l’appareil pour l’imprimante.
nPage
[in] Numéro de page à imprimer.
cx
[in] Décalage horizontal de l’en-tête, en pixels.
Valeur de retour
Si elle réussit, la hauteur du texte imprimé. Pour plus d’informations, consultez la section Valeur de retour de CDC ::D rawText.
Notes
L’infrastructure utilise cette méthode pour imprimer la carte de clavier. Par défaut, cette méthode imprime le numéro de page, le nom de l’application et le titre de la boîte de dialogue.
CMFCKeyMapDialog ::OnPrintItem
Appelé par l’infrastructure pour imprimer un élément de mappage de clavier.
virtual int OnPrintItem(
CDC& dc,
int nItem,
int y,
int cx,
BOOL bCalcHeight) const;
Paramètres
dc
[in] Contexte de l’appareil de l’imprimante.
nItem
[in] Index de base zéro de l’élément à imprimer.
y
[in] Décalage vertical entre le haut de la page et la position de l’élément.
cx
[in] Décalage horizontal entre la gauche de la page et la position de l’élément.
bCalcHeight
[in] TRUE pour calculer la meilleure hauteur pour l’élément d’impression ; FALSE pour tronquer l’élément d’impression afin qu’il corresponde à l’espace par défaut.
Valeur de retour
Hauteur de l’élément imprimé.
Notes
L’infrastructure appelle cette méthode pour imprimer un élément de boîte de dialogue de carte de clés. Par défaut, cette méthode imprime le nom de la commande, les touches de raccourci et la description de la commande de l’élément.
CMFCKeyMapDialog ::OnSetColumns
Appelé par l’infrastructure pour définir des légendes pour les colonnes du contrôle de liste interne qui prend en charge le contrôle de mappage de clavier.
virtual void OnSetColumns();
Notes
Par défaut, cette méthode obtient les légendes des colonnes à partir de trois ressources. La légende de colonne de commande provient de IDS_AFXBARRES_COMMAND, la légende de colonne clé provient de IDS_AFXBARRES_KEYS et la légende de la colonne de description provient de IDS_AFXBARRES_DESCRIPTION.
CMFCKeyMapDialog ::P rintKeyMap
Appelé par l’infrastructure lorsqu’un utilisateur clique sur le bouton Imprimer .
virtual void PrintKeyMap();
Notes
La PrintKeyMap
méthode imprime la carte de clés. Il lance un nouveau travail d’impression, puis appelle à plusieurs reprises les méthodes CMFCKeyMapDialog ::OnPrintHeader et CMFCKeyMapDialog ::OnPrintItem jusqu’à ce que tous les mappages de clés soient imprimés.
CMFCKeyMapDialog ::SetColumnsWidth
Appelé par l’infrastructure pour définir la largeur des colonnes dans le contrôle de liste interne qui prend en charge le contrôle de mappage de clavier.
virtual void SetColumnsWidth();
Notes
Cette méthode définit les colonnes du contrôle de liste interne sur les largeurs par défaut. Tout d’abord, la largeur de la colonne des touches de raccourci est calculée. Ensuite, un tiers de la largeur restante est allouée à la colonne de commande et les deux tiers restants sont alloués à la colonne de description.