1. 地理可视化deck.gl基础使用

1. 简介

官网

文档写得还可以,实现原理到性能优化都包含了,就是感觉目录不是很循序渐进。

2. 使用

此时的我使用的deck版本是8.9.33

基础使用官网也有讲,结合示例代码就能实现。不再赘述基础概念。

ts 复制代码
// 这里为了又ts类型提示,引入的模块后面加了一个typed
// 下一个版本会默认拥有ts类型提示不需要加typed
import DeckGL from "@deck.gl/react/typed";
import { GeoJsonLayer } from "@deck.gl/layers/typed";
import { useState } from "react";
import { Layer, LayerExtension } from "@deck.gl/core/typed";

export default function App() {
// 新建图层组
  const layers = [
  // 新建GeoJson图层
    new GeoJsonLayer({
      id: "geojson",
      // 加载数据
      // 数据可以是字面量,或者一个网络地址,或者一个promise
      // 上面提到的类型都必须满足,返回一个有length属性的数据类型
      data: "/mapData.json",
      opacity: 0.8,
      stroked: false,
      filled: true,
      extruded: true,
      wireframe: true,
      getElevation: (f) => 2500,
      getLineColor: [255, 0, 0],
      pickable: true,
    }),
  ];
  return (
    <DeckGL
      layers={layers}
      // 设置初始view状态,主要是中心点、缩放等级、倾斜角度等
      initialViewState={{
        latitude: 30.298245137499997,
        longitude: 106.75365820549999,
        zoom: 11,
        maxZoom: 16,
        pitch: 45,
        bearing: 0,
      }}
      // 开始交互控制
      controller={true}
    ></DeckGL>
  );
}

这里黑黢黢的是因为我没设置填充颜色,不过地图样子还是能看出来。

2.1. 动态设置viewState

可能你想在后面的逻辑中修改viewState,这个时候就需要让state受控。

ts 复制代码
const APP = () => {
  const [viewState, setViewState] = useState({
    latitude: 30.298245137499997,
    longitude: 106.75365820549999,
    zoom: 11,
    maxZoom: 16,
    pitch: 45,
    bearing: 0,
  });
    return <DeckGL
      // 不能同时设置initialViewState和viewState
      viewState={viewState}
      // 记得在事件中更新
      // 因为deck内部状态是单向的
      onViewStateChange={(e) => setViewState(e.viewState)}
    ></DeckGL>
}

2.2. 中心点怎么来

deck的中心点并不能自动计算出来,只能手动设置。这里提供几种思路。

使用truf计算出来(推荐)

推荐这个方法的原因是,一般来说地图数据不会经常变,所以中心点计算一次就行了。

ts 复制代码
// 随便找个地方把中心点算一下
console.log(truf.center(mapData)); // [经度, 维度]
ts 复制代码
// 设置viewstate的时候直接写死
  initialViewState={{
    latitude: 30.298245137499997,
    longitude: 106.75365820549999,
    zoom: 11,
    maxZoom: 16,
    pitch: 45,
    bearing: 0,
  }}

使用fitBounds

这个方法只在WebMercatorViewport中有,这个其实就是默认的view,墨卡托投影。

ts 复制代码
const initialViewState = useMemo(() => {
// 这里计算逻辑仅供参考
// 没有考虑实际数据格式
  const minLat = Math.min(...mapData.map((l) => l.latitude))
  const maxLat = Math.max(...mapData.map((l) => l.latitude))
  const minLng = Math.min(...mapData.map((l) => l.longitude))
  const maxLng = Math.max(...mapData.map((l) => l.longitude))
  const southWest = [minLng, minLat]
  const northEast = [maxLng, maxLat]
    return new WebMercatorViewport({ width: 1920, height: 400 }).fitBounds([southWest, northEast], {padding: 200})
}, [mapData])
// 计算出来的initialViewState就可以给`deck`组件了

可以看到这个方法其实很麻烦,还要考虑视口宽高。

相关推荐
正小安1 小时前
如何在微信小程序中实现分包加载和预下载
前端·微信小程序·小程序
_.Switch3 小时前
Python Web 应用中的 API 网关集成与优化
开发语言·前端·后端·python·架构·log4j
一路向前的月光3 小时前
Vue2中的监听和计算属性的区别
前端·javascript·vue.js
长路 ㅤ   3 小时前
vite学习教程06、vite.config.js配置
前端·vite配置·端口设置·本地开发
长路 ㅤ   3 小时前
vue-live2d看板娘集成方案设计使用教程
前端·javascript·vue.js·live2d
Fan_web3 小时前
jQuery——事件委托
开发语言·前端·javascript·css·jquery
安冬的码畜日常3 小时前
【CSS in Depth 2 精译_044】第七章 响应式设计概述
前端·css·css3·html5·响应式设计·响应式
莹雨潇潇4 小时前
Docker 快速入门(Ubuntu版)
java·前端·docker·容器
Jiaberrr4 小时前
Element UI教程:如何将Radio单选框的圆框改为方框
前端·javascript·vue.js·ui·elementui
Tiffany_Ho5 小时前
【TypeScript】知识点梳理(三)
前端·typescript