Skip to content

Commit

Permalink
Improve TerrainLayer loading experience (#4312)
Browse files Browse the repository at this point in the history
  • Loading branch information
Pessimistress authored Feb 26, 2020
1 parent add2cef commit 6a65e73
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 18 deletions.
2 changes: 1 addition & 1 deletion docs/layers/terrain-layer.md
Original file line number Diff line number Diff line change
Expand Up @@ -158,7 +158,7 @@ Set `workerUrl` to empty string to disable worker (improves error messages).

##### `color` (Color, optional)

Color to use before `surfaceImage` is loaded or if `surfaceImage` is unavailable. Equivalent to setting SimpleMeshLayer `getColor` prop to `d => prop.color`.
Color to use if `surfaceImage` is unavailable. Equivalent to setting SimpleMeshLayer `getColor` prop to `d => prop.color`.

- Default: `[255, 255, 255]`

Expand Down
38 changes: 22 additions & 16 deletions modules/geo-layers/src/terrain-layer/terrain-layer.js
Original file line number Diff line number Diff line change
Expand Up @@ -61,13 +61,15 @@ const defaultProps = {
*/
export default class TerrainLayer extends CompositeLayer {
updateState({props, oldProps}) {
if (props.terrainImage !== oldProps.terrainImage) {
const terrainImageChanged = props.terrainImage !== oldProps.terrainImage;
if (terrainImageChanged) {
const isTiled = props.terrainImage.includes('{x}') && props.terrainImage.includes('{y}');
this.setState({isTiled});
}

// Reloading for single terrain mesh
const shouldReload =
terrainImageChanged ||
props.meshMaxError !== oldProps.meshMaxError ||
props.elevationDecoder !== oldProps.elevationDecoder ||
props.bounds !== oldProps.bounds;
Expand All @@ -93,11 +95,17 @@ export default class TerrainLayer extends CompositeLayer {
}

getTiledTerrainData({bbox, x, y, z}) {
const {terrainImage, elevationDecoder, meshMaxError, workerUrl} = this.props;
const {terrainImage, surfaceImage, elevationDecoder, meshMaxError, workerUrl} = this.props;
const url = terrainImage
.replace('{x}', x)
.replace('{y}', y)
.replace('{z}', z);
const surfaceUrl = surfaceImage
? surfaceImage
.replace('{x}', x)
.replace('{y}', y)
.replace('{z}', z)
: false;

const viewport = new WebMercatorViewport({
longitude: (bbox.west + bbox.east) / 2,
Expand All @@ -108,34 +116,32 @@ export default class TerrainLayer extends CompositeLayer {
const topRight = viewport.projectFlat([bbox.east, bbox.north]);
const bounds = [bottomLeft[0], bottomLeft[1], topRight[0], topRight[1]];

return this.loadTerrain({
const terrain = this.loadTerrain({
terrainImage: url,
bounds,
elevationDecoder,
meshMaxError,
workerUrl
});
const texture = surfaceUrl
? // If surface image fails to load, the tile should still be displayed
load(surfaceUrl).catch(_ => null)
: Promise.resolve(null);

return Promise.all([terrain, texture]);
}

renderSubLayers(props) {
const {x, y, z} = props.tile;
const surfaceUrl = props.surfaceImage
? props.surfaceImage
.replace('{x}', x)
.replace('{y}', y)
.replace('{z}', z)
: false;

return new SimpleMeshLayer({
id: props.id,
wireframe: props.wireframe,
mesh: props.data,
mesh: props.data.then(([mesh]) => mesh),
data: [1],
texture: surfaceUrl,
texture: props.data.then(([, texture]) => texture),
getPolygonOffset: null,
coordinateSystem: COORDINATE_SYSTEM.CARTESIAN,
getPosition: d => [0, 0, 0],
getColor: d => props.color
getColor: props.color
});
}

Expand All @@ -155,7 +161,7 @@ export default class TerrainLayer extends CompositeLayer {
getTileData: this.getTiledTerrainData.bind(this),
renderSubLayers: this.renderSubLayers,
updateTriggers: {
getTileData: {terrainImage, meshMaxError, elevationDecoder}
getTileData: {terrainImage, surfaceImage, meshMaxError, elevationDecoder}
}
});
}
Expand All @@ -168,7 +174,7 @@ export default class TerrainLayer extends CompositeLayer {
mesh: this.state.terrain,
texture: surfaceImage,
getPosition: d => [0, 0, 0],
getColor: d => color,
getColor: color,
wireframe
}
);
Expand Down
3 changes: 2 additions & 1 deletion website/src/components/demos/terrain-demo.js
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,8 @@ const LOCATIONS = {
const SURFACE_IMAGES = {
Sectional: 'https://wms.chartbundle.com/tms/1.0.0/sec/{z}/{x}/{y}.png?origin=nw',
Satellite: `https://api.mapbox.com/v4/mapbox.satellite/{z}/{x}/{y}@2x.png?access_token=${MAPBOX_TOKEN}`,
Street: 'https://c.tile.openstreetmap.org/{z}/{x}/{y}.png'
Street: 'https://c.tile.openstreetmap.org/{z}/{x}/{y}.png',
None: null
};

export default class TerrainDemo extends Component {
Expand Down

0 comments on commit 6a65e73

Please sign in to comment.