react-native-scale-bar

1.0.6 • Public • Published

react-native-scale-bar NPM version Downloads Software License

Scale bar for MapView in React Native. Works with Mapbox and Google Map.

Image

Installation

npm install --save react-native-scale-bar

Usage

import React, { Component } from "react";
import Mapbox from "@mapbox/react-native-mapbox-gl";
import ScaleBar from "react-native-scale-bar";
import debounce from "lodash.debounce";

(...)

onUserLocationUpdate(location) {
  const latitude = location.coords.latitude;
  this.setState({latitude});
}

async handleMapChange() {
  const zoom = await this._map.getZoom();
  this.setState({zoom});
}

(...)

<Mapbox.MapView
  ref={c => (this._map = c)}
  onRegionDidChange={() => this.handleMapChange()}
  onRegionIsChanging={debounce(() => this.handleMapChange(), 200)}
  onRegionWillChange={() => this.handleMapChange()}
  onUserLocationUpdate={this.onUserLocationUpdate}
  (...)
/>

<ScaleBar zoom={this.state.zoom} latitude={this.state.latitude}/>

Properties

Prop Required Type Default Description
zoom yes number - Pass the zoom level to the component to adjust the scale bar.
latitude no number 48.8187 Use the latitude to adjust the scale bar precision.
left no number 10 Padding with left border of the screen.
bottom no number 32 Padding with bottom of the screen.

Todo

  • Option to place the scale bar anywhere on the screen
  • Add imperial units

Readme

Keywords

Package Sidebar

Install

npm i react-native-scale-bar

Weekly Downloads

191

Version

1.0.6

License

MIT

Unpacked Size

145 kB

Total Files

12

Last publish

Collaborators

  • felixgourdeau