腾讯位置服务开发应用-使用教程,案例分享,知识总结

article/2025/1/11 2:13:31

文章目录

  • 前言
  • 一、腾讯位置服务是什么?
  • 二、使用步骤
    • 1.uniapp开发map说明
      • 介绍markers属性-类型为数组Array
        • marker 上的气泡 callout(Object类型)
        • marker 上的标签 label(Object类型)
        • polyline
        • polygon
        • circles
        • controls
        • position
    • 2.uniapp使用map组件
      • 基本使用方法
      • 地址搜索
      • 获取附近的动态,点聚合
      • 地图上标注附近的人
      • 定位附近门店
      • 滑动轨迹
      • vue接入腾讯地图接口
    • 3.vue接入腾讯地图
    • 4.个性化地图样式
    • 5.腾讯位置入门步骤
  • 三.微信小程序JavaScript SDK
  • 总结


把你的前端拿捏得死死的,每天学习得爽爽的,达达前端程序员,关注这个不一样的程序员。 感谢不负每一份热爱前端的程序员,不论前端技能有多奇葩。

前言

作为一名在职岗位为【前端开发工程师】的程序员,我开发的应用程序经常需要获取用户位置信息,需要再某些场合下使用展示地图以及地图商的某些地点,需要获取行政区划列表(省市区)以及地址详情信息,需要在地图上规划一条(动态)路线,轨迹回放,小车移动,需要创建信息窗口,用于地点的摘要性信息的展示。

公司内做的是共享项目, 场景是这样的,一种常见共享充电宝(功能差不多和流行的共享单车一样),在做小程序首页时,需要做到的是扫码充电,联系客服(问题反馈),获取地理位置,开篇即是一副地理位置,在你附近获取到区域内店铺信息,点击该店的logo标志可以获取该店的地理位置,营业时间,店名,距离,是否当前该店里是否有可借的充电宝等信息。

共享充电电动车🚗,首页也是一副地理位置地图,可以获取你附近最近的共享电动车,获取车的地址,状态等信息。显示该车的剩余电量,使用记录,租借订单,获取行程轨迹,某时间段内的里程,动态显示轨迹等。

涉及到的共享其实内容很多(如除了电动车,充电宝,还可租借设备等),但大都功能几乎相同,需要交押金,租借费用,信用免押金等。开发过app,H5,web网站,小程序项目都与地图相关的位置服务息息相关,让我说说与位置服务有关的故事。

下面主要还是讲解其中的关于地图功能等功能,使用的也是腾讯位置开发服务。会一步一步说明,做一些案例展示,代码说明,使用教程。(注意这里我回去看开发教程,尽量把每个功能都熟悉地说明一下使用方法


一、腾讯位置服务是什么?

腾讯位置服务无疑是获取位置服务等信息内容,该产品亮点:

  1. 定位:为合作伙伴和广大开发者提供完善的位置解决方案,已为社交、出行、游戏、商业、O2O、物流等领域提供专业精准的定位服务
  2. 地图:腾讯位置服务在多平台为开发者提供了丰富的地图展现形式,帮助从属于不同领域的开发人员轻松完成构建地图并在其基础上打造专属内容的工作。同时配合海量数据、个性化定制、可视化等能力满足各个行业场景下对地图的需求
  3. 地点搜索:基于海量鲜活地点(POI)数据,提供周边搜索,城市范围搜索,关键词输入提示、分类筛选等多种搜索能力,面向社交、物流、出行等行业打造专属搜索策略,体验更胜一筹
  4. 路线规划:根据出发地、目的地以及路线策略设置,结合精准的实时交通路况提供驾车、步行、骑行、公交路线规划能力,助力开发者为用户提供贴心、人性化的出行体验
  5. 微信小程序解决方案:腾讯位置服务全面拥抱小程序生态,从服务API、基础地图组件、插件、行业方案等多个层面服务不同场景需求的小程序开发者,助力小程序插上地图的“翅膀”!
  6. 个性化地图:个性化样式:千行千面,助力开发者根据自身产品的使用场景、界面色调, 选取或者创建风格匹配的地图样式,体验更胜一筹;个性化图层:真实酷炫,助力开发者将精美绘图生成地图瓦片并置于地图之上,让旅游景点、大学高校等区域的展示效果与众不同

二、使用步骤

1.uniapp开发map说明

使用uniapp是因为它是一个使用vue.js开发所有前端应用的框架,开发者编写一套代码,可以发布到ios,android,web以及各种小程序,快应用等多个平台。

使用map地图组件开发,地图组件用于展示地图(使用的时腾讯地图),说一下它的属性有:

longitude(类型为Number,没有默认值,表示中心经度)
latitude(类型为Number,没有默认值,表示中心纬度)
scale(类型为Number,默认值为16,缩放级别取值范围为5-18)
markers(类型为Array数组,类型为数组即表示地图上可以有多个,没有默认值,表示标记点)
polyline(类型为Array数组,没有默认值,表示路线,数组上的所有点连成线)
circles(类型Array数组,表示圆)
controls(类型Array数组,表示控件)
include-points(类型Array数组,表示缩放视野已包含所有给定的坐标点)
enable-3D(类型为Boolean,默认值为false,表示是否显示3D搂块)
show-compass(类型为Boolean,默认值为false,表示为是否显示指南针)
enable-overlooking(类型为Boolean,默认值为false,表示为是否开启俯视)
enable-satellite(类型为Boolean,默认值为false,表示为是否开启卫星图)
enable-traffic(类型为Boolean,默认值为false,表示为是否开启实时路况)
show-location(类型为Boolean,表示显示带有方向的当前定位点)
polygons(类型Array,表示为多边形)

点击属性

  1. @markertap-表示点击标记点时触发,e.detail={markerId}
  2. @labeltap-表示点击label时触发,e.detail = {markerId}
  3. @callouttap-表示点击标记点对应的气泡时触发,e.detail = {markerId}
  4. @controltap-表示点击控件时触发,e.detail = {controlId}
  5. @regionchange-表示视野发生变化时触发
  6. @tap-表示点击地图时触发; App-nuve、微信小程序2.9支持返回经纬度
  7. @updated-表示在地图渲染更新完成时触发

我们在写map组件时,组件的宽/高推荐写直接量,比如说是 750rpx,不要设置百分比值,在uni-app中只支持gcj02坐标。

介绍markers属性-类型为数组Array

由之前描述可知,markers属性类型为Array,表示标记点用于在地图上显示标记的位置。这个数组属性,它里面有它的对象配置属性,分别是:

  1. id,表示 标记点id,类型为Number,必填项,marker点击事件回调会返回此id,建议为每个marker设置上Number类型id,保证更新marker时有更好的性能。
  2. latitude,纬度,类型Number,必填项,浮点数,范围 -90 ~ 90
  3. longitude,经度,类型Number,必填项,浮点数,范围 -180 ~ 180
  4. title,标注点名,类型String,不是必填,点击时显示,callout存在时将被忽略
  5. iconPath,显示的图标,类型String,必填项,项目目录下的图片路径
  6. rotate,旋转角度,类型Number,不是必填,顺时针旋转的角度,范围 0 ~ 360,默认为 0
  7. alpha,标注的透明度,类型Number,不是必填,默认1,无透明,范围 0 ~ 1
  8. width,标注图标宽度,类型Number,不是必填,默认为图片实际宽度
  9. height,标注图标高度,类型Number,不是必填,默认为图片实际高度
  10. callout,自定义标记点上方的气泡窗口,类型Object,不是必填 - 可识别换行符
  11. label,为标记点旁边增加标签,类型Object,不是必填 - 可识别换行符
  12. anchor,经纬度在标注图标的锚点,默认底边中点,不是必填,{x, y},x表示横向(0-1),y表示竖向(0-1)。{x: .5, y: 1} 表示底边中点

marker 上的气泡 callout(Object类型)

marker数组 上属性 callout 对象使用属性:

  1. content,文本,String
  2. color,文本颜色,String
  3. fontSize,文字大小,Number
  4. borderRadiuscallout边框圆角,Number
  5. bgColor,背景色,String
  6. padding,文本边缘留白,Number
  7. display'BYCLICK':点击显示; 'ALWAYS':常显String
  8. textAlign,文本对齐方式。有效值: left, right, centerString

marker 上的标签 label(Object类型)

  1. content,文本,String
  2. color,文本颜色,String
  3. fontSize,文字大小,Number
  4. x,label的坐标,原点是 marker 对应的经纬度,Number
  5. y,label的坐标,原点是 marker 对应的经纬度,Number
  6. borderWidth,边框宽度,Number
  7. borderColor,边框颜色,String
  8. borderRadius,边框圆角,Number
  9. bgColor,背景色,String
  10. padding,文本边缘留白,Number
  11. textAlign,文本对齐方式。有效值: left, right, center,String

polyline

polyline表示指定一系列坐标点,从数组第一项连线至最后一项

  1. points,经纬度数组,类型为Array,必填,如:[{latitude: 0, longitude: 0}]
  2. color,线的颜色,类型为String,不必填,如:#0000AA
  3. width,线的宽度,类型为Number,不必填
  4. dottedLine,是否虚线,类型为Boolean,不必填,默认值false
  5. arrowLine,带箭头的线,类型为Boolean,不必填,默认值为false
  6. arrowIconPath,更换箭头图标,类型为String,不必填,在arrowLinetrue时,默认带箭头的线时生效
  7. borderColor,线的边框颜色,类型为String,不必填
  8. borderWidth,线的厚度,类型为Number,不必填

polygon

polygon指定一系列坐标点,根据points坐标数据生成闭合多边形

  1. points,经纬度数组,array,必填,如:[{latitude: 0, longitude: 0}]
  2. strokeWidth,描边的宽度,Number,否
  3. strokeColor 描边的颜色,String,否
  4. fillColor,填充颜色,String,否
  5. zIndex,设置多边形 Z 轴数值,Number,否

circles

circles在地图上显示圆

  1. latitude,纬度,Number,必填,浮点数,范围 -90 ~ 90
  2. longitude,经度,Number,必填,浮点数,范围-180 ~ 180
  3. color,描边的颜色,String,不必填,如:#0000AA
  4. fillColor,填充颜色,String,不必填,如:#0000AA
  5. radius,半径,Number,必填
  6. strokeWidth,描边的宽度,Number,不必填

controls

controls在地图上显示控件,控件不随着地图移动

  1. id,控件idNumber,不必填,在控件点击事件回调会返回此id
  2. position,控件在地图的位置,Object,必填,控件相对地图位置
  3. iconPath,显示的图标,String,必填,项目目录下的图片路径,支持相对路径写法,以'/'开头则表示相对项目根目录;也支持临时路径
  4. clickable,是否可点击,Boolean,不必填,默认不可点击

position

  1. left,距离地图的左边界多远,Number,不必填,默认为0
  2. top,距离地图的上边界多远,Number,不必填,默认为0
  3. width,控件宽度,Number,不必填,默认为图片宽度
  4. height,控件高度,Number,不必填,默认为图片高度

注意在uniapp中地图组件的经纬度必填,如果不填,经纬度则默认值是北京的经纬度。

2.uniapp使用map组件

基本使用方法

使用uniapp开发中的map组件,基本使用方法:

代码如下(示例):

<map :scale="scale" style="width: 100%; height: 100%;"
enable-3D="false" show-compass="false" enable-overlooking="false"
:enable-satellite="false" :enable-traffic="false" show-location="false"
:latitude="latitude" :longitude="longitude" :markers="covers">
</map>

markers属性的使用,代码如下(示例):

markers: [{id: 1, // Numbertitle: '1', // String-标注点名rotate: 180, // Number - 顺时针旋转的角度,范围 0 ~ 360,默认为 0alpha: 0.5, // 默认1,无透明,范围 0 ~ 1latitude: 39.899,longitude: 116.39742,width: 30,height: 30,// callout: {// 	display: "BYCLICK",// 	padding: 10,// 	borderRadius: 5,// 	content: '',// },// anchor: {},iconPath: '../../../static/location.png', // 显示的图标
}, {id: 2,title: '2', // Stringlatitude: 39.90,longitude: 116.39,callout: {color: '#007AFF', // 文本颜色bgColor: '#563BFF', // 背景色display: "ALWAYS", // 'BYCLICK':点击显示; 'ALWAYS':常显fontSize: 15,textAlign: 'left', // 文本对齐方式。有效值: left, right, centerpadding: 10, // 文本边缘留白borderRadius: 5,content: '腾讯地图',},label: {content: 'Jeskson',color: '#000000',fontSize: 12,borderWidth: 12,borderColor: '#007AFF',borderRadius: 5,padding: 5,textAlign: 'center',bgColor: '#563BFF',},iconPath: '../../../static/location.png'
}]

预览效果如下:

在这里插入图片描述

controls:[{// 在地图上显示控件,控件不随着地图移动id: 1, // 控件idiconPath:'../../static/icon.png', // 显示的图标position:{// 控件在地图的位置left: 15,top: 15,width: 50,height: 50},    
}],

地址搜索

uni-app 只支持 gcj02 坐标

uni.getLocation(OBJECT)中的object参数

获取当前的地理位置、速度。 在微信小程序中,当用户离开应用后,此接口无法调用,除非申请后台持续定位权限;当用户点击“显示在聊天顶部”时,此接口可继续调用。

OBJECT参数说明

  1. typeString,不必填,默认为 wgs84 返回 gps 坐标,gcj02 返回国测局坐标,可用于 uni.openLocation 的坐标,app平台高德SDK仅支持返回gcj02
  2. altitudeBoolean,不必填,传入 true 会返回高度信息,由于获取高度需要较高精确度,会减慢接口返回速度
  3. geocodeBoolean,不必填,默认false,是否解析地址信息
  4. successFunction,必填,接口调用成功的回调函数,返回内容详见返回参数说明
  5. failFunction,不必填,接口调用失败的回调函数
  6. completeFunction,不必填,接口调用结束的回调函数(调用成功、失败都会执行)

对于success返回参数说明:

  1. latitude,纬度,浮点数,范围为-90~90,负数表示南纬
  2. longitude,经度,浮点数,范围为-180~180,负数表示西经
  3. speed,速度,浮点数,单位m/s
  4. accuracy,位置的精确度
  5. altitude,高度,单位 m
  6. verticalAccuracy,垂直精度,单位 mAndroid 无法获取,返回 0
  7. horizontalAccuracy,水平精度,单位 m
  8. address,地址信息(仅App端支持,需配置geocodetrue

address 地址信息说明

  1. countryString,国家 如“中国”,没有则返回undefined
  2. provinceString,省份名称 如“北京市”,没有则返回undefined
  3. cityString,城市名称,如“北京市”,没有则返回undefined
  4. districtString,区,县名称 如“朝阳区”,没有则返回undefined
  5. streetString,街道信息,如“酒仙桥路”,没有则返回undefined
  6. streetNumString,获取街道门牌号信息,如“3号”,没有则返回undefined
  7. poiNameString POI信息,如“电子城.国际电子总部”,没有则返回undefined
  8. postalCodeString,邮政编码,如“100016”,没有则返回undefined
  9. cityCodeString,城市代码,如“010”,没有则返回undefined

uni.chooseLocation(OBJECT)打开地图选择位置。

  1. latitudeString,不必填,目标地纬度
  2. longitudeString,不必填,目标地经度
  3. keywordString,不必填,搜索关键字,仅App平台支持
  4. successFunction,必填
  5. failFunction,不必填
  6. completeFunction,不必填

success返回参数说明:

  1. name,位置名称
  2. address,详细地址
  3. latitude,纬度,浮点数,范围为-90~90,负数表示南纬,使用 gcj02 国测局坐标系。
  4. longitude,经度,浮点数,范围为-180~180,负数表示西经,使用 gcj02 国测局坐标系。

代码如下(示例):

chooseLocation(e) { //打开地图选择位置uni.chooseLocation({success: res => {console.log('位置名称:' + res.name);console.log('详细地址:' + res.address);console.log('纬度:' + res.latitude);console.log('经度:' + res.longitude);uni.getLocation({type: 'gcj02',altitude:true,geocode:true,success: function(res) {console.log('当前位置的经度:' + res.longitude);console.log('当前位置的纬度:' + res.latitude);}});console.log('省:' + res.address.slice(0, res.address.indexOf('省') + 1));console.log('市:' + res.address.slice(res.address.indexOf('省') + 1, res.address.indexOf('市') + 1));console.log('区:' + res.address.slice(res.address.indexOf('市') + 1, res.address.indexOf('区') + 1));this.query.address = res.address;this.query.latitude = res.latitude;this.query.longitude = res.longitude;this.query.province = res.address.slice(0, res.address.indexOf('省') + 1)this.query.city = res.address.slice(res.address.indexOf('省') + 1, res.address.indexOf('市') + 1)this.query.district = res.address.slice(res.address.indexOf('市') + 1, res.address.indexOf('区') + 1)}});
},

预览效果:

在这里插入图片描述
在这里插入图片描述

获取附近的动态,点聚合

uni.getNetworkType(OBJECT)获取网络类型。

uni.createMapContext(mapId,this)创建并返回 map 上下文 mapContext 对象。在自定义组件下,第二个参数传入组件实例this,以操作组件内 <map> 组件。

mapContext-mapContext 通过 mapId 跟一个 <map> 组件绑定,通过它可以操作对应的 <map> 组件。

该对象得方法列表:

  1. getCenterLocation OBJECT 获取当前地图中心的经纬度,返回的是 gcj02 坐标系,可以用于 uni.openLocation
  2. moveToLocation OBJECT 将地图中心移动到当前定位点,需要配合map组件的show-location使用
  3. translateMarker OBJECT 平移marker,带动画
  4. includePoints OBJECT 缩放视野展示所有经纬度
  5. getRegion OBJECT 获取当前地图的视野范围
  6. getScale OBJECT 获取当前地图的缩放级别
  7. $getAppMap 获取原生地图对象 plus.maps.Map

getCenterLocationOBJECT 参数列表

success Function 不必填,接口调用成功的回调函数 ,res = { longitude: "经度", latitude: "纬度"}

moveToLocationOBJECT 参数列表 - 可不必填

translateMarkerOBJECT 参数列表

  1. markerId Number 必填 指定 marker
  2. destination Object 必填 指定 marker 移动到的目标点
  3. autoRotate Boolean 不必填 移动过程中是否自动旋转 marker
  4. rotate Number 不必填 marker 的旋转角度
  5. duration Number 不必填 动画持续时长,默认值1000ms,平移与旋转分别计算
  6. animationEnd Function 不必填 动画结束回调函数
  7. fail Function 不必填 接口调用失败的回调函数

代码如下(示例):

<view id="activeMap"><view @tap="activeMarker={}"><view class="page-body map-view" style="z-index: 1;position: relative;"><view class="page-section page-section-gap map-view"><map :markers="shops" id="map1" :show-location="true" :latitude="latitude" :longitude="longitude" @regionchange="regionChange"@markertap="markerTap" @tap="activeMarker={}"><!-- @markertap 点击标记点时触发,e.detail = {markerId}--><!-- @tap 点击地图时触发--><!-- @regionchange 视野发生变化时触发--></map><cover-image class="map-image" src="../static/address.png"></cover-image></view></view></view>
</view>
regionChange() { // 移动地图后重新获取门店uni.createMapContext('map1', this).getCenterLocation({success: res => {console.log(res.latitude)console.log(res.longitude)this.shopTimeout = setTimeout(_ => {this.shops = [{address: "广东省汕头市xxx区xx大道1",distance: 122,end_time: "1",id: 2,latitude: "22.72078500009999",longitude: "114.36090200009999",shop: {iconPath: '/static/logo.png',id: 3,latitude: "22.72078500009999",longitude: "114.36090200009999",height: 34,width: 34,shop: {return: 0}},return: 0,height: 34,width: 34,start_time: "1",store_name: "三星大酒店",iconPath: '/static/shop.png',}]}, 500)},fail: res => {uni.showModal({content: '获取位置失败',showCancel: false})}})
},

预览效果图如下:

在这里插入图片描述

地图上标注附近的人

代码如下(示例):

list: [{id: 1264640,user_id: 335187,place: "Jeskson市",text: "dadaqianduan.cn",latitude: "27.267520",longitude: "111.727120",status: "normal",nickname: "dada",avatar: "https://image.aishencn.com/2020/10/20/002207441_40845724-user.jpg",distance: 13419,
}, {id: 1272720,user_id: 36950,place: "dadaqianduan市",text: "dadaqianduan.cn",latitude: "27.257640",longitude: "111.747910",deletetime: null,status: "normal",nickname: "dadaqianduan",avatar: "https://image.aishencn.com/2020/04/09/004135379_37869100-user.jpg",distance: 27070,
}, {id: 1316740,user_id: 366172,place: "dadaqianduan.cn",text: "dadaqianduan.cn",images: "https://image.aishencn.com/2020/11/04/215134979_98197351-bbs.jpg",latitude: "27.257430",longitude: "111.732960",status: "normal",nickname: "dada",avatar: "https://image.aishencn.com/2020/11/04/182622730_98197351-user.venus/cache/ext/crop/1604518314542_jpg",distance: 27190,images_arr: ["https://image.aishencn.com/2020/11/04/215134979_98197351-bbs.jpg"]
}],

预览效果如图:

在这里插入图片描述

在这里插入图片描述

定位附近门店

代码如下(示例):

// 两点间距离
distance(la1, lo1, la2, lo2) {var La1 = (la1 * Math.PI) / 180.0var La2 = (la2 * Math.PI) / 180.0var La3 = La1 - La2var Lb3 = (lo1 * Math.PI) / 180.0 - (lo2 * Math.PI) / 180.0var s =2 *Math.asin(Math.sqrt(Math.pow(Math.sin(La3 / 2), 2) +Math.cos(La1) * Math.cos(La2) * Math.pow(Math.sin(Lb3 / 2), 2)))s = s * 6378.137 //地球半径s = Math.round(s * 10000) / 10000return s
},
// 计算最近的距离
nearDistance(array, centerLatitude, centerLongitude) {let temp = []for (let i = 0, l = array.length; i < l; i++) {const element = array[i]let d = this.distance(element.latitude,element.longitude,centerLatitude,centerLongitude)temp.push(d)}this.distanceL = Math.min.apply(null, temp)
}

效果如下图:
在这里插入图片描述

滑动轨迹

代码如下(示例):

<map :polyline="polyline" :scale="scale" id="maps" :markers="markers" :latitude="center.latitude"
:longitude="center.longitude">
</map>
// 播放标记点
playMarkars() {if (this.polyline.length == 0) {uni.showModal({content: '当前时间范围内没有轨迹,无法播放!',})this.isPlay = false // 无this.playIndex = 0 // 第一个return}this.playIndex = Math.min(this.points.length - 1, this.playIndex)this.markers = [this.formatMarker(this.points[this.playIndex++], 'ALWAYS')]this.timer = setInterval(_ => {var i = this.playIndex++this.nextAdaress(i);if (i >= this.points.length) {clearInterval(this.timer)this.isPlay = falsethis.playIndex = 0this.initMarkers()return}this.markers = [this.formatMarker(this.points[i], 'ALWAYS')]}, 1000)
},formatMarker(point, display = "BYCLICK") {let content = ["时间:" + parseTime(point.create_time),"运动状态:" + (point.sport == 1 ? '运动' : '静止'),"地址:" + point.address || '']return {id: point.id,iconPath: '/static/dada.png',width: 35,height: 35,latitude: point.latitude,longitude: point.longitude,callout: {display: display,padding: 10,borderRadius: 5,content: content.join("\n")}}
},
nextAdaress(index) {const len = 10;if (this.isGetAddress) {return}for (let i = 0; i < len; i++) {if (!this.points[i + index]) {break}if (this.points[i + index].address === undefined) {this.isGetAddress = truethis.getAddress(i + index, len * 2, _ => {this.isGetAddress = false});break}}
},

图片效果如下:

在这里插入图片描述

vue接入腾讯地图接口

腾讯(推荐)

https://apis.map.qq.com/ws/location/v1/ip={$ip}&key={$key}

需要申请key,速度快,有基本信息

首页点击可以进行注册,申请一个获取key:https://lbs.qq.com?lbs_invite=VJJIFLV

key管理,创建新密钥,填写相应信息即可
在这里插入图片描述

1.创建地图预览效果图如下:
在这里插入图片描述

<script charset="utf-8" src="https://map.qq.com/api/gljs?v=1.exp&key=申请的key"></script><script type="text/javascript">function initMap() {var center = new TMap.LatLng(39.984104, 116.307503);//初始化地图var map = new TMap.Map("container", {rotation: 20,//设置地图旋转角度pitch:30, //设置俯仰角度(0~45)zoom:12,//设置地图缩放级别center: center//设置地图中心点坐标});}
</script>

2.地图加载完成效果图:
在这里插入图片描述

<script>function initMap() {//初始化地图var map = new TMap.Map("container", {center: new TMap.LatLng(39.984104, 116.307503)});//监听地图瓦片加载完成事件map.on("tilesloaded", function () {document.getElementById("tip").innerHTML = "地图瓦片已加载完成"})}
</script>

3.异步加载地图

<script>function initMap() {var map = new TMap.Map("container", {pitch: 45,zoom: 12,center: new TMap.LatLng(39.984104, 116.307503)});}function loadScript() {//创建script标签,并设置src属性添加到body中var script = document.createElement("script");script.type = "text/javascript";script.src = "https://map.qq.com/api/gljs?v=1.exp&key=申请key";document.body.appendChild(script);}window.onload = loadScript;</script>

4.同时加载两个地图效果图如下:

在这里插入图片描述

<script>function initMap() {//初始化地图一var mapOne = new TMap.Map("containerOne", {pitch:45,center: new TMap.LatLng(39.984104, 116.307503)});//初始化地图二var mapTwo = new TMap.Map("containerTwo", {center: new TMap.LatLng(39.984104, 116.307503)});}
</script>

5.获取地图中心效果如下图:
在这里插入图片描述

<script>var centerInfo = document.getElementById("center-info");var center = new TMap.LatLng(39.984104, 116.307503);//设置中心点坐标//初始化地图var map = new TMap.Map("container", {center: center});//获取地图中心点事件function getCenter() {            var mapCenter = map.getCenter(); //获取地图中心点坐标centerInfo.innerHTML = "当前地图中心为: " + mapCenter.getLat().toFixed(6) + "," + mapCenter.getLng().toFixed(6);}//设置地图中心点事件function setCenter() {map.setCenter(new TMap.LatLng(39.908802,116.397502));//坐标为天安门centerInfo.innerHTML = "当前地图中心为: 39.908802,116.397502";}
</script>

6.地图平移效果图如下:
在这里插入图片描述

<script>function initMap() {var position = document.getElementById("position");var txt = document.getElementById("txt");var center = new TMap.LatLng(39.984104, 116.307503);//设置中心点坐标//初始化地图var map = new TMap.Map("container", {center: center});location.innerHTML = map.getCenter().toString();//监听地图开始平移map.on("panstart", function () {txt.innerHTML = "地图开始平移"})//监听地图平移map.on("pan",function(){txt.innerHTML = "地图正在平移";position.innerHTML = map.getCenter().toString();//获取地图中心点})//监听地图平移结束map.on("panend",function(){txt.innerHTML = "地图结束平移";})}
</script>

3.vue接入腾讯地图

<template><div><div id="map" style="width:500px;height:500px;"></div></div>
</template><script>
export default {data() {return {longitude: "",latitude: ""};},methods: {init() {let address = "";let that = this;var center = new qq.maps.LatLng(34.754152, 113.667636);var map = new qq.maps.Map(document.getElementById('map'), {center: center,zoom: 13,disableDefaultUI: true});var marker = new qq.maps.Marker({position: center,map: map});var infoWin = new qq.maps.InfoWindow({map: map});var geocoder = new qq.maps.Geocoder({complete: function(res) {console.log(res);address = res.detail.nearPois[0].name;}});qq.maps.event.addListener(map, "click", function(event) {this.longitude = event.latLng.getLat();this.latitude = event.latLng.getLng();console.log(event);let lat = new qq.maps.LatLng(this.longitude, this.latitude);geocoder.getAddress(lat);setTimeout(() => {infoWin.open();infoWin.setContent('<div style="text-align:center;white-space:nowrap;">' +address +"</div>");infoWin.setPosition(event.latLng);}, 200);});}},mounted() {this.init();}
};
</script>
<style scoped>
</style>

使用前需要在index.html里引入<script charset="utf-8" src="https://map.qq.com/api/js?v=2.exp&key=YOUR_KEY"></script>才可以使用地图。

<script charset="utf-8" src="https://map.qq.com/api/js?v=2.exp&key=yourkey"></script>
<template><div><div id="container" style="width:500px;height:500px;"></div></div>
</template><script>export default{data() {return {longitude:39.956987, // 经度latitude:116.235128 // 纬度}},mounted () {this.init();},methods:{init() {var myLatlng = new qq.maps.LatLng(39.945687,116.3976968);var myOptions = {zoom: 8,               // 设置地图缩放级别center: myLatlng,      // 设置中心点样式mapTypeId: qq.maps.MapTypeId.ROADMAP   }var map = new qq.maps.Map(document.getElementById("container"), myOptions);}}}
</script>

创建地图实例

var map=new qq.maps.Map(document.getElement('container'),{
center,//坐标,即最初显示的地图中心
zoom    //缩放级别,即显示的比例
}

给地图添加事件

qq.maps.event.addListener(map,'click',function(res){
// res即点击后的位置信息
})

添加标记

var marker=new qq.maps.Marker({
position, // 标记点的位置,也可以是通过IP获取到的坐标
map, // 标记在哪个地图上
animation, // 标记显示时的动画效果
title, // 鼠标悬浮到标记上时的标题
draggable // 是否可拖拽
})

创建信息窗口

var info=new qq.maps.InfoWindow({
map, // 标记在哪个地图上
content // 信息窗口的内容
})

覆盖物

var polyline=new qq.maps.Polyline({
map, // 标记在哪个地图上
path, // 一个坐标数组,折线、多边形就是依靠这些坐标数组来成形的
strokeColor, // 折线颜色
strokeDashStyle, // 折线样式
strokeWeight, // 折线宽度
editable, // 折线是否可编辑
clickable // 是否可点击
})

单个标注点

mounted生命周期或者从后台接口获得信息后调用初始化地图方法

initMap (latitude, longitude, message) {var center = new qq.maps.LatLng(latitude, longitude);var map = new qq.maps.Map(document.getElementById("container"),{center: center,zoom: 13});var marker = new qq.maps.Marker({position: center,map: map});var info = new qq.maps.InfoWindow({map: map});// 悬浮标记显示信息qq.maps.event.addListener(marker, 'mouseover', function() {        info.open();info.setContent(`<div style="margin:10px;">${message}</div>`);info.setPosition(center);});qq.maps.event.addListener(marker, 'mouseout', function() {info.close();});
},

多个标注点

markers: [  ]; // 标记点数组mounted () {this.initMap(this.markers)
},initMap (arr) {// 默认以数组第一项为中心var center = new qq.maps.LatLng(arr[0].latitude, arr[0].longitude);var map = new qq.maps.Map(document.getElementById("container"),{center: center,zoom: 13});// 提示窗var info = new qq.maps.InfoWindow({map: map});for (var i = 0; i < arr.length; i++) {var data = arr[i];var marker = new qq.maps.Marker({ position: new qq.maps.LatLng(data.latitude, data.longitude), map: map });marker.id = data.id;marker.name = data.name;// 点击事件qq.maps.event.addListener(marker, 'mouseover', function() {info.open();// 设置提示窗内容info.setContent(`<div><p>${this.name}</p></div>`);// 提示窗位置 info.setPosition(new qq.maps.LatLng(this.position.lat, this.position.lng));});qq.maps.event.addListener(marker, 'mouseout', function() {info.close();                    });}
}

4.个性化地图样式

为什么要用个性化地图,提高不同场景下地图的展现效果和用户体验。
在这里插入图片描述
为什么选择腾讯位置服务个性化地图:

  1. 全平台通用
  2. 开发成本极小
  3. 个性化样式支持动态更新
  4. 支持全局配置和分级配置
  5. 编辑平台UI控件全面优化
  6. 每个元素可配置的属性全部开放
  7. 能够支持自定义的地图元素扩充为52种

5.腾讯位置入门步骤

  1. 登录腾讯位置服务
  2. 验证手机 与 邮箱
  3. 申请开发密钥(Key
  4. 选择您需要的产品

https://lbs.qq.com/webApi/component/componentGuide/componentMarker

位置展示组件
在这里插入图片描述
路线规划组件

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
地图选点组件
在这里插入图片描述
前端定位组件
在这里插入图片描述

三.微信小程序JavaScript SDK

  1. 我申请了开发者密钥key
  2. 开通webserviceAPI服务:控制台 -> key管理 -> 设置(使用该功能的key)-> 勾选webserviceAPI -> 保存
    (小程序SDK需要用到webserviceAPI的部分服务,所以使用该功能的KEY需要具备相应的权限)

日调用量:1万次 / Key----并发数:5次 / key / 秒

onLoad() {console.log('页面加载了')// 实例化API核心类qqmapsdk = new QQMapWX({// key: '申请的key'});
},
onShow() {console.log('页面显示了')// 调用接口dadaqianduanqqmapsdk.search({keyword: '酒店',success: (res) => {console.log(res);},fail: (err) => {console.log(err);},complete: (cres) => {console.log(cres);}})
},

我返回的数据如图:
在这里插入图片描述
QQMapWX – 小程序JavaScriptSDK核心类 – new QQMapWX(options:Object)
在这里插入图片描述

// 引入SDK核心类
var QQMapWX = require('xxx/qqmap-wx.js');// 实例化API核心类
var demo = new QQMapWX({key: '开发密钥(key)' // 必填
});

地点搜索:

// 地点搜索
nearbySearchBtn() {qqmapsdk.search({keyword: 'kfc', //搜索关键词location: '39.980014,116.313972', //设置周边搜索中心点success: (res) => {var mks = []for (var i = 0; i < res.data.length; i++) {mks.push({ // 获取返回结果,放到mks数组中title: res.data[i].title,id: res.data[i].id,latitude: res.data[i].location.lat,longitude: res.data[i].location.lng,iconPath: "/location.png", //图标路径width: 20,height: 20})}this.markers = mks},fail: (res) => {console.log(res);},complete: (res) => {console.log(res);}});
},

效果如图:
在这里插入图片描述

<script>// 引入SDK核心类,js文件根据自己业务,位置可自行放置// var QQMapWX = require('../../js_sdk/wxmp-qqmap/qqmap-wx-jssdk.js');import QQMapWX from '../../js_sdk/wxmp-qqmap/qqmap-wx-jssdk.js';var qqmapsdk;export default {components: {},data() {return {backfill: '',markers: [],suggestion: [],}},onLoad() {console.log('页面加载了') // 实例化API核心类qqmapsdk = new QQMapWX({ // key: '申请的key'key: '自己申请,我的就不放出来了'});},onShow() {console.log('页面显示了') // 调用接口dadaqianduanqqmapsdk.search({keyword: '酒店',success: (res) => {console.log(res);},fail: (err) => {console.log(err);},complete: (cres) => {console.log(cres);}})},onReady() {console.log('页面初次渲染完成了')},methods: {getsuggest(e) {console.log(e.detail.value)qqmapsdk.getSuggestion({keyword: e.detail.value, //用户输入的关键词,可设置固定值,如keyword:'KFC'//region:'北京', //设置城市名,限制关键词所示的地域范围,非必填参数success: (res) => {//搜索成功后的回调console.log(res);var sug = [];for (var i = 0; i < res.data.length; i++) {sug.push({ // 获取返回结果,放到sug数组中title: res.data[i].title,id: res.data[i].id,addr: res.data[i].address,city: res.data[i].city,district: res.data[i].district,latitude: res.data[i].location.lat,longitude: res.data[i].location.lng});}this.suggestion = sug},fail: (error)=> {console.error(error);},complete: (res)=> {console.log(res);}});},backfillBtn(e) {var id = e.currentTarget.id;for (var i = 0; i < this.suggestion.length; i++) {if (i == id) {this.backfill = this.suggestion[i].title}}},// 地点搜索nearbySearchBtn() {qqmapsdk.search({keyword: 'kfc', //搜索关键词location: '39.980014,116.313972', //设置周边搜索中心点success: (res) => {var mks = []for (var i = 0; i < res.data.length; i++) {mks.push({ // 获取返回结果,放到mks数组中title: res.data[i].title,id: res.data[i].id,latitude: res.data[i].location.lat,longitude: res.data[i].location.lng,iconPath: "/static/location.png", //图标路径width: 20,height: 20})}this.markers = mks},fail: (res) => {console.log(res);},complete: (res) => {console.log(res);}});},},onHide() {console.log('页面隐藏了')},}
</script>

预览效果如图下:

在这里插入图片描述

<script>import QQMapWX from '../../js_sdk/wxmp-qqmap/qqmap-wx-jssdk.js';var qqmapsdk;export default {components: {},data() {return {backfill: '',markers: [],poi: {latitude: 39.984060,longitude: 16.307520},}},onLoad() {console.log('页面加载了') // 实例化API核心类qqmapsdk = new QQMapWX({ // key: '申请的key'key: ''});},onShow() {console.log('页面显示了')},onReady() {console.log('页面初次渲染完成了')},methods: {formSubmit(e) {qqmapsdk.reverseGeocoder({location: e.detail.value.reverseGeo || '',//获取表单传入的位置坐标,不填默认当前位置,示例为string格式//get_poi: 1, //是否返回周边POI列表:1.返回;0不返回(默认),非必须参数success: (res) => {console.log(res);var res = res.result;var mks = [];/***  当get_poi为1时,检索当前位置或者location周边poi数据并在地图显示,可根据需求是否使用*for (var i = 0; i < result.pois.length; i++) {mks.push({ // 获取返回结果,放到mks数组中title: result.pois[i].title,id: result.pois[i].id,latitude: result.pois[i].location.lat,longitude: result.pois[i].location.lng,iconPath: './resources/placeholder.png', //图标路径width: 20,height: 20})}***///当get_poi为0时或者为不填默认值时,检索目标位置,按需使用mks.push({ // 获取返回结果,放到mks数组中title: res.address,id: 0,latitude: res.location.lat,longitude: res.location.lng,iconPath: '/static/location.png', //图标路径width: 20,height: 20,callout: { //在markers上展示地址名称,根据需求是否需要content: res.address,color: '#000',display: 'ALWAYS'}});this.markers = mks;// this.poi = {// 	latitude: res.location.lat,// 	longitude: res.location.lng// }},fail: (error) => {console.error(error);},complete: (res) => {console.log(res);}})}},onHide() {console.log('页面隐藏了')},}
</script>

geocoder – 提供由地址描述到所述位置坐标的转换,与逆地址解析reverseGeocoder()的过程正好相反。

预览效果如图:
在这里插入图片描述

formSubmit(e) {//调用地址解析接口qqmapsdk.geocoder({//获取表单传入地址 e.detail.value.geocoderaddress: e.detail.value, //地址参数,例:固定地址,address: '北京市海淀区彩和坊路海淀西大街74号'success: (res)=> {//成功后的回调console.log(res);var res = res.result;var latitude = res.location.lat;var longitude = res.location.lng;//根据地址解析在地图上标记解析地址位置this.markers = [{id: 0,title: res.title,latitude: latitude,longitude: longitude,iconPath: '/static/location.png',//图标路径width: 20,height: 20,callout: { //可根据需求是否展示经纬度content: latitude + ',' + longitude,color: '#000',display: 'ALWAYS'}}],this.poi= { //根据自己data数据设置相应的地图中心坐标变量名称latitude: Number(latitude),longitude:  Number(longitude),}},fail: (error)=> {console.error(error);},complete: (res)=> {console.log(res);}})
}

预览效果图如下:
在这里插入图片描述

formSubmit(e){//调用距离计算接口console.log(this.start,'dadaqianduan')qqmapsdk.calculateDistance({//mode: 'driving',//可选值:'driving'(驾车)、'walking'(步行),不填默认:'walking',可不填//from参数不填默认当前地址//获取表单提交的经纬度并设置from和to参数(示例为string格式)// from: e.detail.value.start || '', //若起点有数据则采用起点坐标,若为空默认当前地址from: this.start || '',to: this.end,// to: e.detail.value.dest, //终点坐标success: (res)=> {//成功后的回调console.log(res);var res = res.result;var dis = [];for (var i = 0; i < res.elements.length; i++) {dis.push(res.elements[i].distance); //将返回数据存入dis数组,}this.distance=dis},fail: (error)=> {console.error(error);},complete: (res)=> {console.log(res);}});}
},

调用获取城市列表接口,效果图如下:
在这里插入图片描述

onShow() {console.log('页面显示了')//调用获取城市列表接口qqmapsdk.getCityList({success: (res) => { //成功后的回调console.log(res);console.log('省份数据:', res.result[0]); //打印省份数据this.a = res.result[0]console.log('城市数据:', res.result[1]); //打印城市数据this.b = res.result[1]console.log('区县数据:', res.result[2]); //打印区县数据this.c = res.result[2]},fail: (error) => {console.error(error);},complete: (res) => {console.log(res);}});
},

获取城市区县,效果图如下:
在这里插入图片描述

onShow() {console.log('页面显示了')//调用获取城市列表接口qqmapsdk.getCityList({success: (res) => { //成功后的回调console.log(res);console.log('省份数据:', res.result[0])var city = res.result[0];//根据对应接口getCityList返回数据的Id获取区县数据(以北京为例)qqmapsdk.getDistrictByCityId({// 传入对应省份ID获得城市数据,传入城市ID获得区县数据,依次类推id: city[0].id, //对应接口getCityList返回数据的Id,如:北京是'110000'success: (res) => { //成功后的回调console.log(res);console.log('对应城市ID下的区县数据(以北京为例):', res.result[0]);},fail: (error) => {console.error(error);},complete: (res) => {console.log(res);}});},fail: (error) => {console.error(error);},complete: (res) => {console.log(res);}});
},

参考地址:https://lbs.qq.com/miniProgram/jsSdk/jsSdkGuide/jsSdkOverview

腾讯位置服务为微信小程序提供了基础的标点能力、线和圆的绘制接口等地图组件和位置展示、地图选点等地图API位置服务能力支持,使得开发者可以自由地实现自己的微信小程序产品。 在此基础上,腾讯位置服务微信小程序JavaScript SDK是专为小程序开发者提供的LBS数据服务工具包,可以在小程序中调用腾讯位置服务的POI检索、关键词输入提示、地址解析、逆地址解析、行政区划和距离计算等数据服务,让您的小程序更强大!

插件市场:https://ext.dcloud.net.cn/plugin?id=3746可以多下载试试玩,后续更新插件内容。
在这里插入图片描述
在这里插入图片描述
点击下方链接,申请腾讯地图开发者所用到的key,到官方进行注册:
专属邀请链接: https://lbs.qq.com?lbs_invite=VJJIFLV
专属邀请码: VJJIFLV

我是Jeskson(达达前端),感谢各位人才的:点赞、收藏和评论,我们下期见!

文章持续更新,本文个人网站 http://www.dadaqianduan.cn/#/ 已经收录,欢迎Star。


总结

以上就是今天要讲的内容,本文仅仅简单介绍了腾讯位置服务开发应用-使用教程,案例分享,知识总结。


http://chatgpt.dhexx.cn/article/ml3i85d7.shtml

相关文章

Unity基于GPS获取当前位置并将地图瓦片置于一个平面上

unity版本&#xff1a;2019.1.0f2 1.需要高德地图的key&#xff0c;去官网搞一个就行->高德的静态地图教程 2.然后将脚本挂在一个plane&#xff08;Map_Tile&#xff09;上就行了 3.加一个button&#xff0c;并将Onclick设置为下面的样子就完事了&#xff0c;然后导出&#…

微信小程序获取地理位置失败原因及解决方案

微信小程序获取用户地理位置失败的原因主要有3种情况&#xff1a; 1. 手机系统设置中地理位置未开启 2. 系统未给微信app授权 3. 用户未给小程序授权地理位置信息 所以需要继续完善下定位失败的处理逻辑。 1. 在获取地理位置信息失败后&#xff0c;首先判断用户手机系统定位服务…

百度、高德、腾讯、天地图、谷歌、必应地图切片切图工具 MapCutter(旧名MapTiler),支持超大图、高清切片、webgl、leaflet、maptalk、openlayers、cesium等

# MapCutter MapCutter 是制作覆盖图/瓦片图/金字塔图/游戏地图/切图切片的工具&#xff0c;它支持百度、腾讯、高德、天地图、谷歌、必应地图、MapBox等地图服务&#xff0c;是市面上最易用的同类软件&#xff0c;并支持js、webgl、leaflet、maptalks、openlayers、cesium 等…

java获取输入的地点的经纬度和编码等信息

我的苦衷 对于不规则,无序的数据做数据清洗,使之可以在GIS地图上展示出来数据。在地图上展示出来倒是不难,难的是如何对这些不规则,无序的数据做数据清洗,拿到每个的经纬度呢? 原始数据分析 数据清洗后的数据都有公司名称,还有地点,能到区。那这个就好办了。 既然我…

视频教程-Web前端开发仿美团/饿了吗移动App之高德地图接口对接案例-JavaScript

Web前端开发仿美团/饿了吗移动App之高德地图接口对接案例 互联网编程行业10年开发和授课经验 曾任太极集团&#xff0c;外资企业等一线互联网python高级开发工程师 现任聚焦计算机技术有限公司项目组担任架构师及项目经理 精通&#xff1a;python/php/web前端开发技术以及unity…

大数据之数据清洗之爬取数据后如何根据地名或者公司名获取经纬度信息-地址逆解析经纬度

关于本文章说明: 本文章的想法来源于:爬了大量的数据后,想利用GIS技术把数据展示在地图上。但是爬的数据又没有经纬度坐标,就无法在地图上进行展示了,所以用了百度地图的正/逆地理编码。计算机行业招聘智能分析平台效果

微信小程序地图获取地点信息(打卡签到功能为例)-2020-7-26

目录 微信小程序地图获取地点信息(打卡签到功能为例) 效果图前提步骤 首先需要了解的代码部分 配置性代码功能性代码demo 下载 微信小程序地图获取地点信息(打卡签到功能为例) 解决方案&#xff1a;利用微信小程序的地图组件获取到用户的地理位置信息(经纬度)&#xff0c;再通过…

IOS高德地图逆地理编码定位+网络判断

先说下这功能的流程&#xff0c; 流程:判断用户是否联网--->获取用户地理位置经纬度--->通过经纬度去查询地理位置名称 //高德地图 property (nonatomic, strong) MAMapView *mapView;//高德地图 property (nonatomic, strong) AMapSearchAPI *search; property(nonatom…

如何制作专业的手绘地图(电子地图、智慧导览系统)

一、智慧导览系统介绍 手绘电子地图&#xff0c;就是把手绘地图覆盖到地图上&#xff0c;游客或者普通用户&#xff0c;可以在手机上通过地图的链接&#xff08;或者现在流行的小程序&#xff09;打开使用。是一种使用非常方便&#xff0c;集**“视、听、路径规划、实时导航”*…

js技术调用高德api实现精准定位

我先说下写这个程序的起因&#xff0c;昨天晚上我的一个朋友在淘宝上卖它玩了两年的光遇号。 号给淘宝商家了就不理人也不给钱了&#xff0c;因为没有订单记录淘宝官方不管。这种回收游戏账号的微信账号的十有九骗。在黑猫上就能查到各种回收账号的诈骗案件。 于是我给我朋友写…

vue + 高德精准定位(示例)

鱼弦:CSDN内容合伙人、CSDN新星导师、51CTO(Top红人+专家博主) 、github开源爱好者(go-zero源码二次开发、游戏后端架构 https://github.com/Peakchen) 使用Vue和高德精准定位可以实现基于Vue框架的精准定位功能。下面是对该方法的原理、使用场景、文献材料链接以及当前使…

CocosCreator系列——接入高德地图sdk获取经纬度信息图文详解

CocosCreator接入高德地图sdk获取经纬度信息图文详解 先看效果 1.首先去 高德开放平台.申请key 接下来该获取发布版和调试版的SHA1了&#xff0c;首先打开cmd命令窗口 输入命令&#xff1a;cd .android(首先进入用户系统的安卓文件夹) 然后输入命令&#xff1a;keytool -li…

反应式编程框架设计:如何使得程序调用不阻塞等待

前言&#xff1a; 程序在高并发的情况下&#xff0c;程序容易崩溃。主要的原因是&#xff1a;在高并发的情况下&#xff0c;有大量用户请求需要程序计算处理&#xff0c;而目前的处理方式是&#xff0c;为每个用户请求分配一个线程&#xff0c;当程序内部因为访问数据库等原因…

TensorFlow编程框架基础

一、为什么要使用编程框架 深度学习的算法具有多层结构&#xff0c;每层的运算由一些基本操作构成&#xff0c;这些基本操作中存在大量共性运算&#xff0c;如卷积、池化、激活等。 将这些共性运算操作封装起来&#xff0c;可以提高编程实现效率。 面向这些封装起来的操作&am…

c语言编程框架_编程语言和框架的状态

c语言编程框架 作为专业的软件交付人员&#xff0c;我喜欢掌握技术趋势和“市场可能走向何方”。 在过去的十五年中&#xff0c;已经出现了许多语言和框架&#xff0c;并且几乎没有任何真正的持久力。 为了在“人们想知道的事情”上适销对路&#xff0c;使我知识广博&#xff0…

MFC编程框架总结

简介 MFC是一种C类库&#xff0c;利用面向对象的方法封装了Windows API&#xff0c;为Windows应用程序的开发带来了极大便利。本文总结了使用MFC进行编程的基本方法&#xff0c;编程环境为VS2008 SP1。 搭建MFC开发环境 由于使用MFC应用程序向导后VS会自动生成应用程序框架&am…

并发编程框架----disruptor框架(一)

背景 Disruptor是英国外汇交易公司LMAX开发的一个高性能队列&#xff0c;研发的初衷是解决内存队列的延迟问题&#xff08;在性能测试中发现竟然与I/O操作处于同样的数量级&#xff09;。基于Disruptor开发的系统单线程能支撑每秒600万订单&#xff0c;2010年在QCon演讲后&…

网络编程框架

网络编程 Socket网络通信编程 Socket主要解决一个网间进程通信&#xff08;不同主机进程间的相互通信问题&#xff09;。 提供进程通信的端点&#xff0c;一个程序将一段信息写入Socket中&#xff0c;该Socket将这段信息发送给另外一个Socket中&#xff0c;使这段信息能传送到…

您所应了解的Python四大主流网络编程框架

**本文内容摘录自《Python高效开发实战——Django、Tornado、Flask、Twisted》一书。**该书分为三部分&#xff1a;第1部分是基础篇&#xff0c;带领初学者实践Python开发环境和掌握基本语法&#xff0c;同时对网络协议、Web客户端技术、数据库建模编程等网络编程基础深入浅出地…