62 lines
1.5 KiB
JavaScript
62 lines
1.5 KiB
JavaScript
'use strict';
|
|
|
|
//var oS2 = require('./s2geometry.old.js').S2;
|
|
var jS2 = require('../src/s2geometry.js').S2;
|
|
var nS2 = require('s2geometry-node');
|
|
|
|
var lat = -43.525166;
|
|
var lng = 172.655096;
|
|
//var id = '8678661352471920640';
|
|
|
|
var tests = [
|
|
[ -13.846153846153854, -41.53846153846155 ] // face 0
|
|
, [ -13.846153846153854, 96.92307692307692 ] // face 1
|
|
, [ 41.53846153846153, -124.61538461538463 ] // face 2
|
|
, [ -152.30769230769232, 41.53846153846153 ] // face 3
|
|
, [ -152.30769230769232, 69.23076923076923 ] // face 4
|
|
, [ -124.61538461538463, -69.23076923076924 ] // face 5
|
|
];
|
|
|
|
tests.forEach(function (pair, i) {
|
|
var lat = pair[0];
|
|
var lng = pair[1];
|
|
|
|
console.log('');
|
|
console.log('');
|
|
console.log('FACE', i);
|
|
|
|
console.log('');
|
|
console.log('Lat/Lng');
|
|
console.log('=', lat + ',' + lng);
|
|
|
|
//
|
|
// Lat / Lng to XYZ
|
|
//
|
|
var nS2LatLng = new nS2.S2LatLng(lat, lng).toPoint();
|
|
//var nXyz = [ nS2LatLng.x(), nS2LatLng.y(), nS2LatLng.z() ];
|
|
//var jXyz = jS2.LatLngToXYZ({ lat: lat, lng: lng });
|
|
/*
|
|
console.log('');
|
|
console.log('XYZ');
|
|
console.log('=', nXyz);
|
|
console.log('j', jXyz);
|
|
*/
|
|
|
|
|
|
var nCell = new nS2.S2CellId(nS2LatLng).parent(15);
|
|
var jCell = jS2.S2Cell.FromLatLng({ lat: lat, lng: lng }, 15);
|
|
/*
|
|
console.log('');
|
|
console.log('F,IJ,L');
|
|
console.log('j', jCell.toString());
|
|
*/
|
|
|
|
var nKey = nCell.toString();
|
|
var jQuad = jCell.getFaceAndQuads();
|
|
var jKey = jQuad[0] + '/' + jQuad[1].join('');
|
|
console.log('');
|
|
console.log('Quadkey');
|
|
console.log('=', nKey);
|
|
console.log('j', jKey);
|
|
});
|