百度GL地图实现选点获取经纬度并且地址逆解析

 

index.html引入

    <script src="https://api.map.baidu.com/api?type=webgl&v=1.0&ak=你的ak"></script>

 组件使用

            <el-input
                :disabled="['详情'].includes(title)"
                v-model="formData.site"
                placeholder=""
              >
                <template slot="append">
                  <el-button
                    type="primary"
                    icon="iconfont if-ditudingwei"
                    :disabled="['详情'].includes(title)"
                    style="color: #1492ff"
                    @click="choosePosition"
                    >选择
                  </el-button>
                </template>
              </el-input>



    <positionDialog @on-response="getPosition" ref="positionDialog" />

import positionDialog from "@/components/Map/positionDialog/positionDialog.vue";
  components: {positionDialog},



    getPosition(e) {
      console.log(e);
      this.$set(this.formData, "longitude", e.lng);
      this.$set(this.formData, "latitude", e.lat);
    },

    choosePosition() {
      let passData = {
        data: JSON.parse(JSON.stringify({
            lng: this.formData.longitude,
            lat: this.formData.latitude,
        })),
        type: "地图选点",
      };
      this.$refs.positionDialog.showDialog(passData);
    },

positionDialog组件封装

<template>
  <el-dialog
    width="1000px"
    v-dialog-drag
    :title="title"
    :visible.sync="dialogVisible"
    :before-close="hideDialog"
    append-to-body
  >
    <div class="wrap-box">
      <!-- 搜索显示框 -->
      <el-form v-if="!hasNoSearch" class="formWrap" label-width="90px">
        <el-col :span="12">
          <el-form-item
            label="搜索 : "
            prop="keyword"
            style="position: relative"
          >
            <el-input id="search" v-model="keyword" @input="searchPositionList">
            </el-input>
            <div class="wrap-search" v-if="searchList.length > 0">
              <div
                class="wrap-search-item"
                v-for="(item, index) in searchList"
                :key="index"
                @click="selectAddress(item)"
              >
                <div style="width: 80%">{{ item }}</div>
                <div style="width: 20%; text-align: right">
                  <i class="iconfont if-biaodancaozuo-fabu"></i>
                </div>
              </div>
            </div>
          </el-form-item>
          <!-- <label
            >搜索:<el-input v-model="keyword">
              <el-button
                slot="append"
                icon="el-icon-search"
              ></el-button></el-input
          ></label> -->
        </el-col>
        <el-col :span="6">
          <el-form-item label="经度: " prop="lng">
            <el-input v-model="formData.lng"></el-input>
          </el-form-item>
          <!-- <label>经度:<el-input v-model="formData.lng" /></label> -->
        </el-col>
        <el-col :span="6">
          <el-form-item label="纬度: " prop="lat">
            <el-input v-model="formData.lat" />
          </el-form-item>
        </el-col>
      </el-form>
      <!-- 地图盒子 -->
      <div id="allmap"></div>
    </div>
    <span slot="footer" class="dialog-footer">
      <el-button @click="hideDialog">取 消</el-button>
      <el-button type="primary" @click="submitForm">确 定</el-button>
    </span>
  </el-dialog>
</template>

<script>
export default {
  name: "positionDialog",
  components: {},
  props: {
    hasNoSearch: {
      type: Boolean,
      defalut: false, //是否有搜索框
    },
    hasNoChoosePosition: {
      type: Boolean,
      defalut: false, //是否可以改变选择的坐标点
    },
  },
  data() {
    return {
      dialogVisible: false,
      title: "",
      keyword: "",
      location: "",
      mapCenter: {
        lng: 103.653534,
        lat: 30.998257,
      },
      formData: {},
      mapZoom: 13,
      map: null,
      marker: null, //坐标点
      searchInput: null, //搜索
      searchList: [],
    };
  },
  methods: {
    // 选择检索的列表项
    selectAddress(value) {
      this.keyword = value;
      this.getAddress(value);
    },
    // 解析地址
    getAddress(e) {
      let that = this;
      let myGeo = new BMapGL.Geocoder();
      // 将地址解析结果显示在地图上,并调整地图视野
      myGeo.getPoint(
        e,
        function (point) {
          if (point) {
            console.log(point);
            point = {
              lng: point.lng.toFixed(6),
              lat: point.lat.toFixed(6),
            };
            that.$set(that.formData, "lng", point.lng);
            that.$set(that.formData, "lat", point.lat);

            that.map.centerAndZoom(new BMapGL.Point(point.lng, point.lat), 14); //设置中心点
            that.setMarker(point.lng, point.lat); //设置坐标点
            that.searchList = [];
          }
        },
        ""
      );
    },
    searchPositionList(e) {
      let that = this;
      let option = {
        onSearchComplete: function (results) {
          // 判断状态是否正确
          if (local.getStatus() == BMAP_STATUS_SUCCESS) {
            var list = [];
            for (var i = 0; i < results.getCurrentNumPois(); i++) {
              // console.log(results.getPoi(i));
              list.push(results.getPoi(i).address);
            }
            that.searchList = list;
          }
        },
        // pageCapacity: 5,
      };
      var local = new BMapGL.LocalSearch(this.map, option);
      local.search(e);
    },
    showDialog(data) {
      console.log("showDialog", data);
      this.title = data.type;
      this.formData = data.data;
      if (this.formData.lng && this.formData.lat) {
        this.mapCenter.lng = this.formData.lng;
        this.mapCenter.lat = this.formData.lat;
      }
      this.dialogVisible = true;
      this.initMap();
    },
    setMarker(lng, lat) {
      if (this.marker) {
        this.map.removeOverlay(this.marker);
        this.marker = null;
      }
      setTimeout(() => {
        let point = new BMapGL.Point(lng, lat); //创建点
        this.marker = new BMapGL.Marker(point); // 创建标注
        this.map.addOverlay(this.marker);
        console.log(lng, lat);
      }, 100);
    },

    hideDialog() {
      console.log("hideDialog");
      this.formData = {};
      this.keyword = "";
      this.dialogVisible = false;
    },
    getClickInfo(e) {
      console.log("地图点击", e);
    },
    submitForm() {
      if (!this.formData.lng || !this.formData.lat) {
        this.$message.error("请选择位置");
      } else {
        this.$emit("on-response", this.formData);

        this.hideDialog();
      }
    },
    initMap() {
      let that = this;
      this.$nextTick(() => {
        // 按住鼠标右键,修改倾斜角和角度
        this.map = new BMapGL.Map("allmap"); // 创建Map实例

        this.map.centerAndZoom(
          new BMapGL.Point(this.mapCenter.lng, this.mapCenter.lat),
          12
        ); // 初始化地图,设置中心点坐标和地图级别
        // this.searchInput = new BMapGL.Autocomplete({
        //   //建立一个自动完成的对象
        //   input: "search",
        //   location: this.map,
        // });
        this.setMarker(this.mapCenter.lng, this.mapCenter.lat);
        this.map.enableScrollWheelZoom(true); //开启鼠标滚轮缩放
        this.map.setHeading(64.5); //设置高度
        this.map.setTilt(0); //设置角度

        var geoc = new BMapGL.Geocoder();
        if (!this.hasNoChoosePosition) {
          this.map.addEventListener("click", function (e) {
            console.log(e);
            // let pt = {
            //   lng: e.latlng.lng.toFixed(6),
            //   lat: e.latlng.lat.toFixed(6),
            // };
            let pt = e.latlng
            that.$set(that.formData, "lat", pt.lat);
            that.$set(that.formData, "lng", pt.lng);
            // that.$set(that.mapCenter, "lat", pt.lat);
            // that.$set(that.mapCenter, "lng", pt.lng);
            that.setMarker(pt.lng, pt.lat);
            geoc.getLocation(pt, function (rs) {
              console.log(rs, "res")
              var addComp = rs.addressComponents;
              that.keyword =
                addComp.province +
                addComp.city +
                addComp.district +
                addComp.street +
                addComp.streetNumber;
            });
          });
        }
      });
    },
  },
  created() {},
  mounted() {
    // this.initMap();
  },
};
</script>

<style lang="scss" scoped>
::v-deep .el-dialog__body {
  padding: 10px 0 0 !important;
}
#allmap {
  height: 500px;
  width: 100%;
  overflow: hidden;
}
.wrap-box {
  position: relative;
  .formWrap {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 99999;
  }
  .wrap-search {
    position: absolute;
    z-index: 9999;
    width: 100%;
    background-color: #fff;
    box-shadow: 1px 1px 4px #f0f0f0;
    max-height: 300px;
    // width: 250px;
    overflow-y: auto;
    &-item {
      width: 100%;
      padding: 10px 10px;
      display: flex;
      justify-content: space-between;
      align-items: center;
      cursor: pointer;
      &:hover {
        background-color: #f0f0f0;
      }
    }
  }
}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/568511.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

OpenHarmony南向开发案例:【 智能家居中控】

应用场景简介 智能家居。 今天打造的这一款全新智能家庭控制系统&#xff0c;凸显应用在智能控制和用户体验的特点&#xff0c;开创国内智能家居系统体验新局面。新的系统主要应用在鸿蒙生态。 工程版本 系统版本/API版本&#xff1a;OpenHarmony SDK API 8IDE版本&#xf…

java使用Sokcet和ServerSocket类实现tcp通信

TCP通信&#xff1a; 面向连接&#xff0c;可靠通信 创建客户端程序&#xff0c;使用Socket类 Socket: public Socket(String host, int port) Creates a stream socket and connects it to the specified port number on the named host. 根据指定的服务器ip&#xff0c;…

软件测试——Postman Script脚本功能

Postman作为软件测试里一款非常流行的调试工具&#xff0c;给我们提供了一个执行JavaScript脚本的环境&#xff0c;所以我们可以使用js语言编写脚本来解决一些接口自动化的问题&#xff0c;比如接口依赖、接口断言等等。Postman有Pre-RequestScript和Tests两个编写js脚本的模块…

赛氪网参与第61届中国高等教育博览会,助力产教融合与科教融汇

为深入贯彻党的二十大精神&#xff0c;落实立德树人根本任务&#xff0c;推动高等教育装备现代化&#xff0c;第61届中国高等教育博览会&#xff08;以下简称“高博会”&#xff09;于近日在福建省福州市隆重开幕。作为高等教育领域内的综合性品牌博览会&#xff0c;此次高博会…

将MySQL数据库查询结果导出为txt文档,并建成实体类

目录 第一章、功能需求和分析1.1&#xff09;具体需求1.2&#xff09;分析需求转为小的问题1、如何获得数据库表的字段&#xff1f;2、如何将数据库查询结果导出&#xff1f;3.将获得的数据库查询结果转为驼峰式4.让AI建个实体类 友情提醒: 先看文章目录&#xff0c;大致了解文…

C语言之文件操作【万字详解】

目录 一.什么是文件&#xff1f; 二.为什么要使用文件&#xff1f; 三.文件的分类 3.1.程序文件 3.2.数据文件 四.二进制文件和文本文件 五.文件的打开和关闭 &#xff08;重点&#xff09; 5.1流和标准流 5.1.1何为流&#xff1f; 5.1.2.标准流 5.2文件指针 5.3文件的打开和关…

[Android]Jetpack Compose加载图标和图片

一、加载本地矢量图标 在 Android 开发中使用本地矢量图标是一种常见的做法&#xff0c;因为矢量图标&#xff08;通常保存为 SVG 或 Android 的 XML vector format&#xff09;具有可缩放性和较小的文件大小。 在 Jetpack Compose 中加载本地矢量图标可以使用内置的支持&…

ubuntu如何运行python程序

打开LINUX UBUNTU操作系统。 找到左边的TERMINAL&#xff0c;打开窗口。 输入python&#xff0c;如果没有安装&#xff0c;就会提示需要安装。 如果已经安装好python3&#xff0c;直接输入&#xff0c;那么就会进入。 exit()就可以退出python3的模式。 创建一个文件&#xff0c…

java多线程-悲观锁、乐观锁

简介 悲观锁&#xff1a;没有安全感&#xff0c;一上来就直接加锁&#xff0c;每次只能一个线程进入访问&#xff0c;访问完毕之后&#xff0c;再解锁。线程安全&#xff0c;但是性能差。乐观锁&#xff1a;很乐观&#xff0c;一开始不上锁&#xff0c;认为没有问题。等到要出现…

揭秘“磁盘管理未知没有初始化”背后的秘密与应对策略

在日常使用电脑的过程中&#xff0c;我们有时会遇到一个令人头疼的问题——磁盘管理显示“未知没有初始化”。这种情况意味着系统无法正确识别和管理该磁盘&#xff0c;导致我们无法访问其中的数据。那么&#xff0c;究竟什么是“磁盘管理未知没有初始化”&#xff1f;又该如何…

等保测评之主机测评详解(二级)

等保测评之主机测评详解&#xff08;二级&#xff09;服务器——Windows 身份鉴别: 测评项a&#xff09;&#xff1a; a&#xff09;应对登录的用户进行身份标识和鉴别&#xff0c;身份标识具有唯一性&#xff0c;身份鉴别信息具有复杂度要求并定期更换&#xff1b; 整改方…

案例:SpringBoot集成Sharding-JDBC实现分表分库与主从同步(详细版)

案例&#xff1a;SpringBoot集成Sharding-JDBC实现分表分库与主从同步&#xff1a;详细版 1. 案例分析2. 主从同步2.1 主从数据库准备2.2 简单插点数据 3 案例代码3.1 application.properties配置信息3.2 测试 4. 遇到的坑4.1 水平分表时的属性设置4.2 绑定表的配置 1. 案例分析…

C语言为什么没有应用层开发的库

C语言是一门“古老”的语言了&#xff0c;在中大型的应用层项目开发中&#xff0c;C,Java,Python,C# 等其他编程语言能够更好地胜任&#xff0c;为C语言开发应用层的库简直是费力不讨好&#xff0c;所以几乎没人这么做。在开始前我有一些资料&#xff0c;是我根据网友给的问题精…

退役军人档案管理系统|DW-S403是一套成熟系统

退役军人档案管理系统是一种专门用于管理退役军人档案的信息系统&#xff0c;旨在提高退役军人档案的管理效率和利用价值。该系统采用先进的信息技术手段&#xff0c;对退役军人的档案进行全面、精准、高效的管理&#xff0c;为退役军人的就业、社保、优抚安置等提供有力支持。…

FreeRTOS使用中断相关的函数导致程序卡死解决办法

1.现象 想在串口中断中实现任务通知的功能&#xff0c;所以在串口中断服务函数中使用了xTaskGenericNotifyFromISR&#xff08;&#xff09;函数来发送通知&#xff0c;发现一进入中断服务函数&#xff0c;程序就卡死了。下边是串口初始化和中断服务函数: void Usart_Init_U(…

这届年轻人,对AI对象上头

在AI技术飞速发展的今天&#xff0c;虚拟对象这一概念也流行了起来。从AI女友到AI男友&#xff0c;这些基于人工智能的AI社交应用正在改变我们对情感陪伴的认知。本文深入探讨了AI虚拟对象的兴起、用户需求、商业模式以及技术局限&#xff0c;不妨来看一下。 继2023年文生文大语…

标准版/开源版 移动端新增页面使用文档

在标准版开发的实际使用中&#xff0c;随着用户移动端的产品和信息内容不断增多&#xff0c;新增页面来展示对应的产品详情、模块等内容。针对一些概念或者步骤较多的内容&#xff0c;可以新增子页面构建多级模块结构&#xff0c;帮助用户快速定位。 下面就如何新增页面做一讲…

网际互联及OSI七层模型

1什么是OSI七层模型 2OSI每一个Layer的定义 及用途 3如何使用OSI参考模型分析网络通信过程 一、网际互联 &#xff08;一&#xff09;OSI的概念&#xff1a; open system interconnect开放系统互联参考模型&#xff0c;是有ISO&#xff08;国际标准化组织&#xff09;定义…

混合现实(MR)技术的应用场景

混合现实&#xff08;MR&#xff09;技术将虚拟世界和现实世界融合在一起&#xff0c;用户可以在现实世界中看到和与虚拟物体进行交互&#xff0c;同时还可以感知周围的真实环境。MR技术具有广阔的应用前景&#xff0c;可以应用于各行各业。以下是一些MR的应用场景。北京木奇移…

iOS ------代理 分类 拓展

代理协议 一&#xff0c;概念&#xff1a; 代理&#xff0c;又称委托代理&#xff08;delegate&#xff09;&#xff0c;是iOS中常用的一种设计模式。顾名思义&#xff0c;它是把某个对象要做的事委托给别的对象去做。那么别的对象就是这个对象的代理&#xff0c;代替它来打理…