2018-10-30 11:22:18 +08:00
|
|
|
<!DOCTYPE html>
|
|
|
|
<html lang="en">
|
|
|
|
<head>
|
|
|
|
<meta charset="UTF-8">
|
|
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
|
|
<meta http-equiv="X-UA-Compatible" content="ie=edge">
|
|
|
|
<meta name="geometry" content="diagram">
|
|
|
|
<link rel="stylesheet" href="./assets/common.css">
|
|
|
|
|
|
|
|
<title>dem demo</title>
|
|
|
|
<style>
|
|
|
|
#map { position:absolute; top:0; bottom:0; width:100%; }
|
|
|
|
</style>
|
|
|
|
</head>
|
|
|
|
|
|
|
|
<body>
|
|
|
|
<div id = 'gui' style="position:absolute;top:0px;right:0px;z-index:2;"></div>
|
|
|
|
<div id="map"></div>
|
|
|
|
<script src="https://webapi.amap.com/maps?v=1.4.8&key=15cd8a57710d40c9b7c0e3cc120f1200&plugin=Map3D"></script>
|
|
|
|
<script src="./assets/jquery-3.2.1.min.js"></script>
|
|
|
|
<script src="./assets/geotiff.browserify.min.js"></script>
|
|
|
|
<script src="../build/L7.js"></script>
|
|
|
|
<script>
|
|
|
|
|
|
|
|
const scene = new L7.Scene({
|
|
|
|
id: 'map',
|
|
|
|
viewMode: '3D',
|
|
|
|
mapStyle: 'amap://styles/ba3e9759545cd618392ef073c0dfda8c?isPublic=true', // 样式URL
|
2019-04-29 18:16:04 +08:00
|
|
|
center: [ 110.770672, 44.159869 ],
|
2018-10-30 11:22:18 +08:00
|
|
|
pitch: 0,
|
2019-04-29 18:16:04 +08:00
|
|
|
zoom: 3
|
2018-10-30 11:22:18 +08:00
|
|
|
});
|
|
|
|
|
2018-10-31 11:29:54 +08:00
|
|
|
scene.on('loaded', () => {
|
2018-10-30 11:22:18 +08:00
|
|
|
|
|
|
|
const xhr = new XMLHttpRequest();
|
|
|
|
xhr.open('GET', ' https://gw.alipayobjects.com/os/rmsportal/XKgkjjGaAzRyKupCBiYW.dat', true);
|
|
|
|
xhr.responseType = 'arraybuffer';
|
|
|
|
xhr.onload = function(e) {
|
|
|
|
if (this.status === 200) {
|
|
|
|
// get binary data as a response
|
|
|
|
const blob = this.response;
|
|
|
|
const tiff = GeoTIFF.parse(blob);
|
|
|
|
const image = tiff.getImage();
|
2019-04-29 18:16:04 +08:00
|
|
|
const values = image.readRasters()[0].values();
|
2018-10-30 11:22:18 +08:00
|
|
|
const m = image.getHeight();
|
|
|
|
const n = image.getWidth();
|
|
|
|
const layer = scene.RasterLayer({ zIndex: 2 }).
|
|
|
|
source(values, {
|
2019-02-25 23:56:37 +08:00
|
|
|
parser: {
|
|
|
|
type: 'raster',
|
|
|
|
width: n,
|
|
|
|
height: m,
|
|
|
|
min: 0,
|
|
|
|
max: 8000,
|
|
|
|
extent: [ 73.482190241, 3.82501784112, 135.106618732, 57.6300459963 ]
|
|
|
|
}
|
2018-10-30 11:22:18 +08:00
|
|
|
})
|
|
|
|
.style({
|
|
|
|
rampColors: {
|
|
|
|
colors: [ '#002466', '#0D408C', '#105CB3', '#1A76C7', '#2894E0', '#3CB4F0', '#65CEF7', '#98E3FA', '#CFF6FF', '#E8FCFF' ],
|
|
|
|
positions: [ 0, 0.02, 0.05, 0.1, 0.2, 0.3, 0.5, 0.6, 0.8, 1.0 ]
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.render();
|
2019-04-29 18:16:04 +08:00
|
|
|
console.log(layer);
|
2018-11-23 09:44:13 +08:00
|
|
|
|
2018-10-30 11:22:18 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
xhr.send();
|
|
|
|
});
|
|
|
|
|
|
|
|
</script>
|
|
|
|
</body>
|
|
|
|
</html>
|
|
|
|
|