Comment : masquer du texte dans des documents par programmationHow to: Programmatically Hide Text in Documents

Vous pouvez masquer du texte dans un document en définissant la propriété Hidden de Font pour une plage de texte particulière.You can hide text in a document by setting the Hidden property of the Font for a particular range of text.

Par exemple, vous pouvez masquer temporairement le texte dans un Bookmark (dans une personnalisation au niveau du document) ou un Bookmark (dans un complément VSTO) avant d’envoyer un document à une imprimante.For example, you can temporarily hide the text within a Bookmark (in a document-level customization) or a Bookmark (in an VSTO Add-in) before sending a document to a printer.

S’applique à : Les informations contenues dans cette rubrique s’appliquent aux projets de niveau document et aux projets de compléments VSTO pour Word.Applies to: The information in this topic applies to document-level projects and VSTO add-in projects for Word. Pour plus d’informations, consultez Fonctionnalités disponibles par type d’application et de projet Office.For more information, see Features Available by Office Application and Project Type.

Pour masquer du texte dans un contrôle Bookmark pendant l’impression du documentTo hide text in a Bookmark control while printing the document

  1. Créez une procédure qui masque tout le texte figurant dans une plage spécifiée.Create a procedure that hides all text that is in a specified range.

    Shared Sub HideText(ByVal rng As Word.Range)
        rng.Font.Hidden = True
    End Sub
    
    static void HideText(Word.Range rng)
    {
        rng.Font.Hidden = 1;  // 1 = True
    }
    
  2. Créez une procédure qui affiche tout le texte figurant dans une plage spécifiée.Create a procedure that unhides all text that is in a specified range.

    Shared Sub UnhideText(ByVal rng As Word.Range)
        rng.Font.Hidden = False
    End Sub
    
    static void UnhideText(Word.Range rng)
    {
        rng.Font.Hidden = 0;  // 0 = False
    }
    
  3. Passez la plage d’un signet à la méthode HideText , imprimez le document, puis passez la même plage à la méthode UnhideText .Pass the range of a bookmark to the HideText method, print the document, and then pass the same range to the UnhideText method.

    Vous pouvez utiliser l’exemple de code suivant dans une personnalisation au niveau du document.The following code example can be used in a document-level customization. Pour utiliser cet exemple, exécutez-le à partir de la classe ThisDocument dans votre projet.To use this example, run it from the ThisDocument class in your project.

    HideText(Bookmark1.Range)
    
    Me.PrintOut()
    
    UnhideText(Bookmark1.Range)
    
    HideText(bookmark1.Range);
    
    object oTrue = true;
    object oFalse = false;
    object range = Word.WdPrintOutRange.wdPrintAllDocument;
    object items = Word.WdPrintOutItem.wdPrintDocumentContent;
    object copies = "1";
    object pages = "";
    object pageType = Word.WdPrintOutPages.wdPrintAllPages;
    
    this.PrintOut(
        ref oTrue, ref oFalse, ref range, ref missing, ref missing, ref missing,
        ref items, ref copies, ref pages, ref pageType, ref oFalse, ref oTrue,
        ref missing, ref oFalse, ref missing, ref missing, ref missing, ref missing);
    
    UnhideText(bookmark1.Range);
    

    Vous pouvez utiliser l’exemple de code suivant dans un complément VSTO.The following code example can be used in an VSTO Add-in. Cet exemple utilise le document actif.This example uses the active document. Pour utiliser l'exemple, exécutez-le à partir de la classe ThisAddIn dans votre projet.To use the example, run it from the ThisAddIn class in your project.

    HideText(Bookmark1.Range)
    Me.Application.ActiveDocument.PrintOut()
    UnhideText(Bookmark1.Range)
    
    HideText(bookmark1.Range);
    
    this.Application.ActiveDocument.PrintOut(true, false, Word.WdPrintOutRange.wdPrintAllDocument,
        Item:Word.WdPrintOutItem.wdPrintDocumentContent, Copies:"1", Pages:"", 
        PageType:Word.WdPrintOutPages.wdPrintAllPages, PrintToFile:false, Collate:true, 
        ManualDuplexPrint:false);
    
    UnhideText(bookmark1.Range);
    

Compilation du codeCompiling the Code

Cet exemple de code suppose que le document contient un contrôle Bookmark (dans une personnalisation au niveau du document) ou un contrôle Bookmark (dans un complément VSTO) nommé bookmark1.This code example assumes that the document contains a Bookmark control (in a document-level customization) or Bookmark control (in an VSTO Add-in) that is named bookmark1.

Voir aussiSee Also

Comment : imprimer des Documents par programmation How to: Programmatically Print Documents
Comment : définir par programme et sélectionner des plages dans des Documents How to: Programmatically Define and Select Ranges in Documents
Comment : réinitialiser des plages dans Word Documents par programmation How to: Programmatically Reset Ranges in Word Documents
Comment : mettre à jour par programme de texte d’un signet How to: Programmatically Update Bookmark Text
Paramètres optionnels dans les solutions OfficeOptional Parameters in Office Solutions