Search Results for

    Show / Hide Table of Contents

    Interface IFormFieldAnnotation

    Document form field annotation

    Inherited Members
    IFormFieldAnnotationObject.X
    IFormFieldAnnotationObject.Y
    IFormFieldAnnotationObject.Width
    IFormFieldAnnotationObject.Height
    IPdfDocumentObject.Client
    Namespace: IronSoftware.Forms
    Assembly: IronPdf.dll
    Syntax
    public interface IFormFieldAnnotation : IFormFieldAnnotationObject, IPdfDocumentObject, IPdfDocumentObject, IDocumentObject

    When you inspect or edit a single on-page widget annotation belonging to a fillable PDF form field in IronPDF, IFormFieldAnnotation is the contract you read it through. A single form field can own multiple annotations across pages, so each annotation carries its own appearance state, flags, and optional JavaScript hook while sharing a parent field through the FormField property. Geometry (X, Y, Width, Height) is inherited from IFormFieldAnnotationObject.

    Widget-level access becomes necessary whenever a form must be inspected or edited per page rather than per field. Radio button groups, for example, surface their option widgets through the Annotations collection on the parent form field, where each entry exposes an AppearanceState such as Yes or Off that decides which radio in the group is currently selected. Per-page rendering audits, appearance customization, and form-flattening pipelines all read against this contract.

    Most everyday access is through the Annotations property on a form field, which returns List<IFormFieldAnnotation>. The declared surface on this interface adds AnnotationFlags (a PdfAnnotationFlags value), Appearances (the list of named appearances the annotation defines), AppearanceState (which named appearance is active), FormField (the parent IFormFieldObject backreference), Javascript (an action script the annotation runs on interaction), and OnAppearance (the name of the appearance shown when the annotation is selected). The concrete implementor is FormFieldAnnotation; annotations are obtained from a loaded field, not constructed. For a worked example that reads a field's widgets and writes its value, see the fill and edit PDF forms how-to.

    using IronPdf;
    using IronSoftware.Forms;
    
    PdfDocument pdf = PdfDocument.FromFile("application.pdf");
    
    // Radio groups expose their option widgets as a List<IFormFieldAnnotation>.
    IFormField radioGroup = pdf.Form.FindFormField("Shipping");
    foreach (IFormFieldAnnotation annotation in radioGroup.Annotations)
    {
        // X, Y, Width, Height come from IFormFieldAnnotationObject.
        // AppearanceState identifies which radio option this widget represents.
        System.Console.WriteLine(
            $"option={annotation.AppearanceState} at ({annotation.X},{annotation.Y})");
    }
    
    // Select the "Express" radio by assigning to the parent field's Value.
    radioGroup.Value = "Express";
    pdf.SaveAs("application-filled.pdf");

    For the field-level contract that owns this annotation collection, see IFormField. For building forms from scratch, the create PDF forms how-to is the entry point.

    Properties

    AnnotationFlags

    Annotation flags

    Declaration
    PdfAnnotationFlags AnnotationFlags { get; set; }
    Property Value
    Type Description
    PdfAnnotationFlags

    Appearances

    Annotation appearance names

    Declaration
    List<string> Appearances { get; }
    Property Value
    Type Description
    System.Collections.Generic.List<System.String>

    AppearanceState

    Current active appearance

    Declaration
    string AppearanceState { get; set; }
    Property Value
    Type Description
    System.String

    FormField

    Parent form

    Declaration
    IFormFieldObject FormField { get; set; }
    Property Value
    Type Description
    IFormFieldObject

    Javascript

    Javascript to execute when the annotation is interacted with

    Declaration
    string Javascript { get; set; }
    Property Value
    Type Description
    System.String
    Remarks

    See ISO 21757-1:2020 for an ECMAScript reference

    OnAppearance

    Name of the appearance which is active when this annotation is selected

    Declaration
    string OnAppearance { get; set; }
    Property Value
    Type Description
    System.String

    Inherited members

    X
    Y
    Width
    Height
    Client
    ☀
    ☾
    Downloads
    • Download with Nuget
    • Start for Free
    In This Article
    Back to top
    Install with Nuget
    IronPDF_for_dotnet_log2o
    Blue key in circleGet started for FREE
    No credit card required
    Test in a live environment

    Test in production without watermarks.
    Works wherever you need it to.

    Fully-functional product

    Get 30 days of fully functional product.
    Have it up and running in minutes.

    24/5 technical support

    Full access to our support engineering team during your product trial

    Grey key in circleGet started for FREE
    The trial form was submitted successfully.
    Calendar in circleBook Free Live Demo
    No contact, no card details, no commitments Book a 30-minute, personal demo.
    Here's what to expect:

    A live demo of our product and its key features

    Get project specific feature recommendations

    All your questions are answered to make sure you have all the information you need. (No commitment whatsoever.)

    Grey key in circleBook Free Live Demo
    Your booking has been completed Check your e-mail for confirmation
    Support Team Member 6 related to The C# PDF Library Support Team Member 14 related to The C# PDF Library Support Team Member 4 related to The C# PDF Library Support Team Member 2 related to The C# PDF Library
    Online 24/5
    Need help? Our sales team would be glad to help you.
    Try the Enterprise Trial
    ironpdf_for_dotnet_log2o
    Key in blue circle
    Get your free 30-day Trial Key instantly.
    bullet_checkedNo credit card or account creation required
    Key in blue circle
    Get your free 30-day Trial Key instantly.
    Blue key in circleNo credit card or account creation required
    Green Check in orange circle
    The trial form was submitted successfully.
    badge_greencheck_in_yellowcircle
    Thank you for starting a trial

    Please check your email for the trial license key.

    If you don’t receive an email, please start a live chat or email support@ironsoftware.com

    Install with NuGet
    View Licensing
    • Logo Aetna
    • Logo NASA
    • Logo GE
    • Logo Porsche
    • Logo USDA
    • Logo Qatar
    Join Millions of Engineers who’ve tried IronPDF