好客租房169-渲染所有区的覆盖物

简介: 好客租房169-渲染所有区的覆盖物

图片.png

import React from 'react'
// 导入axios
import axios from 'axios'
// 导入封装好的 NavHeader 组件
import NavHeader from '../../components/NavHeader'
// 导入样式
// import './index.scss'
import styles from './index.module.css'
// 解决脚手架中全局变量访问的问题
const BMapGL = window.BMapGL
// 覆盖物样式
const labelStyle = {
  cursor: 'pointer',
  border: '0px solid rgb(255, 0, 0)',
  padding: '0px',
  whiteSpace: 'nowrap',
  fontSize: '12px',
  color: 'rgb(255, 255, 255)',
  textAlign: 'center'
}
export default class Map extends React.Component {
  componentDidMount() {
    this.initMap()
  }
  // 初始化地图
  initMap() {
    // 获取当前定位城市
    const { label, value } = JSON.parse(localStorage.getItem('hkzf_city'))
    // console.log(label, value)
    // 初始化地图实例
    const map = new BMapGL.Map('container')
    // 创建地址解析器实例
    const myGeo = new BMapGL.Geocoder()
    // 将地址解析结果显示在地图上,并调整地图视野
    myGeo.getPoint(
      label,
      async point => {
        if (point) {
          //  初始化地图
          map.centerAndZoom(point, 11)
          // 添加常用控件
          map.addControl(new BMapGL.NavigationControl())
          map.addControl(new BMapGL.ScaleControl())
          /* 
            1 获取房源数据。
            2 遍历数据,创建覆盖物,给每个覆盖物添加唯一标识(后面要用)。
            3 给覆盖物添加单击事件。
            4 在单击事件中,获取到当前单击项的唯一标识。
            5 放大地图(级别为13),调用 clearOverlays() 方法清除当前覆盖物。
          */
          const res = await axios.get(
            `http://localhost:8080/area/map?id=${value}`
          )
          console.log('房源数据:', res)
          res.data.body.forEach(item => {
            // 为每一条数据创建覆盖物
            const {
              coord: { longitude, latitude },
              label: areaName,
              count,
              value
            } = item
            // 创建覆盖物
            const areaPoint = new BMapGL.Point(longitude, latitude)
            const label = new BMapGL.Label('', {
              position: areaPoint,
              offset: new BMapGL.Size(-35, -35)
            })
            // 给 label 对象添加一个唯一标识
            label.id = value
            // 设置房源覆盖物内容
            label.setContent(`
              <div class="${styles.bubble}">
                <p class="${styles.name}">${areaName}</p>
                <p>${count}套</p>
              </div>
            `)
            // 设置样式
            label.setStyle(labelStyle)
            // 添加单击事件
            label.addEventListener('click', () => {
              console.log('房源覆盖物被点击了', label.id)
              // 放大地图,以当前点击的覆盖物为中心放大地图
              // 第一个参数:坐标对象
              // 第二个参数:放大级别
              map.centerAndZoom(areaPoint, 13)
              // 解决清除覆盖物时,百度地图API的JS文件自身报错的问题
              setTimeout(() => {
                // 清除当前覆盖物信息
                map.clearOverlays()
              }, 0)
            })
            // 添加覆盖物到地图中
            map.addOverlay(label)
          })
        }
      },
      label
    )
  }
  render() {
    return (
      <div className={styles.map}>
        {/* 顶部导航栏组件 */}
        <NavHeader>地图找房</NavHeader>
        {/* 地图容器元素 */}
        <div id="container" className={styles.container} />
      </div>
    )
  }
}

运行结果

图片.png

相关文章
|
定位技术
好客租房174-地图找房createReact方法绘制小区覆盖物
好客租房174-地图找房createReact方法绘制小区覆盖物
151 0
好客租房174-地图找房createReact方法绘制小区覆盖物
好客租房167-绘制房源覆盖物
好客租房167-绘制房源覆盖物
183 0
好客租房167-绘制房源覆盖物
|
索引
好客租房144-渲染城市列表
好客租房144-渲染城市列表
130 0
好客租房144-渲染城市列表
|
定位技术
好客租房164-地图找房导航栏样式调整
好客租房164-地图找房导航栏样式调整
91 0
好客租房164-地图找房导航栏样式调整
|
定位技术
好客租房173-地图找房createCircle方法
好客租房173-地图找房createCircle方法
212 0
好客租房173-地图找房createCircle方法
好客租房146-渲染(展示索引下每一行的高度)
好客租房146-渲染(展示索引下每一行的高度)
107 0
好客租房146-渲染(展示索引下每一行的高度)
|
定位技术
好客租房125-顶部导航
好客租房125-顶部导航
99 0
好客租房125-顶部导航
好客租房140-长列表性能优化(可视区域渲染)
好客租房140-长列表性能优化(可视区域渲染)
98 0
好客租房140-长列表性能优化(可视区域渲染)
|
定位技术 API
好客租房130-获取顶部导航信息
好客租房130-获取顶部导航信息
141 0
好客租房130-获取顶部导航信息