Annotation toolbar customization in Xamarin

This tutorial only applies to Xamarin.Android. See Xamarin.iOS equivalent here .

AnnotationToolbarComponent is a class that contains the logic and views that make up the annotation toolbar. The annotation toolbar can be customized to contain a number of annotation creation tools button as well as any custom button. With the annotation toolbar, users are able to conveniently create annotations and switch between different tools.

The buttons on the annotation toolbar are contained in two groups: the scrollable region (left) and the sticky region (right). The scrollable region can contain any number of buttons and scrolling is used to access buttons that are off-screen. Buttons in the sticky region will always show on the screen and will not be scrollable.

Apryse Docs Image

To learn more about each icon, see the icon cheat sheet .

Create a custom annotation toolbar

The annotation toolbar allows users to easily switch tools when adding annotations to a document. To add an annotation toolbar to your app, first define some layout groups in your app that will contain the annotation toolbar:

XML

1<FrameLayout android:id="@+id/annotation_toolbar_container" android:layout_width="match_parent" android:layout_height="wrap_content"/>

Then in your activity, setup your AnnotationToolbarComponent with ToolManager and attach the required ViewModel classes:

C#

1AnnotationToolbarComponent annotationToolbarComponent;
2// ...
3private void SetupAnnotationToolbar(ToolManager toolManager)
4{
5 // First find our container view group
6 var mToolbarContainer = FindViewById(Resource.Id.annotation_toolbar_container);
7
8 // Then setup ToolManager and related ViewModels with AnnotationToolbarComponent
9 // Remember to initialize your ToolManager before calling below
10 var vmProvider = ViewModelProviders.Of(this);
11 var toolManagerVm = (ToolManagerViewModel)vmProvider.Get(Java.Lang.Class.FromType(typeof(ToolManagerViewModel)));
12 toolManagerVm.ToolManager = toolManager;
13 var presetVm = (PresetBarViewModel)vmProvider.Get(Java.Lang.Class.FromType(typeof(PresetBarViewModel)));
14 var annotToolbarVm = (AnnotationToolbarViewModel)vmProvider.Get(Java.Lang.Class.FromType(typeof(AnnotationToolbarViewModel)));
15
16 // Create our UI component for the annotation toolbar
17 annotationToolbarComponent = new AnnotationToolbarComponent(this, annotToolbarVm, presetVm, toolManagerVm, mToolbarContainer);
18}

Finally, you can customize the annotation toolbar by either using one of our default toolbars or creating a custom toolbar from scratch.

C#

1// Use a default toolbar
2annotationToolbarComponent.InflateWithBuilder(DefaultToolbars.DefaultAnnotateToolbar);
3
4// Or create a custom toolbar from scratch
5annotationToolbarComponent.InflateWithBuilder(
6 AnnotationToolbarBuilder.WithTag("Custom Toolbar")
7 // Add some pre-defined tools that will be handled internally using ToolManager
8 .AddToolButton(ToolbarButtonType.Square, 100)
9 .AddToolButton(ToolbarButtonType.Ink, 102)
10 .AddToolButton(ToolbarButtonType.FreeHighlight, 103)
11 .AddToolButton(ToolbarButtonType.Eraser, 104)
12 // We can also add a custom button to handle ourselves, for example here
13 // we have added a "favorites" button that contains a star icon
14 .AddCustomButton(Resource.String.favorites, Resource.Drawable.annotation_note_icon_star_fill, 105)
15 .AddToolStickyButton(ToolbarButtonType.Undo, 106)
16 .AddToolStickyButton(ToolbarButtonType.Redo, 107)
17 );

Show and hide annotation toolbar

You can show and hide the toolbar by calling AnnotationToolbarComponent.show(boolean) and AnnotationToolbarComponent.hide(boolean).

Hide annotation toolbar items

If you have used ToolManager to hide certain tools, then the associated tool buttons will also be hidden in the annotation toolbar.

Hide tool buttons

If there are tools that you would like to remove from the annotation toolbar, you can disable them by calling ToolManager.disableToolMode(ToolMode[]). This will also hide the tool in the quick menu. For example:

C#

1// Disable TextHighlightCreate tool, TextUnderlineCreate tool,
2// TextSquigglyCreate tool and TextStrikeoutCreate tool
3mToolManager.DisableToolMode(new ToolManager.ToolMode[] {
4 ToolManager.ToolMode.TextHighlight,
5 ToolManager.ToolMode.TextUnderline,
6 ToolManager.ToolMode.TextSquiggly,
7 ToolManager.ToolMode.TextStrikeout
8});

For reference, a mapping of ToolMode to button icons is shown below:

Icon

ToolMode

Apryse Docs Image

RECT_CREATE

Apryse Docs Image

OVAL_CREATE

Apryse Docs Image

POLYLINE_CREATE

Apryse Docs Image

POLYGON_CREATE

Apryse Docs Image

CLOUD_CREATE

Apryse Docs Image

LINE_CREATE

Apryse Docs Image

ARROW_CREATE

Apryse Docs Image

RULER_CREATE

Apryse Docs Image

TEXT_CREATE

Apryse Docs Image

CALLOUT_CREATE

Apryse Docs Image

TEXT_ANNOT_CREATE

Apryse Docs Image

INK_CREATE

Apryse Docs Image

INK_ERASER

Apryse Docs Image

SIGNATURE

Apryse Docs Image

STAMPER

Apryse Docs Image

RUBBER_STAMPER

Apryse Docs Image

FREE_HIGHLIGHTER

Apryse Docs Image

TEXT_HIGHLIGHT

Apryse Docs Image

TEXT_UNDERLINE

Apryse Docs Image

TEXT_SQUIGGLY

Apryse Docs Image

TEXT_STRIKEOUT

Apryse Docs Image

ANNOT_EDIT_RECT_GROUP

Annotation toolbar listener

You can set an AnnotationButtonClickListener to be notified of annotation toolbar button click events.

Edit annotations continuously

For continuous annotation creation, AnnotationToolbarComponent will use value set by PdfViewCtrlSettingsManager.setContinuousAnnotationEdit(Context, boolean) (by default true). If continuous annotation editing is disabled, then the tool button will be de-selected in the annotation toolbar after creating an annotation.

Appearance styles

In order to customize the appearance of UI elements in your annotation toolbar, you can define a new style that extends PTAnnotationToolbarTheme inside your res\values\style.xml file and pass it as an attribute to your viewer's theme named pt_annotation_toolbar_style. For more information on customizing the style of UI components, please take a look at our viewer theme guide .

Did you find this helpful?

Trial setup questions?

Ask experts on Discord

Need other help?

Contact Support

Pricing or product questions?

Contact Sales