uniapp获取当前位置保姆级教程(uni.getFuzzyLocation和腾讯地图API)


实现截图

在这里插入图片描述
**
编译器:Hbuilder,运行器:微信开发者工具
主要流程:在微信开发者官网申请uni.getFuzzyLocatoin权限=>利用该方法调用出当前位置经纬度=>在腾讯地图开发官网中注册并创建应用获取密钥=>利用腾讯地图API对前者的经纬度进行转义实现获取当前位置**
下面就是全套教程

前期准备工作

在开始前,需要在微信开发者平台申请uni.getFuzzyLocation API的权限,如何申请getFuzzyLocation在我的另一篇文章有讲到,链接放在下面.这里就不赘述了
https://blog.csdn.net/lplovewjm/article/details/130215474?spm=1001.2014.3001.5501

还需要在腾讯地图开发者官网注册账号官网链接放在下面
https://lbs.qq.com/

一、如何使用getFuzzyLocation接口获取经纬度

我先默认你已经在微信开发者官网申请授权getFuzzyLocation,

使用流程:配置manifest.json=>配置page.json=>页面调用方法以及实现.

配置manifest.json
创建完uniapp项目后点击marnfest.json在它左侧视图中找到源码视图并点击.
在这里插入图片描述
加上如下代码:
appid设置成自己的Id

/* 小程序特有相关 */
	    "mp-weixin" : {
	        "appid" : "wxa8e6388009466d0c",
	        "setting" : {
	            "urlCheck" : false
	        },
	        "usingComponents" : true,
	        "permission" : {
	            "scope.userFuzzyLocation":{
	            	"desc":"位置信息效果展示"
	            }
	        },
	        "requiredPrivateInfos" : [ "getFuzzyLocation" ]
	    },

在这里插入图片描述配置完点击pages.json

"permission":{
	"scope.userFuzzyLocation":{
		"desc":"位置信息效果展示"
	}
}

在这里插入图片描述
配置完后点击要运行的页面调用接口

<template>
</template>


<script>
	export default {
		data() {
			return {
				longitude: null,
				latitude: null,
			}
		},
		onLoad() {
			this.location()
		},
		methods: {
			location() {
				var that=this
				uni.getFuzzyLocation({
					success: function(res) {
						this.longitude=res.longitude
						this.latitude=res.latitude
						console.log(res)
					},
				});
			}
		}
	}
</script>

<style>
	.title {
		display: inline-block;
		margin: 20px;
		font-size: 20px;
	}
</style>

运行该代码即可成功调用uni.getFuzzyLocation接口,并获取到经纬度,

二、如果调用腾讯地图API来根据经纬度输出所在位置

注册腾讯地图开发者=>点击左上角控制台=>点击管理应用-我的应用=>在右上角找到创建应用=>创建应用的key=>在页面中调用方法.

1.注册腾讯地图开发者

官网:https://lbs.qq.com/

注册成功后点击右上角控制台:
在这里插入图片描述
在左侧工具栏中点击管理应用-我得应用
在这里插入图片描述
点击右上角创建应用,配置应用信息
创建成功后点击添加key:
在这里插入图片描述
配置成功后返回运行界面,调用腾讯地图API并且显示数据.

全部代码如下:
腾讯地图中的key要用自己的key

<template>
	<view>
		<view class="title">当前位置:<text style="font-weight: bold;">{{address}}</text></view>
		<button @click="locationn">点击获取当前位置</button>
	</view>
</template>


<script>
	export default {
		data() {
			return {
				longitude: null,
				latitude: null,
				address: ""
			}
		},
		onLoad() {
			this.location()
		},
		methods: {

			location() {
				var that=this
				uni.getFuzzyLocation({
					success: function(res) {
						that.longitude=res.longitude
						that.latitude=res.latitude
					},
				});
			},
			locationn() {
				console.log(this.longitude)
				console.log(this.latitude)
				uni.request({
					url: `https://apis.map.qq.com/ws/geocoder/v1/?location=${encodeURIComponent(this.latitude)},${encodeURIComponent(this.longitude)}&key=E7XBZ-FUXC7-D22XZ-POFT7-OD5LJ-6RBAV&get_poi=1`,
					method: 'GET',
					success: (res) => {
						console.log(res)
						this.address=res.data.result.ad_info.city
					}
				})

			}
		}
	}
</script>

<style>
	.title {
		display: inline-block;
		margin: 20px;
		font-size: 20px;
	}
</style>

2.代码逻辑

利用onLoad生命周期函数来调用getFuzzyLocation方法获取经纬度,把经纬度赋给data的数据中,点击调用腾讯地图API,把我想要的值赋给

address,在template中进行显示.

注:腾讯地图API中的url中的是`而不是’,

that调用也可以替换成success:()=>{}方式,本质上都是指向

总结

在本文中介绍了getFuzzyLocation的简单使用和腾讯地图API的简单调用,它俩的用法还有很多,包括微信开发者工具自带的getLocation就可以实现上述效果,但是申请没有getFuzzyLocation好申请,腾讯地图API中也可以根据当前IP地址来进行调用,在官网中都有详细的接口文档供大家使用,文章对于我而言最难的部分其实是腾讯地图的API调用,因为老是显示location格式不正确,所以一直以为是url的接口写错了,最后才发现原来是success没有用=>,把this改成var that= this 调用that就解决了,
最后,文章有点长,希望能帮到大家.

进窄门,走远路,见微光.

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
Android 和风天气 SDK 是一款强大的天气查询工具,可以帮助开发者获取实时天气信息。下面是关于如何在 Android 应用中使用 Andriod 和风天气 SDK 的保姆教程: 1. 首先,你需要在和风天气官网(https://www.heweather.com/)注册一个账号,并创建一个应用,获取到你的应用的 API key。API key 是用来标识你的应用的身份,每个应用都有一个唯一的 API key。 2. 在你的 Android 项目中,添加和风天气 SDK 的依赖。可以通过在 build.gradle 文件中的 dependencies 中添加以下代码实现: ``` implementation 'com.heweather.android:HeWeatherSDK:x.x.x' ``` 请将 "x.x.x" 替换为最新版本号。 3. 在你的代码中,引入和风天气 SDK 的相关类,并初始化 SDK: ``` HeConfig.init("你的 API key", "中国"); ``` 请将 "你的 API key" 替换为你在第一步中获取到的 API key。 4. 创建一个和风天气的请求对象,并设置需要查询的城市和天气类型: ``` WeatherRequest request = new WeatherRequest.Builder() .city("北京") .build(); ``` 请将 "北京" 替换为你需要查询的城市名称。 5. 发起天气查询请求,并处理返回的结果: ``` WeatherManager.getInstance().getWeatherNow(request, new OnResultWeatherNowListener() { @Override public void onError(Throwable throwable) { // 处理错误 } @Override public void onSuccess(WeatherNowBean bean) { // 处理成功,获取实时天气信息 String weather = bean.getNow().getWeather(); String temperature = bean.getNow().getTemperature(); // 在这里可以根据需要进行相应的操作,比如更新界面显示等 } }); ``` 通过以上步骤,你就可以在你的 Android 应用中使用和风天气 SDK 来获取实时天气信息了。请注意,和风天气 SDK 还提供了其他丰富的功能,比如获取未来几天的天气预报、空气质量等等,你可以去官网查看更多的文档和示例代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱吃巧克li

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值