@1304dante/ns-google-maps-utils

A NativeScript Goole maps utils for IOS & Android.


Keywords
NativeScript, Google maps utils, Cluster, Clustering
License
Apache-2.0
Install
npm install @1304dante/ns-google-maps-utils@2.0.2

Documentation

nativescript-danem-google-maps-utils (V1.0.17)

NativeScript Google Maps SDK utility library IOS & Android :

  • Clustering implemented
  • Heatmap implemented

*** I am available to improve this plugin as needed, so do not hesitate to open a ticket for a request ! ***

Dependencies

Install

tns plugin add nativescript-danem-google-maps-utils

Usage

Import

var GoogleMaps = require('nativescript-google-maps-sdk');
var GoogleMapsUtils = require('nativescript-danem-google-maps-utils');

Call function

// After initializing google maps and creating a marker array :
GoogleMapsUtils.setupMarkerCluster(mapView, makerSet);
GoogleMapsUtils.setupHeatmap(this.mapView, positionSet);

Clustering Info

Marker icon

var icon = 'marker_icon'
var marker: Marker = new Marker();
marker.infoWindowTemplate = icon;
makerSet.push(marker)

Marker Select & Cluster Select

onMarkerSelect(event) {
// Be careful, if you tap on a marker it returns a marker, if you tap on a cluster it returns an array of markers.
// var marker = event.marker
// or
// var arrayMarkers = event.marker
}

MoveCamera

GoogleMapsUtils.moveCamera(lat,lon,zoom)

Clear

GoogleMapsUtils.clearMap();
GoogleMapsUtils.

HeatMap

generateRandomPosition(position, distance) {
    var r = distance / 111300;

    var x = position[0];
    var y = position[1];

    var u = Math.random();
    var v = Math.random();

    var w = r * Math.sqrt(u);
    var t = 2 * Math.PI * v;

    var dx = w * Math.cos(t) / Math.cos(y);
    var xy = w * Math.sin(t);

    return [x + dx, y + xy];
}

demoSetupHeatMap() {
    var positionSet = [];
    for (var i = 0; i < 400; i++) {
        positionSet.push(this.generateRandomPosition([48.7797613, 2.4658653], 10000));
    }

    positionSet = positionSet.map(function (position) {
        return GoogleMaps.Position.positionFromLatLng(position[0], position[1]);
    });
    GoogleMapsUtils.setupHeatmap(this.mapView, positionSet, [new Color("#00FF00"), new Color("#FF0000")], [0.10, 0.50]);
    GoogleMapsUtils.setOpacity(0.8);
    GoogleMapsUtils.setRadius(80)
}

Set Opacity & Radius

    GoogleMapsUtils.setOpacity(0.8);
    GoogleMapsUtils.setRadius(80)

Plugin inspired by nativescript-google-maps-utils, thanks @naderio