How can I help you?
Add Radius Measurement Annotations in React PDF Viewer
27 Feb 20267 minutes to read
Radius measurement annotations allow users to draw circular regions and calculate the radius visually.

Enable Radius Measurement
To enable Radius annotations, inject the following modules into the React PDF Viewer:
import * as React from 'react';
import * as ReactDOM from 'react-dom/client';
import { PdfViewerComponent, Toolbar, Annotation, Inject } from '@syncfusion/ej2-react-pdfviewer';
function App() {
return (
<PdfViewerComponent
id="container"
documentPath="https://cdn.syncfusion.com/content/pdf/pdf-succinctly.pdf"
resourceUrl="https://cdn.syncfusion.com/ej2/31.2.2/dist/ej2-pdfviewer-lib"
style={{ height: '650px' }}
>
<Inject services={[Toolbar, Annotation]} />
</PdfViewerComponent>
);
}
ReactDOM.createRoot(document.getElementById('sample')).render(<App/>);Add Radius Annotation
Add Radius Using the Toolbar
- Open the Annotation Toolbar.
- Select Measurement → Radius.
- Click and drag on the page to draw the radius.

NOTE
If Pan mode is active, selecting the Radius tool automatically switches interaction mode.
Enable Radius Mode
Programmatically switch the viewer into Radius mode.
function enableRadiusMode() {
const viewer = document.getElementById('container').ej2_instances[0];
viewer.annotation.setAnnotationMode('Radius');
}Exit Radius Mode
function exitRadiusMode() {
const viewer = document.getElementById('container').ej2_instances[0];
viewer.annotation.setAnnotationMode('None');
}Add Radius Programmatically
Configure default properties using the Radius Settings property (for example, default fill color, stroke color, opacity).
function addRadius() {
const viewer = document.getElementById('container').ej2_instances[0];
viewer.annotation.addAnnotation('Radius', {
offset: { x: 200, y: 630 },
pageNumber: 1,
width: 90,
height: 90
});
}Customize Radius Appearance
Configure default properties using the Radius Settings property (for example, default fill color, stroke color, opacity).
<PdfViewerComponent
id="container"
documentPath="https://cdn.syncfusion.com/content/pdf/pdf-succinctly.pdf"
resourceUrl="https://cdn.syncfusion.com/ej2/31.2.2/dist/ej2-pdfviewer-lib"
radiusSettings={{ fillColor: 'yellow', strokeColor: 'orange', opacity: 0.6 }}
style={{ height: '650px' }}
>
<Inject services={[Toolbar, Annotation]} />
</PdfViewerComponent>Manage Radius (Move, Reshape, Edit, Delete)
- Move: Drag inside the polygon to reposition it.
- Reshape: Drag any vertex handle to adjust points and shape.
Edit Radius Annotation
Edit Radius (UI)
- Edit the fill color using the Edit Color tool.
- Edit the stroke color using the Edit Stroke Color tool.
- Edit the border thickness using the Edit Thickness tool.
- Edit the opacity using the Edit Opacity tool.
- Open Right Click → Properties for additional line‑based options.
Edit Radius Programmatically
Update properties and call editAnnotation().
function editRadiusProgrammatically() {
const viewer = document.getElementById('container').ej2_instances[0];
for (const ann of viewer.annotationCollection) {
if (ann.subject === 'Radius calculation') {
ann.strokeColor = '#0000FF';
ann.thickness = 2;
ann.opacity = 0.8;
viewer.annotation.editAnnotation(ann);
break;
}
}
}Delete Radius Annotation
Delete Radius Annotation via UI (toolbar/context menu) or programmatically. For supported workflows and APIs, see Delete Annotation.
Set Default Properties During Initialization
Apply defaults for Radius using the radiusSettings property.
<PdfViewerComponent
id="container"
documentPath="https://cdn.syncfusion.com/content/pdf/pdf-succinctly.pdf"
resourceUrl="https://cdn.syncfusion.com/ej2/31.2.2/dist/ej2-pdfviewer-lib"
radiusSettings={{ fillColor: 'orange', opacity: 0.6, strokeColor: 'pink' }}
style={{ height: '650px' }}
>
<Inject services={[Toolbar, Annotation]} />
</PdfViewerComponent>Set Properties While Adding Individual Annotation
Apply defaults for Area using the radiusSettings property.
function addStyledRadius() {
const viewer = document.getElementById('container').ej2_instances[0];
viewer.annotation.addAnnotation('Radius', {
offset: { x: 200, y: 630 },
pageNumber: 1,
width: 90,
height: 90,
fillColor: 'orange',
opacity: 0.6,
strokeColor: 'pink'
});
}Scale Ratio & Units
- Use Scale Ratio from the context menu.
- Supported units: Inch, Millimeter, Centimeter, Point, Pica, Feet.
Set Default Scale Ratio During Initialization
Configure scale defaults using measurementSettings.
<PdfViewerComponent
id="container"
documentPath="https://cdn.syncfusion.com/content/pdf/pdf-succinctly.pdf"
resourceUrl="https://cdn.syncfusion.com/ej2/31.2.2/dist/ej2-pdfviewer-lib"
measurementSettings={{ scaleRatio: 2, conversionUnit: 'cm', displayUnit: 'cm' }}
style={{ height: '650px' }}
>
<Inject services={[Toolbar, Annotation]} />
</PdfViewerComponent>Handle Radius Events
Listen to annotation life-cycle events (add/modify/select/remove). For the full list and parameters, see Annotation Events.
Export and Import
Radius measurements can be exported or imported with other annotations. For workflows and supported formats, see Export and Import annotations.