前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mapboxGL中楼层的的展示与单体化(二)

mapboxGL中楼层的的展示与单体化(二)

作者头像
lzugis
发布2023-07-25 18:16:30
1760
发布2023-07-25 18:16:30
举报

概述

前文讲述如何在mapboxGL中如何实现楼层的展示与单体化选中效果,本文在前文的基础上优化高亮方式,实现点击楼层时弹出楼层。

实现效果

map1.gif
map1.gif

实现代码

1. 数据处理

代码语言:javascript
复制
const coords = [ [ [ 113.885632905452397, 22.552818892926712 ], [ 113.885771878698918, 22.553046303693751 ], [ 113.886302503822009, 22.553484279985827 ], [ 113.887106864127674, 22.554212836702447 ], [ 113.887443768967728, 22.554246527186454 ], [ 113.888075465542826, 22.55364430978485 ], [ 113.888214438789362, 22.553412687707311 ], [ 113.890008457062649, 22.551715529575528 ], [ 113.889991611820648, 22.55150075273999 ], [ 113.88778909642879, 22.549538282046655 ], [ 113.88754484041975, 22.549454055836641 ], [ 113.887182667716687, 22.549407731421134 ], [ 113.886353039548055, 22.54956776122016 ], [ 113.885784512630451, 22.549727791019198 ], [ 113.88556552448442, 22.550098386343258 ], [ 113.885632905452397, 22.552818892926712 ] ] ]
let lon = []
coords[0].forEach(([x, y]) => {
    lon.push(x)
})
lon = lon.sort((a, b) => a - b)
const deltX = lon[lon.length - 1] - lon[0]
const coordsHighlight = [
    coords[0].map(([x, y]) => [x - deltX, y])
]
const floorNums = 10, floorHeight = 20, floorTop = 2
let features = [], featuresH = []
for (let i = 0; i <= floorNums; i++) {
    const baseH = i * floorHeight,
        topH = baseH + floorHeight,
        h = topH - floorTop
    const feature = {
        "type": "Feature",
        "properties": {height: h, baseHeight: baseH, type: 'building', floor: i},
        "geometry": { "type": "Polygon", "coordinates": coords }
    }
    features.push(feature)
    features.push({
        "type": "Feature",
        "properties": {height: topH, baseHeight: h, type: 'top', floor: i},
        "geometry": { "type": "Polygon", "coordinates": coords }
    })
    featuresH.push({
      "type": "Feature",
      "properties": {height: h, baseHeight: baseH, type: 'building', floor: i},
      "geometry": { "type": "Polygon", "coordinates": coordsHighlight }
    })
}

2. 添加数据源和图层

代码语言:javascript
复制
map.addSource('building', {
 type: 'geojson',
 data: {
     "type": "FeatureCollection",
     "features": features
 }

.addSource('building-hightlight', {
 type: 'geojson',
 data: {
     "type": "FeatureCollection",
     "features": featuresH
 }

map.loadImage('', function (error, image) {
 if (error) throw error;
	map.addImage('building-wl', image);

	map.addLayer({
		 'id': '3d-buildings',
		 'source': 'building',
		 'type': 'fill-extrusion',
		 filter: ['==', ['get', 'type'], 'building'],
		 'paint': {
			 'fill-extrusion-color': '#ffffff',
			 'fill-extrusion-pattern': 'building-wl',
			 'fill-extrusion-height': ['get', 'height'],
			 'fill-extrusion-base': ['get', 'baseHeight'],
			 'fill-extrusion-opacity': 1
		 }
	 });
	 map.addLayer({
		 'id': '3d-buildings-top',
		 'source': 'building',
		 'type': 'fill-extrusion',
		 filter: ['==', ['get', 'type'], 'top'],
		 'paint': {
			 'fill-extrusion-color': [
				 'match',
				 ['get', 'floor'],
				 floorNums, '#bbb4ab',
				 '#ffffff'
			 ],
			 'fill-extrusion-height': ['get', 'height'],
			 'fill-extrusion-base': ['get', 'baseHeight'],
			 'fill-extrusion-opacity': 1
		 }
	 });

    map.addLayer({
        'id': '3d-buildings-highlight',
        'source': 'building-hightlight',
        'type': 'fill-extrusion',
        filter: ['==', ['get', 'floor'], -1],
        'paint': {
            'fill-extrusion-color': '#00ffe8',
            'fill-extrusion-pattern': 'building-wl',
            'fill-extrusion-height': ['get', 'height'],
            'fill-extrusion-base': ['get', 'baseHeight'],
            'fill-extrusion-opacity': 0.5
        }
    });
    map.addLayer({
        'id': '3d-buildings-top-highlight',
        'source': 'building-hightlight',
        'type': 'fill-extrusion',
        filter: ['==', ['get', 'floor'], -1],
        'paint': {
            'fill-extrusion-color': '#bbb4ab',
            'fill-extrusion-height': ['+', ['get', 'height'
            'fill-extrusion-base': ['get', 'height'],
            'fill-extrusion-opacity': 1
        }
    });
})

3. 添加交互

代码语言:javascript
复制
map.on('click', e => {
    map.setFilter('3d-buildings', ['!=', ['get', 'floor'], -1])
    map.setFilter('3d-buildings-highlight', ['==', ['get', 'floor'], -1])
    map.setFilter('3d-buildings-top-highlight', ['==', ['get', 'floor'], -1])
})
map.on('click', '3d-buildings', e => {
    const { properties } = e.features[0]
    map.setFilter('3d-buildings', ['!=', ['get', 'floor'], properties.floor])
    map.setFilter('3d-buildings-highlight', ['==', ['get', 'floor'], properties.floor])
    map.setFilter('3d-buildings-top-highlight', ['==', ['get', 'floor'], properties.floor])
})
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2023-07-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 概述
  • 实现效果
  • 实现代码
    • 1. 数据处理
      • 2. 添加数据源和图层
        • 3. 添加交互
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档