diff options
author | Alexander NeonXP Kiryukhin <a.kiryukhin@mail.ru> | 2019-06-09 19:04:34 +0300 |
---|---|---|
committer | Alexander NeonXP Kiryukhin <a.kiryukhin@mail.ru> | 2019-06-09 19:04:34 +0300 |
commit | 2a5b10f500c8909a371010bc67cce3896f5fa781 (patch) | |
tree | eadc177afe4406d2a626ec2430c35890d8fc5b7a /src | |
parent | 6b8ef1ef1a93061a43cfe5e6d94db0e7f2a29052 (diff) |
fixes
Diffstat (limited to 'src')
-rw-r--r-- | src/index.js | 31 |
1 files changed, 17 insertions, 14 deletions
diff --git a/src/index.js b/src/index.js index 0a48054..ff719e7 100644 --- a/src/index.js +++ b/src/index.js @@ -80,7 +80,7 @@ export default class Map extends PureComponent { width: props.width || props.defaultWidth, height: props.height || props.defaultHeight, zoomDelta: 0, - pixelDelta: null, + pixelDelta: [0, 0], oldTiles: [], deltaX: 0, deltaY: 0, @@ -317,7 +317,6 @@ export default class Map extends PureComponent { const tileX = this.lng2tile(latLng[1], zoom) const tileY = this.lat2tile(latLng[0], zoom) - return [ (tileX - tileCenterX) * 256.0 + width / 2 + (pixelDelta ? pixelDelta[0] : 0), (tileY - tileCenterY) * 256.0 + height / 2 + (pixelDelta ? pixelDelta[1] : 0) @@ -479,6 +478,9 @@ export default class Map extends PureComponent { // Markers renderMarkers = () => { + if (!this.state.width || !this.state.height || !this.state.pixelDelta) { + return null + } const { center, zoom, pixelDelta, zoomDelta, width, height } = this.state const roundedZoom = Math.round(zoom + (zoomDelta || 0)) const zoomDiff = zoom + (zoomDelta || 0) - roundedZoom @@ -577,10 +579,10 @@ export default class Map extends PureComponent { key: `${x}-${y}-${old.roundedZoom}`, url: mapUrl(x, y, old.roundedZoom), srcSet: this.srcSet(dprs, mapUrl, x, y, old.roundedZoom), - left: xDiff + (x - old.tileMinX) * 256 * pow + left, - top: yDiff + (y - old.tileMinY) * 256 * pow + top, - width: 256 * pow, - height: 256 * pow, + left: (xDiff + (x - old.tileMinX) * 256 * pow + left) * scale, + top: (yDiff + (y - old.tileMinY) * 256 * pow + top) * scale, + width: 256 * pow * scale, + height: 256 * pow * scale, active: false, opacity: 1, }) @@ -601,10 +603,10 @@ export default class Map extends PureComponent { key, url: mapUrl(x, y, roundedZoom), srcSet: this.srcSet(dprs, mapUrl, x, y, roundedZoom), - left: (x - tileMinX) * 256 + left, - top: (y - tileMinY) * 256 + top, - width: 256, - height: 256, + left: ((x - tileMinX) * 256 + left) * scale, + top: ((y - tileMinY) * 256 + top) * scale, + width: 256 * scale, + height: 256 * scale, active: true, opacity: 1, }) @@ -616,10 +618,10 @@ export default class Map extends PureComponent { source={{ uri: tile.url, cache: 'force-cache' }} resizeMethod={"scale"} style={{ - height: tile.height * scale, - width: tile.width * scale, - left: tile.left * scale, - top: tile.top * scale, + height: tile.height, + width: tile.width, + left: tile.left, + top: tile.top, position: 'absolute', opacity: tile.opacity }} @@ -629,6 +631,7 @@ export default class Map extends PureComponent { } render() { + return (<View onLayout={(event) => { const { width, height } = event.nativeEvent.layout; |