1.0.6 • Published 6 years ago

react-image-mappers v1.0.6

Weekly downloads
20
License
MIT
Repository
github
Last release
6 years ago

react-image-mapper

React Component to highlight interactive zones in images

Installation

The easiest way to use react-image-mappers is to install it from NPM and include it in your own React build process (using Browserify, Webpack, etc).

npm install react-image-mappers --save

Usage

Import the component as you normally do, and add it wherever you like in your JSX views as below:

// ES5 require
var ImageMapper = require('react-image-mappers');

// ES6 import
import ImageMapper from 'react-image-mappers';

<ImageMapper src={IMAGE_URL} map={AREAS_MAP}/>

Properties

PropstypeDescriptiondefault
srcstringImage source urlrequired
mapstringMapping description{ name: generated, areas: [ ] }(see below)
fillColorstringFill color of the highlighted zonergba(255, 255, 255, 0.5)
strokeColorstringBorder color of the highlighted zonergba(0, 0, 0, 0.5)
lineWidthnumberBorder thickness of the highlighted zone1
widthnumberImage widthDisplayed width
heightnumberImage heightDisplayed height
activeboolEnable/Disable highlightingtrue
Props callbacksCalled onsignature
onLoadImage loading and canvas initialization completed(): void
onMouseEnterHovering a zone in image(area: obj, index: num, event): void
onMouseLeaveLeaving a zone in image(area: obj, index: num, event): void
onClickClick on a zone in image(area: obj, index: num, event): void
onImageClickClick outside of a zone in image(event): void

Map is an object describing highlighted areas in the image.

Its structure is similar to the HTML syntax of mapping:

  • map: (object) Object to describe highlighted zones - name: (string) Name of the map, used to bind to the image. - areas: (array) Array of area objects - area: (object) Shaped like below :
PropertytypeDescription
_idstringUniquely identify an area. Index in array is used if this value is not provided.
shapestringEither rect, circle or poly
coordsarray of numberCoordinates delimiting the zone according to the specified shape: rect: top-left-X,top-left-Y,bottom-right-X,bottom-right-Ycircle: center-X,center-Y,radiuspoly: Every point in the polygon path as point-X,point-Y,...
hrefstringTarget link for a click in the zone (note that if you provide a onClick prop, href will be prevented)

Notes & Contributions

This a component is still a work in progress.

If you encounter a bug of some kind, feel free to report the issue.

If you'd like to improve this code or ask/advise for any improvement, feel free to comment it as well.

License

Distributed with an MIT License. See LICENSE.txt for more details

Copyright (c) 2017.