当前位置: 首页 > article >正文

【vue baidu-map】实现百度地图展示基地,鼠标悬浮标注点展示详细信息

实现效果如下:

自用代码记录

<template>
  <div class="map" style="position: relative;">
    <baidu-map
      id="bjmap"
      :scroll-wheel-zoom="true"
      :auto-resize="true"
      @ready="handler"
    >
      <bm-marker
        v-for="(item, index) in markerList"
        :key="index"
        :position="item.position"
        :icon="item.icon"
        @click="handlerinfoWindowOpen(index)"
      >
        <bm-info-window
        
          :position="item"
          :show="item.show"
          @close="infoWindowClose(index)"
          @open="infoWindowOpen(index, item)"
          :auto-pan="true"
          :close-on-click="false"
        >
        <div>视频箭头</div>
          <!-- <div>
            <a
              href="#/internet"
              style="
                font-size: 15px;
                border-bottom: 1px #0464a4 solid;
                color: #0464a4;
              "
              >视频监控名称:{{ item.name }}</a
            > -->
            <!-- <video-player
              style="width: 200px; height: 100px"
              :ref="videoId"
              class="myPlayer"
              muted="true"
              :options="videoOptions"
            /> -->

            <!-- <span>企业名称:</span><span>{{current }}testt</span> -->
          <!-- </div> -->
        </bm-info-window>
      </bm-marker>
      <bm-polygon v-for="(markers, index) in planBaseMassifs" :key="index" :path="markers" :stroke-color="drawColor" :stroke-opacity="1" :stroke-weight="4" :fillColor="drawColors" :fillOpacity="1" />
      <div class="equipmentBox" v-if="equipmentType">
        <div
          :class="current == key ? 'item current' : 'item'"
          v-for="(value, key) in equipmentType"
          :key="key"
          @click="changeType(key)"
        >
          <div>{{ key }}</div>
          <div>({{ value }})</div>
        </div>
      </div>
      <div v-show="current == '视频监控'" class="equipmentBox1">
        <video-player
          style="width: 100%; height: 100%;position:absolute;"
          :ref="videoId"
          class="myPlayer"
          muted="true"
          :options="videoOptions"
        />
      </div>
    </baidu-map>
  </div>
</template>

<script>
// var echarts = require('echarts')
import { getPlantBases } from '@/api/table'
import { getUserEquipments ,getPageList} from '@/api/equipment'
// import { setServers } from 'dns';
// import { sumRpt } from '@/api/equipment'
import { staticResourceLocation } from '@/settings'
import defaultSettings from '@/settings'
import initData from '../../../mixins/initData'
import VideoPlayer from '@/views/components/videoPlayer.vue'
import { log } from 'video.js'

export default {
  props: {
    childrenData: {
      type: Object,
      default: function () {
        return {}
      },
    },
  },
  data() {
    return {
      staticResourceLocation,
      plantBaseList: [],
      screenHeight: window.innerHeight - 84, // 屏幕高度
      screenWidth: window.innerWidth,
      systitle: '',
      map: null,
      BMap: null,
      NavigationControl: null,
      MapTypeControl: null,
      // 设备列表
      equipmentList: [],
      planBaseMassifs:[],
      equipmentType: [],
      current: 'LED',
      markerList: [],
      videoOptions: {
        autoplay: false,
        controls: true,
      },
      videoId: '',
      drawColors: '#e9d99b',
      videoList: [],
      markers:[],
      drawColor: "#ff0000",
    }
  },
  components: { VideoPlayer },
  mounted() {
    var _this = this
    window.onresize = function () {
      // 定义窗口大小变更通知事件
      _this.screenHeight = document.documentElement.clientHeight - 84 // 窗口高度
      _this.screenWidth = document.documentElement.clientWidth // 窗口宽度
      //map.removeControl(NavigationControl)   //删除比例尺控件
      _this.map.removeControl(_this.NavigationControl)
      _this.map.removeControl(_this.MapTypeControl)
      _this.NavigationControl = new BMap.NavigationControl({
        // 地图平移缩放控件
        anchor: BMAP_ANCHOR_TOP_LEFT,
        type: BMAP_NAVIGATION_CONTROL_LARGE,
        offset: new BMap.Size(_this.screenWidth / 4 + 5, 10),
      })

      _this.MapTypeControl = new BMap.MapTypeControl({
        mapTypes: [BMAP_NORMAL_MAP, BMAP_SATELLITE_MAP, BMAP_HYBRID_MAP],
        offset: new BMap.Size(_this.screenWidth / 4 + 5, 10),
      })
      _this.map.addControl(_this.NavigationControl)
      _this.map.addControl(_this.MapTypeControl)
    }
    console.log(this.childrenData, 'childrenData--->statistics')
    this.equipmentType = this.childrenData.withCategory
    // sumRpt().then((res) => {
    //   if (res.body) {
    //     let { withCategory } = res.body
    //     this.equipmentType = withCategory
    //   }
    // })

    getUserEquipments().then((res) => {
      console.log('百度地图传的接口',res)
      this.equipmentList = res.body
      this.equipmentList.forEach((item) => {
        if (item.category === 1 && item.point) {
          var obj = {
            position: {
              lng: item.point.split(',')[0],
              lat: item.point.split(',')[1],
            },

            icon: {
              url: this.staticResourceLocation + 'static/LED.png',
              size: { width: 33, height: 33 },
              opts: {
                imageSize: { width: 33, height: 33 },
              },
            },
          }
          this.markerList.push(obj)
        } else if (item.category === 2) {
          var obj1 = {
            hdAddress: item.videoUrl,
            id: item.videoId,
          }
          this.videoList.push(obj1)

          let indexId = 0
          this.videoId = this.videoList[indexId].id
          this.$nextTick(function () {
            var _thisVideoRefs = this.$refs[this.videoList[indexId].id]
            if (_thisVideoRefs) {
              var player = _thisVideoRefs.player
              player.src(this.videoList[indexId].hdAddress)
              //player.play();
            }
          })
        }
      })
    })
  },
  beforeDestroy() {
    if (this.timer) {
      clearInterval(this.timer) // 在Vue实例销毁前,清除我们的定时器
    }
  },
  created() {},
  mixins: [initData],
  methods: {
    changeType(key) {
      this.markerList = []
      this.current = key
      var index =
        key == 'LED'
          ? 1
          : key == '视频监控'
          ? 2
          : key == '环境监测'
          ? 3
          : key == '水肥机'
          ? 4
          : key == '虫情测报灯'
          ? 5
          : key == '杀虫灯'
          ? 6
          : key == '智能控制柜'
          ? 7
          : 0
      // console.log(index)
      var iconPath = ''
      if (index == 1) {
        iconPath = this.staticResourceLocation + 'static/led.png'
      } else if (index == 2) {
        iconPath = this.staticResourceLocation + 'static/video.png'
      } else if (index == 3) {
        iconPath = this.staticResourceLocation + 'static/qxjc.png'
      } else if (index == 4) {
        iconPath = this.staticResourceLocation + 'static/jsgg.png'
      } else if (index == 5) {
        iconPath = this.staticResourceLocation + 'static/Insecticidal.png'
      } else if (index == 6) {
        iconPath = this.staticResourceLocation + 'static/scd.png'
      } else if (index == 7) {
        iconPath = this.staticResourceLocation + 'static/znkzk.png'
      }
      this.equipmentList.forEach((item) => {
        if (item.category === index && item.point) {
          var obj = {
            position: {
              lng: item.point.split(',')[0],
              lat: item.point.split(',')[1],
            },
            show: false,
            name: item.name,
            icon: {
              url: iconPath,
              size: { width: 33, height: 33 },
              opts: {
                imageSize: { width: 33, height: 33 },
              },
            },
          }
          this.markerList.push(obj)
        }
      })
      // console.log(this.markerList, 'kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk')
    },
    // gohome() {
    //   console.log('666')
    //   var user = this.$store.state.user.user
    //   if (user.homeUrl && user.homeUrl != '') {
    //     this.$router.push(user.homeUrl)
    //   } else {
    //     this.$router.push('/')
    //   }
    // },
    // redirectMonitor: function () {
    //   this.$router.push('/monitor/tine')
    // },
    handler({ BMap, map }) {
      this.map = map
      this.BMap = BMap
      getPlantBases().then((res) => {
        console.log(res.body, '百度地图')
        this.plantBaseList = res.body
        var point = ''
        this.plantBaseList.forEach((item) => {
          if (item.position) {
            point = new BMap.Point(
              item.position.split(',')[0],
              item.position.split(',')[1]
            )
          }
        })

        if (point === '') {
          point = new BMap.Point(107.034026, 33.073558)
        }
        map.centerAndZoom(point, 8) // 初始化地图,设置中心点坐标和地图级别

        map.enableScrollWheelZoom(true) // 启用滚轮放大缩小
        var myIcon = new BMap.Icon(
          'http://lyds.fengyuniot.com/content/upload/mappoint.png',
          new BMap.Size(40, 52),
          {
            anchor: new BMap.Size(10, 10),
          }
        )

        // var marker = new BMap.Marker(point) // 创建标注
        // map.addOverlay(marker) // 将标注添加到地图中
        var NavigationControl = new BMap.NavigationControl({
          // 地图平移缩放控件
          anchor: BMAP_ANCHOR_TOP_LEFT,
          type: BMAP_NAVIGATION_CONTROL_LARGE,
          offset: new BMap.Size(this.screenWidth / 4 + 5, 10),
        })
        this.NavigationControl = NavigationControl
        // 添加地图类型控件
        var MapTypeControl = new BMap.MapTypeControl({
          mapTypes: [BMAP_NORMAL_MAP, BMAP_SATELLITE_MAP, BMAP_HYBRID_MAP],
          offset: new BMap.Size(this.screenWidth / 4 + 5, 10),
        })
        this.MapTypeControl = MapTypeControl
        map.addControl(NavigationControl)
        map.setMapType(BMAP_HYBRID_MAP) // 调取地图类型混合型
        map.addControl(MapTypeControl)

        var markerArr = this.plantBaseList
        // console.log(this.plantBaseList, 'this.plantBaseList11111')
        markerArr.forEach((e, i) => {
          var positionArr = e.position.split(',')
          // console.log(e, 'errrrr')
          // console.log(e.plantBasePictures[0].pictureUrl, 'rrrrr')
          var background = ''
          if (e.plantBasePictures != null && e.plantBasePictures.length > 0) {
            background =
              defaultSettings.staticResourceLocation +
              e.plantBasePictures[0].pictureUrl
          }
          // console.log(background, 'background')
          let opts = {
            width: 200,
            height: 100,
          }
          // 创建point, 将x,y值传入
          const pointNumber = new BMap.Point(positionArr[0], positionArr[1])
          const infoWindow = new window.BMap.InfoWindow(
            "<div class='maptipsinfo'style='color:white;' ><a href='#/nutrientManagement'  style='font-size:15px;border-bottom:1px #0464A4 solid;color:#00fe8f;'><span>" +
              e.baseName +
              '</span></a>' +
              "<p style='font-size:14px;'><span>地址:</span>" +
              e.address +
              '</p>' +
              '<img  style="width:100%;height:80%;" src="' +
              background +
              '"/>' +
              '</div>',
            opts
          )
          // infoWindow.setStyle({
          // color: '#fff', // 字体颜色为白色
          // background: '#000', // 背景颜色为黑色
          // border: 'none', // 去掉边框
          // borderRadius: '5px', // 圆角半径
          // padding: '10px', // 内边距
          // fontSize: '14px', // 字体大小
          // lineHeight: '20px', // 行高
          // })
          var label = new BMap.Label(e.baseName, {
            offset: new BMap.Size(25, 5),
          })
          this.markerFun(map, pointNumber, infoWindow, label, myIcon)
        })
      })
        const params = {
        pageIndex: this.pageIndex,
        pageSize: this.pageSize,
        enterPriseId: this.enterPriseId,
      }
      getPageList(params).then((res)=>{
        console.log(res,'你好555555555555');
        // planBaseMassifs
        if(res.errorCode == 20000){
           const  array  = res.body.list
           const innerObjects = [];
           for (let i = 0; i < array .length; i++) {
            const innerObject  = array [i].planBaseMassifs;
            innerObjects.push(innerObject)

          }
          this.planBaseMassifs = innerObjects
          console.log(this.planBaseMassifs,'this.planBaseMassifs');
            // 使用map()方法遍历嵌套数组
            let modifiedArray = innerObjects.map((subArray) => {
          // 检查子数组是否为null
              if (subArray === null) {
                return [];
              }

              // 使用map()方法遍历子数组中的每个对象
              return subArray.map((obj) => {
                // 替换属性名
                obj.lat = obj.latitude;
                obj.lng = obj.longitude;
                delete obj.latitude;
                delete obj.longitude;

                // 处理null值
                if (obj === null) {
                  return {};
                } else {
                  return obj;
                }
              });
            }).filter((subArray) => subArray.length > 0);

            for (let i = 0; i < modifiedArray.length; i++) {
                // 获取每个子数组的第一行内容
                let firstRow = modifiedArray[i][0];

                // modifiedArray
                modifiedArray[i].push(firstRow);
              }
              this.planBaseMassifs = modifiedArray

        }
      })
    },

    markerFun: function (map, points, infoWindows, label, myIcon) {
      console.log('1111a',map,points, infoWindows, label, myIcon,)
      const markers = new BMap.Marker(points, { icon: myIcon })
      map.addOverlay(markers) // 将标注添加到地图中
      // markers.setLabel(label);  // 将data中的name添加到地图中
      // 标注的点击事件
      markers.addEventListener('mouseover', function (event) {
        map.openInfoWindow(infoWindows, points) // 参数:窗口、点  根据点击的点出现对应的窗口
      })
      // console.log('1a')
    },
    infoWindowOpen(index, item) {
      if (this.current == '视频监控') {
        this.markerList[index].show = true
        let indexId = index
        this.videoId = this.videoList[indexId].id
        this.$nextTick(function () {
          var _thisVideoRefs = this.$refs[this.videoList[indexId].id]
          // console.log(this.videos,_thisVideoRefs,'_thisVideoRefs_thisVideoRefs')
          if (_thisVideoRefs) {
            var player = _thisVideoRefs.player
            // console.log(player.src,'_thisVideoRefs11')

            player.src(this.videoList[indexId].hdAddress)
            //player.play();
          }
        })
      }
    },
    infoWindowClose(index) {
      this.markerList[index].show = false
    },
    handlerinfoWindowOpen(index) {
      this.markerList[index].show = true
      console.log('点击标记点',index)
      this.show = true
      if (this.current == '视频监控') {
        this.markerList[index].show = true
        let indexId = index
        this.videoId = this.videoList[indexId].id
        this.$nextTick(function () {
          var _thisVideoRefs = this.$refs[this.videoList[indexId].id]
          if (_thisVideoRefs) {
            var player = _thisVideoRefs.player
            player.src(this.videoList[indexId].hdAddress)
            //player.play();
          }
        })
      }
    },
    // handlerinfoWindowOpen(index) {
    //   this.markerList[index].show = true
    //   console.log('点击标记点',this.markerList[index].show)
    //   this.show = true
    //   if (this.current == '视频监控') {
    //     this.markerList[index].show = true
    //     let indexId = index
    //     this.videoId = this.videoList[indexId].id
    //     this.$nextTick(function () {
    //       var _thisVideoRefs = this.$refs[this.videoList[indexId].id]
    //       if (_thisVideoRefs) {
    //         var player = _thisVideoRefs.player
    //         player.src(this.videoList[indexId].hdAddress)
    //         //player.play();
    //       }
    //     })
    //   }
    // },
    // 异步调用百度js
    map_load() {
      var load = document.createElement('script')
      load.src = 'http://api.map.baidu.com/api?v=1.4&callback=map_init'
      document.body.appendChild(load)
    },
  },
}
</script>

<style scoped lang="scss">
/*地图提示*/

.equipmentBox {
  /* width: 240px; */
  // position: absolute;
  // top: 70px;
  // right: calc(25vw + 5px);
  position: absolute;
  top: 70px;
  right: 5px;
}
.equipmentBox1 {
  width: 260px;
  position: absolute;
  bottom: 35%;
  right: calc(25vw + 5px);
}

.equipmentBox .item {
  display: flex;
  justify-content: space-around;
  align-items: center;
  width: 108px;
  height: 27px;
  border-radius: 14px;
  background-color: #fff;
  color: #010101;
  font-size: 12px;
  font-weight: bold;
  cursor: pointer;
  margin-bottom: 5px;
  text-align: right;
}

.equipmentBox .current {
  background-color: #00b065;
  color: #fff;
}
// 地图
.map{
  width:100%;
  height: 100%;
}
.map .maptipsinfo p {
  font-size: 14px;
  line-height: 14px;
  height: 14px;
  color: #777;
}
.maptipsinfo a:hover {
  color: #0696f9;
  border-color: #0696f9;
}
.maptipsinfo span {
  color: #333;
}
.maptipsinfo {
  background: url();
}
.map #bjmap {
  width: 100%;
  height: 100%;
  display: inline-block;
  vertical-align: baseline;
  /* position: fixed; */
  div:first-of-type{
  border-radius: 15px !important;
}
}
.map #bjmap>div:first-of-type{
  border-radius: 15px !important;
}
.map .nowdatatime {
  border: 1px solid #00c7dd;
  background: rgba(0, 0, 0, 0.6);
  box-shadow: 0 0 10px rgba(1, 129, 143, 0.8);
  position: relative;
  top: -97%;
  padding: 10px;
  width: 240px;
  margin: 0 auto;
  text-align: center;
  border-radius: 5px;
  font-size: 1.5rem;
}
.imgss {
  height: 30px;
  width: 30px;
}
/*.map .el-loading-spinner .circular{
  width: 80px;
  height: 80px;
  animation: loading-rotate 2s linear infinite;

} */
/*.map  .el-loading-spinner{
  background: url(../../assets/img/default_img.gif) no-repeat;
  background-size: 80px 80px;
  width: 100%;
  height: 100%;
  position: relative;
  top: 45%;
  left: calc(50% - 40px);
} */

// /deep/.BMap_pop img,
// /deep/.BMap_top,
// /deep/.BMap_center,
// /deep/.BMap_bottom,
// /deep/.BMap_pop > div {
//   &:not(:nth-child(9)) {
//     display: none;
//   }
// }

// /deep/.BMap_pop div:nth-child(9) {
//   // top: 30px !important;
// }
// /deep/.BMap_bubble_content {
//   // border-top: 3px solid #377abd;
//   border-top: 3px solid rgba(44, 55, 47, 0.3);
//   // border-bottom: 3px solid #377abd;
//   border-bottom: 3px solid rgba(44, 55, 47, 0.3);
//   border-radius: 8px;
//   // background-color: rgba(36, 105, 137, 0.8);
//   background-color: rgba(44, 55, 47, 0.4);
//   overflow: hidden;
//   color: #ffffff;
//   padding: 8px 5px;
//   font-size: 14;
// }
.baidu-map-con {
  background-color: #043f31;
  // width: 100%;
  // height: 100%;
}
::v-deep #bjmap .BMap_stdMpCtrl{
  inset: 30px auto auto 10px !important;
}
// ::v-deep #bjmap .BMap_noprint {
//   inset: 10px 90% auto auto !important;
// }
::v-deep #bjmap .anchorTR{
  inset: 5px 91% auto auto !important;
}
::v-deep #bjmap .BMap_stdMpCtrl{
  //inset: 40px auto auto 30px !important;
}
// marker颜色
::v-deep .BMap_bubble_title{
  color:#fff;
  font-size:18px;
  /*font-weight: bold;*/
  text-align:left;
  background:transparent !important;
}

::v-deep .BMap_pop .BMap_top{
  background:#043f31 !important;
  border:0 !important;
}
::v-deep .BMap_pop .BMap_center{
  width:251px !important;
  // height: 300px !important;
  border:0 !important;
  background:#043f31 !important;
}
::v-deep .BMap_pop .BMap_bottom{
  border:0 !important;
  background:#043f31 !important;
}

::v-deep .BMap_pop div:nth-child(3){
  background:transparent !important;
}
::v-deep .BMap_pop div:nth-child(3) div{
  border-radius:7px;
  background:#043f31 !important;
  border:0 !important;
}
::v-deep .BMap_pop div:nth-child(1){
  border-radius:7px 0 0 0;
  background:transparent !important;
  border:0 !important;
}
::v-deep .BMap_pop div:nth-child(1) div{
  background:#043f31 !important;
}
::v-deep .BMap_pop div:nth-child(5){
  border-radius:0 0 0 7px;
  background:transparent !important;
  border:0 !important;
}
::v-deep .BMap_pop div:nth-child(5) div{
  border-radius:7px;
  background:#043f31 !important;
}
::v-deep .BMap_pop div:nth-child(7){
  background:transparent !important;
}
::v-deep .BMap_pop div:nth-child(7) div{
  border-radius:7px;
  background:#043f31 !important;
}

::v-deep .BMap_pop div:nth-child(8) div{
  /*border-radius:7px;*/
  background:#043f31 !important;
}
/*窗体阴影*/
::v-deep .BMap_shadow div:nth-child(5) img{
  margin-left: -1100px !important;
}

::v-deep .BMap_shadow div:nth-child(4){
  width: 262px !important;
}
::v-deep img[src="http://api0.map.bdimg.com/images/iw3.png"] {
  content: url('../../../assets/mapMarker.png');
}
::v-deep img[src="https://api.map.baidu.com/images/iw3.png"] {
  margin-top: -692px !important;
  filter: alpha(opacity=70);
  content: url('../../../assets/mapMarker.png');
}


</style>
<style>
#bjmap>div:first-of-type{
/* border-radius: 15px; */
}

</style>


http://www.kler.cn/a/272840.html

相关文章:

  • ElasticSearch下
  • 大疆发布可折叠航拍无人机,仅重249g,支持 4800 万像素拍摄
  • YOLOv10-1.1部分代码阅读笔记-build.py
  • Java基础:equals()方法与==的区别
  • SuperMap iClient3D for Cesium立体地图选中+下钻特效
  • ClickHouse-CPU、内存参数设置
  • C语言深入理解指针(4)
  • KD-Tree的原理及其在KNN中的应用(附Python代码)
  • flask 继续学习
  • 微信小程序小案例实战
  • c语言大小写字母的转换
  • 用C语言链表实现图书管理
  • 23.1 微服务理论基础
  • 本人遇到大数据面试题和参考答案(超过1万字精华版)
  • LLM大模型统一封装接口解决方案
  • 论文笔记:Llama 2: Open Foundation and Fine-Tuned Chat Models
  • VMware 16下载安装,多图详细版
  • vue3+element-plus中dialog对话框组件去掉遮罩层后可以操作底层页面,以及弹窗嵌套弹窗如何去掉遮罩层且可以操作底层页面
  • MySQL学习Day32——数据库备份与恢复
  • 阿里云服务器配置怎么选择?
  • 本地虚拟机安装与网络配置
  • 数仓建模简介
  • 机器学习揭秘:如何让你的电脑变身智能侦探,预测未来趋势!
  • Spring集成hazelcast实现分布式缓存
  • Unity PS5开发 天坑篇 之 DEVKit环境部署与系统升级02
  • 什么是React属性钻取(Prop Drilling)