Indoor Building Map
import React from 'react';
import { View, StyleSheet } from 'react-native';
import Mapbox from '@rnmapbox/maps';
import { Slider } from '@rneui/base';
import sheet from '../../styles/sheet';
import colors from '../../styles/colors';
import indoorMapGeoJSON from '../../assets/indoor_3d_map.json';
const styles = StyleSheet.create({
slider: {
alignItems: 'stretch',
flex: 1,
justifyContent: 'center',
maxHeight: 60,
paddingHorizontal: 24,
},
});
const layerStyles = {
building: {
fillExtrusionOpacity: 0.5,
fillExtrusionHeight: ['get', 'height'],
fillExtrusionBase: ['get', 'base_height'],
fillExtrusionColor: ['get', 'color'],
// fillExtrusionColorTransition: {duration: 2000, delay: 0},
},
};
class IndoorBuilding extends React.Component {
constructor(props) {
super(props);
this.state = {
sliderValue: -80,
};
this.onSliderChange = this.onSliderChange.bind(this);
}
onSliderChange(value) {
this.setState({ sliderValue: value });
}
render() {
return (
<>
<Mapbox.MapView
ref={(ref) => (this.map = ref)}
style={sheet.matchParent}
>
<Mapbox.Camera
zoomLevel={16}
pitch={40}
heading={20}
centerCoordinate={[-87.61694, 41.86625]}
/>
<Mapbox.Light style={{ position: [5, 90, this.state.sliderValue] }} />
<Mapbox.ShapeSource
id="indoorBuildingSource"
shape={indoorMapGeoJSON}
>
<Mapbox.FillExtrusionLayer
id="building3d"
style={layerStyles.building}
/>
</Mapbox.ShapeSource>
</Mapbox.MapView>
<View style={styles.slider}>
<Slider
value={this.state.sliderValue}
onValueChange={this.onSliderChange}
thumbTintColor={colors.primary.blue}
minimumValue={-180}
maximumValue={180}
thumbTouchSize={{ width: 44, height: 44 }}
maximumTrackTintColor={colors.secondary.purpleLight}
minimumTrackTintColor={colors.secondary.purpleDark}
/>
</View>
</>
);
}
}
export default IndoorBuilding;
}