antv-l7/packages/site/examples/raster/single_raster/demo/light.js

60 lines
1.6 KiB
JavaScript
Raw Permalink Normal View History

2020-01-03 14:43:51 +08:00
// https://gw.alipayobjects.com/zos/antvdemo/assets/2019_clip/ndvi_201905.tif
2020-01-02 20:14:25 +08:00
import { RasterLayer, Scene } from '@antv/l7';
import { GaodeMap } from '@antv/l7-maps';
import * as GeoTIFF from 'geotiff';
const scene = new Scene({
id: 'map',
map: new GaodeMap({
style: 'dark',
2022-01-24 19:32:06 +08:00
center: [ 105, 37.5 ],
zoom: 2.5
2020-01-02 20:14:25 +08:00
})
});
2020-03-15 20:09:16 +08:00
scene.on('loaded', () => {
addLayer();
});
2020-01-02 20:14:25 +08:00
async function getTiffData() {
const response = await fetch(
2020-01-08 17:54:23 +08:00
'https://gw.alipayobjects.com/zos/antvdemo/assets/light_clip/lightF182013.tiff'
2020-01-02 20:14:25 +08:00
);
const arrayBuffer = await response.arrayBuffer();
const tiff = await GeoTIFF.fromArrayBuffer(arrayBuffer);
const image = await tiff.getImage();
const width = image.getWidth();
const height = image.getHeight();
const values = await image.readRasters();
return {
data: values[0],
width,
2020-01-03 14:43:51 +08:00
height
2020-01-02 20:14:25 +08:00
};
}
async function addLayer() {
const tiffdata = await getTiffData();
const layer = new RasterLayer({});
layer
.source(tiffdata.data, {
parser: {
type: 'raster',
width: tiffdata.width,
height: tiffdata.height,
2020-01-03 14:43:51 +08:00
extent: [ 73.4821902409999979, 3.8150178409999995, 135.1066187319999869, 57.6300459959999998 ]
2020-01-02 20:14:25 +08:00
}
})
.style({
2020-01-08 17:54:23 +08:00
clampLow: false,
clampHigh: false,
2020-01-03 14:43:51 +08:00
domain: [ 0, 90 ],
nodataValue: 0,
2020-01-02 20:14:25 +08:00
rampColors: {
type:'linear', // 2.13.0 及以后版本支持
colors: ['rgba(92,58,16,0)','rgba(92,58,16,0)', '#fabd08', '#f1e93f', '#f1ff8f', '#fcfff7' ],
positions: [0,3, 9, 22.5, 45, 90 ]
2020-01-02 20:14:25 +08:00
}
});
scene.addLayer(layer);
}