发送百度地图的定位

news2025/4/23 7:28:21

在vue+php写的聊天软件项目中,增加一个发送百度地图的定位功能

在 Vue + PHP 的聊天软件中增加发送百度地图定位功能,需要从前端定位获取、地图API集成、后端存储到消息展示全流程实现。以下是详细步骤:

一、前端实现(Vue/Uni-app部分)

1. 申请百度地图API Key

前往百度地图开放平台注册开发者账号

创建应用,获取JavaScript API的AK(需启用「浏览器端」和「逆地理编码」服务)

2. 添加定位按钮

在聊天输入工具栏中添加定位按钮(与你的UI风格保持一致):

vue:

<view @click="getLocation" class="toolbar-item" hover-class="toolbar-item-hover">
  <image src="/static/icon/map.png"></image>
  <view>发送位置</view>
</view>

3. 实现定位逻辑

在Vue的methods中添加以下方法:

javascript:

methods: {
  // 获取当前位置
  getLocation() {
    if (!navigator.geolocation) {
      uni.showToast({ title: '您的设备不支持定位', icon: 'none' });
      return;
    }

    uni.showLoading({ title: '定位中...' });
    
    navigator.geolocation.getCurrentPosition(
      async (position) => {
        const { latitude, longitude } = position.coords;
        await this.sendBaiduLocation(latitude, longitude);
        uni.hideLoading();
      },
      (error) => {
        uni.hideLoading();
        uni.showToast({ title: `定位失败: ${error.message}`, icon: 'none' });
      },
      { enableHighAccuracy: true, timeout: 10000 }
    );
  },

  // 使用百度API解析地址并发送
  async sendBaiduLocation(lat, lng) {
    try {
      // 1. 加载百度地图脚本(需在index.html中引入)
      await this.loadBaiduMapScript();
      
      // 2. 反向地理编码获取地址
      const address = await new Promise((resolve) => {
        const geocoder = new BMapGL.Geocoder();
        geocoder.getLocation(new BMapGL.Point(lng, lat), (res) => {
          resolve(res.address || `${lat.toFixed(6)},${lng.toFixed(6)}`);
        });
      });

      // 3. 发送到后端
      this.$socket.emit('sendMessage', {
        type: 'baidu_location',
        lat,
        lng,
        address,
        timestamp: Date.now()
      });

      // 4. 本地即时显示(可选)
      this.addLocalMessage({
        type: 'baidu_location',
        lat,
        lng,
        address,
        sender: 'me'
      });

    } catch (err) {
      console.error('定位发送失败:', err);
      uni.showToast({ title: '位置解析失败', icon: 'none' });
    }
  },

  // 动态加载百度地图API
  loadBaiduMapScript() {
    return new Promise((resolve) => {
      if (window.BMapGL) return resolve();
      
      const script = document.createElement('script');
      script.src = `https://api.map.baidu.com/api?v=3.0&ak=您的百度AK&callback=initBMap`;
      document.head.appendChild(script);
      
      window.initBMap = () => resolve();
    });
  }
}

4. 渲染定位消息

在消息列表组件中添加对定位消息的渲染:

vue:

<view v-else-if="message.type === 'baidu_location'" class="location-message">
  <view class="location-title">位置分享</view>
  <view class="location-address">{{ message.address }}</view>
  <!-- 百度地图静态图 -->
  <image 
    :src="`https://api.map.baidu.com/staticimage/v2?ak=您的百度AK&center=${message.lng},${message.lat}&zoom=15&markers=${message.lng},${message.lat}`"
    mode="widthFix" 
    @click="openBaiduMap(message)"
  />
  <view class="location-tips">点击查看详情</view>
</view>

二、后端实现(PHP部分)

1. 数据库存储

修改messages表结构:

sql:

ALTER TABLE messages ADD COLUMN 
  location_data JSON COMMENT '定位数据{lat,lng,address}';

2. 接收定位消息

在消息处理接口中增加对定位类型的处理:

php:

// 处理WebSocket或HTTP请求
public function handleLocationMessage($data) {
    $message = [
        'type' => 'baidu_location',
        'content' => json_encode([
            'lat' => filter_var($data['lat'], FILTER_VALIDATE_FLOAT),
            'lng' => filter_var($data['lng'], FILTER_VALIDATE_FLOAT),
            'address' => htmlspecialchars($data['address'])
        ]),
        'sender_id' => $this->getUserId(),
        'created_at' => time()
    ];
    
    $this->saveMessageToDatabase($message);
    $this->broadcastToRecipients($message);
}

三、百度地图深度集成方案

1. 可选:地图选点功能

javascript:

openMapPicker() {
  const map = new BMapGL.Map("map-container");
  const geolocation = new BMapGL.Geolocation();
  
  geolocation.getCurrentPosition(async (res) => {
    map.centerAndZoom(new BMapGL.Point(res.longitude, res.latitude), 15);
    
    // 添加可拖拽标记
    const marker = new BMapGL.Marker(new BMapGL.Point(res.longitude, res.latitude), {
      enableDragging: true
    });
    map.addOverlay(marker);
    
    // 确认按钮逻辑
    document.getElementById('confirm-location').onclick = () => {
      const position = marker.getPosition();
      this.sendBaiduLocation(position.lat, position.lng);
    };
  });
}

2. 安全增强

  • 后端校验坐标范围(防止无效坐标)
  • 使用百度鹰眼轨迹服务进行坐标纠偏(可选)

四、样式优化

在style部分添加定位消息样式:

css:

.location-message {
  padding: 12rpx;
  border-radius: 8rpx;
  background: #fff;
  max-width: 70%;
}

.location-title {
  font-weight: bold;
  margin-bottom: 6rpx;
}

.location-address {
  color: #666;
  font-size: 24rpx;
  margin-bottom: 10rpx;
}

.location-message image {
  width: 300rpx;
  border-radius: 8rpx;
  border: 1px solid #eee;
}

.location-tips {
  color: #007AFF;
  font-size: 24rpx;
  text-align: center;
  margin-top: 6rpx;
}

五、注意事项

1. 跨平台兼容:

  • App端需使用uni.getLocation替代浏览器API

  • 微信小程序需使用wx.getLocation并配置权限

2. 性能优化:

  • 对静态地图图片进行缓存

  • 批量获取多个位置的地址时使用逆地理编码批量接口

3. 隐私合规:

  • 在用户首次定位时弹出隐私协议说明

  • 提供「模糊定位」选项(如只到街道级别)

4. 备用方案:

javascript:

// 当百度API失败时使用系统原生坐标
sendBaiduLocation(lat, lng, fallbackAddress = '') {
  if (!fallbackAddress) {
    fallbackAddress = `纬度: ${lat.toFixed(4)}, 经度: ${lng.toFixed(4)}`;
  }
  // ...其余逻辑不变
}

完整实现后,你的聊天应用将支持:

  1. 实时获取当前位置并显示地址

  2. 发送可交互的地图缩略图

  3. 点击查看详细地图信息

  4. 历史位置消息回溯

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

11、Refs:直接操控元素——React 19 DOM操作秘籍

一、元素操控的魔法本质 "Refs是巫师与麻瓜世界的连接通道&#xff0c;让开发者能像操控魔杖般精准控制DOM元素&#xff01;"魔杖工坊的奥利凡德先生轻抚着魔杖&#xff0c;React/Vue的refs能量在杖尖跃动。 ——以神秘事务司的量子纠缠理论为基&#xff0c;揭示DOM…

uniapp-商城-33-shop 布局搜索页面以及u-search

shop页面上有一个搜索&#xff0c;可以进行商品搜索&#xff0c;这里我们先做一个页面布局&#xff0c;后面再来进行数据i联动。 1、shop页面的搜索 2、搜索的页面代码 <navigator class"searchView" url"/pagesub/pageshop/search/search"> …

【dataframe显示不全问题】打开一个行列超多的excel转成df之后行列显示不全

出现问题如下图&#xff1a; 解决方案&#xff5e; display.width解决列显示不全 pd.set_option(display.max_columns,1000) pd.set_option(display.width, 1000) pd.set_option(display.max_colwidth,1000) pd.set_option(display.max_rows,1000)

Windows下Golang与Nuxt项目宝塔部署指南

在Windows下将Golang后端和Nuxt前端项目打包&#xff0c;并使用宝塔面板部署的步骤如下 一、Golang后端打包 交叉编译为Linux可执行文件 在Windows PowerShell中执行&#xff1a; powershell复制下载 $env:GOOS "linux" $env:GOARCH "amd64" go build…

真实趋势策略思路

该交易策略通过一系列技术指标的计算与逻辑判断&#xff0c;旨在捕捉市场趋势的反转与延续点&#xff0c;以实现盈利。其主要交易逻辑思路可以概括如下&#xff1a; 1. 趋势与动量分析 策略首先利用动量函数计算收盘价的短期&#xff08;3周期&#xff09;变化&#xff0c;通过…

江奇霖惊喜亮相泡泡岛音乐节,新歌首唱+合作舞台燃动现场

2025年4月20日&#xff0c;江奇霖受邀参加2025泡泡岛音乐与艺术节东南站。现场献唱三首歌曲&#xff0c;超5万名观众现场一同感受音乐的魅力。 在泡泡岛SPECIAL SET特别企划舞台中&#xff0c;江奇霖带来新歌的首唱&#xff0c;温暖的旋律如低语倾诉&#xff0c;观众们也纷纷喊…

【HarmonyOS】ArKUI框架

目录 概述 声明式开发范式 基于ArKUI的项目 • 1&#xff0e;创建资源文件 • 2&#xff0e;引用资源 • 3&#xff0e;引用系统资源&#xff1a; • 系统资源有哪些 • 4. 在配置和资源中引用资源 声明式语法 UI描述规范 UI组件概述 组件化 组件渲染控制语法 修改…

计算机网络八股——HTTP协议与HTTPS协议

目录 HTTP1.1简述与特性 1. 报文清晰易读 2. 灵活和易于扩展 3. ⽆状态 Cookie和Session 4. 明⽂传输、不安全 HTTP协议发展过程 HTTP/1.1的不足 HTTP/2.0 HTTP/3.0 HTTPS协议 HTTP协议和HTTPS协议的区别 HTTPS中的加密方式 HTTPS中建立连接的方式 前言&#xff…

webpack基础使用了解(入口、出口、插件、加载器、优化、别名、打包模式、环境变量、代码分割等)

目录 1、webpack简介2、简单示例3、入口(entry)和输出(output)4、自动生成html文件5、打包css代码6、优化&#xff08;单独提取css代码&#xff09;7、优化&#xff08;压缩过程&#xff09;8、打包less代码9、打包图片10、搭建开发环境&#xff08;webpack-dev-server&#xf…

微信小程序 van-dropdown-menu

点击其他按钮&#xff0c;关闭van-dropdown-menu下拉框 DropdownMenu 引入页面使用index.wxmlindex.scssindex.ts(重点)index.ts(全部) DropdownMenu 引入 在app.json或index.json中引入组件 "usingComponents": {"van-dropdown-menu": "vant/weapp…

智驱未来:AI大模型重构数据治理新范式

第一章 数据治理的进化之路 1.1 传统数据治理的困境 在制造业巨头西门子的案例中&#xff0c;其全球200个工厂每天产生1.2PB工业数据&#xff0c;传统人工清洗需要300名工程师耗时72小时完成&#xff0c;错误率高达15%。数据孤岛问题导致供应链决策延迟平均达48小时。 1.2 A…

C++ 蓄水池抽样算法

&#xff08;1&#xff09;概念 蓄水池抽样算法&#xff08;Reservoir Sampling&#xff09;是一种用于从 大规模数据集&#xff08;尤其是 流式数据 或 无法预先知晓数据总量 的场景&#xff09;中 等概率随机抽取固定数量样本 的算法。 &#xff08;2&#xff09;实现 我们…

分布式光纤测温技术让森林火灾预警快人一步

2025年春季&#xff0c;多地接连发生森林火灾&#xff0c;累计过火面积超 3万公顷。春季历来是森林草原火灾易发、多发期&#xff0c;加之清明节已到来&#xff0c;生产生活用火活跃&#xff0c;民俗祭祀用火集中&#xff0c;森林火灾风险进一步加大。森林防火&#xff0c;人人…

Vue2 el-checkbox 虚拟滚动解决多选框全选卡顿问题 - 高性能处理大数据量选项列表

一、背景 在我们开发项目中&#xff0c;经常会遇到需要展示大量选项的多选框场景&#xff0c;比如权限配置、数据筛选等。当选项数量达到几百甚至上千条时&#xff0c;传统的渲染方式全选时会非常卡顿&#xff0c;导致性能问题。本篇文章&#xff0c;记录我使用通过虚拟滚动实现…

KUKA机器人KR 3 D1200 HM介绍

KUKA KR 3 D1200 HM是一款小型机器人&#xff0c;型号中HM代表“Hygienic Machine&#xff08;卫生机械&#xff09;用于主副食品行业”&#xff0c;也是一款并联机器人。用于执行高速、高精度的抓取任务。这款机器人采用食品级不锈钢设计&#xff0c;额定负载为3公斤&#xff…

【MATLAB第117期】#源码分享 | 基于MATLAB的SSM状态空间模型多元时间序列预测方法(多输入单输出)

【MATLAB第117期】#源码分享 | 基于MATLAB的SSM状态空间模型多元时间序列预测方法&#xff08;多输入单输出&#xff09; 引言 本文使用状态空间模型实现失业率递归预测&#xff0c;状态空间模型&#xff08;State Space Model, SSM&#xff09;是一种用于描述动态系统行为的…

【Linux】线程ID、线程管理、与线程互斥

&#x1f4da; 博主的专栏 &#x1f427; Linux | &#x1f5a5;️ C | &#x1f4ca; 数据结构 | &#x1f4a1;C 算法 | &#x1f310; C 语言 上篇文章&#xff1a; 【Linux】线程&#xff1a;从原理到实战&#xff0c;全面掌握多线程编程&#xff01;-CSDN博客 下…

【锂电池SOH估计】RF随机森林锂电池健康状态估计,锂电池SOH估计(Matlab完整源码和数据)

目录 效果一览程序获取程序内容代码分享研究内容基于随机森林(RF)的锂电池健康状态(SOH)估计算法研究摘要1. 引言2. 锂电池SOH评估框架3. 实验与结果分析4. 未来研究方向6. 结论效果一览 程序获取 获取方式一:文章顶部资源处直接下载:【锂电池SOH估计】RF随机森林锂电池…

【Pytorch 中的扩散模型】去噪扩散概率模型(DDPM)的实现

介绍 广义上讲&#xff0c;扩散模型是一种生成式深度学习模型&#xff0c;它通过学习到的去噪过程来创建数据。扩散模型有很多变体&#xff0c;其中最流行的通常是文本条件模型&#xff0c;它可以根据提示生成特定的图像。一些扩散模型&#xff08;例如 Control-Net&#xff0…

121.在 Vue3 中使用 OpenLayers 实现去掉鼠标右键默认菜单并显示 Feature 信息

🎯 实现效果 👇 本文最终实现的效果如下: ✅ 地图初始化时绘制一个多边形; ✅ 鼠标 右键点击地图任意位置; ✅ 若命中 Feature,则弹出该图形的详细信息; ✅ 移除浏览器默认的右键菜单,保留地图交互的完整控制。 💡 整个功能基于 Vue3 + OpenLayers 完成,采用 Com…