1.0.6 • Published 6 years ago

react-native-scale-bar v1.0.6

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

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

PropRequiredTypeDefaultDescription
zoomyesnumber-Pass the zoom level to the component to adjust the scale bar.
latitudenonumber48.8187Use the latitude to adjust the scale bar precision.
leftnonumber10Padding with left border of the screen.
bottomnonumber32Padding with bottom of the screen.

Todo

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