Document Solutions for PDF
Features / Annotations / Redact Annotation
In This Topic
    Redact Annotation
    In This Topic

    Redact annotation removes content from a PDF document that is not supposed to be shared. DsPdf provides RedactAnnotation class to enable users to mark and apply redact annotations to the PDF file.

    RedactAnnotation class provides the following properties to set various options for the redact annotation:

    Property Description
    UserName Adds the user name to the text label in the title bar of the annotation’s pop-up window when the annotation is open and active.
    Subject Adds the text representing the subject of the annotation.
    Contents Adds the text to the annotation for display.
    RichText Adds the text to the annotation for display in the pop-up window when opened. You can format this text using HTML tags.
    Color Sets the annotation color, popup window color, line color, etc.
    Area Adds the list of quadrilateral structures defining the annotation area. The coordinates of the quadrilaterals' points are relative to the upper left corner of the page's media box, with the Y (vertical) coordinates increasing from top to bottom. If not empty, these quadrilaterals denote the content region that is intended to be redacted. If this list is empty, the Rect entry denotes the content region that is intended to be redacted.
    MarkBorderColor Sets the outline color used to highlight the annotation rectangle.
    MarkFillColor Sets the color used to fill the annotation rectangle.
    Opacity Sets the opacity of the annotation.
    OverlayFillColor Sets the overlay fill color with which to fill the redacted region after the affected content has been removed.
    OverlayText Sets the overlay text that should be drawn over the redacted region after the affected content has been removed.
    Justification Sets the justification to be used in displaying the overlay text.
    OverlayTextRepeat Sets a value indicating whether the text specified by OverlayText should be repeated to fill the redacted region after the affected content has been removed.
    PdfRect Sets the rectangle that defines the location and size of the annotation on a page in PDF user space coordinates. The positive X axis extends horizontally to the right, and the positive Y axis extends vertically upward, with the origin usually in the lower left corner of the page.

    You can apply redact annotation in two phases:

    Mark Redact Area

    When you mark the redact area, a marking or highlight appears in the place of content to show that the region has been marked for redaction. With DsPdf class library, you can find all instances of texts and mark the content for redaction. This allows anyone in charge for redaction to apply redactions on the marked content.

    Redact area in a PDF file

    Refer to the following example code to mark a redact area in a PDF document:

    C#
    Copy Code
    public void CreatePDF()
    {
        GcPdfDocument doc = new GcPdfDocument();
        var fs = new FileStream(Path.Combine("TimeSheet.pdf"), FileMode.Open, FileAccess.Read);
        doc.Load(fs);  //Load the document
    
        //Create Redact annotation
        RedactAnnotation redactAnnotation = new RedactAnnotation();
        //search the text(e.g employee name) which needs to be redacted
        var l = doc.FindText(new FindTextParams("Jaime Smith", true, false), null);
    
        // add the text's fragment area to the annotation
        List<Quadrilateral> area = new List<Quadrilateral>();
        area.Add(l[0].Bounds[0]);
        redactAnnotation.Area = area;
        redactAnnotation.Justification = VariableTextJustification.Centered;
        redactAnnotation.MarkBorderColor = Color.Black;
    
        //Add the redact annotation to the page
        doc.Pages[0].Annotations.Add(redactAnnotation);
        doc.Save("TimeSheet_Redacted.pdf");
    }
    

    Apply Redaction

    Once the areas in a PDF document are marked for redaction, redaction can be applied to those areas to remove the content from PDF documents. After the PDF content is redacted, it cannot be extracted, copied or pasted in other documents. However, you can add overlay text in the place of redacted content.

    DsPdf allows you to apply redact to areas marked for redaction in PDF documents by using the Redact method of GcPdfDocument class. The Redact method has three overloads which provides you with the option to apply redaction to all the areas marked for redaction, to a particular area marked for redaction or a list of areas marked for redaction in a PDF document.

    Redaction in a PDF file

    Refer to the following example code to apply redaction to a PDF document:

    C#
    Copy Code
    var doc = new GcPdfDocument();
    using (var fs = new FileStream(Path.Combine("Resources", "PDFs", "TimeSheet_Redacted.pdf"), FileMode.Open, FileAccess.Read))
    {
        // Load the PDF containing redact annotations (areas marked for redaction)
        doc.Load(fs);
    
        //mark new redact area
        var rc = new RectangleF(280, 150, 100, 30);
    
        var redact = new RedactAnnotation()
        {
            PdfRect = rc,
            Page = doc.Pages[0],
            OverlayFillColor = Color.PaleGoldenrod,
            OverlayText = "REDACTED",
            OverlayTextRepeat = true
        };
    
        // Apply all redacts (above redact and existing area marked for redaction)
        doc.Redact();
    
        doc.Save(stream);
        return doc.Pages.Count;
    }
    
    Note: Once redact annotations are applied, they no longer exist in the PDF document. It is a destructive change, the content marked for redaction is removed from the PDF along with the redact annotations that were used to mark it.

    Preserve Original Image

    When redacting an image, if the same image is present in other locations, DsPdf redacts all the images by replacing them with the redacted ones. However, DsPdf enables you to choose whether the images within the redacted area appearing in other locations will be copied before applying the redact using CopyImagesOnRedact property of RedactOptions class. The default value is false.

    Refer to the following example code to copy images before applying the redact:

    C#
    Copy Code
    // Initialize GcPdfDocument.
    var doc0 = new GcPdfDocument();
    
    // Open PDF document.
    using var fs0 = File.OpenRead("image3pg.pdf");
    doc0.Load(fs0);
    
    // Redact part of the image on the first page.
    doc0.Pages[0].Annotations.Add(new RedactAnnotation() { Rect = new RectangleF(90, 160, 72 * 4.5f, 72 * 2.8f) });
    
    // Copy images before applying redact.
    RedactOptions options = new RedactOptions();
    options.CopyImagesOnRedact = true;
    
    // Apply redact.
    doc0.Redact(options);
    
    // Save PDF document.
    doc0.Save("Redacted.pdf");