reactnative 获取定位_React Native 地图定位geolocation,获取位置并逆地理转换

componentDidMount() {

this.handleGetLocation();

}

// 获取位置并逆地理转换

handleGetLocation=()=>{

// 当前定位经纬度

navigator.geolocation.getCurrentPosition(

(position) => {

const initialPosition = position

console.log(initialPosition)

const { longitude } = initialPosition.coords

const { latitude } = initialPosition.coords

console.log(`${longitude},${latitude}`)

//通过调用高德地图逆地理接口,传入经纬度获取位置信息

fetch(`http://restapi.amap.com/v3/geocode/regeo?key=2118fd7600536f90d28d&location=${longitude},${latitude}&radius=1000&extensions=all&batch=false&roadlevel=0`, {

method: "POST",

headers: {

"Content-Type": "application/x-www-form-urlencoded"

},

body: ``

})

.then((response) => response.json())

.then((jsonData) => {

try {

console.log(jsonData)

this.setState({

positionValue:jsonData.regeocode.formatted_address,

positionValue2:jsonData.regeocode.addressComponent.province,

positionValue3:jsonData.regeocode.addressComponent.district,

positionValue4: jsonData.regeocode.addressComponent.cityNm,

positionValue5: jsonData.regeocode.addressComponent.adcode,

})

}catch (e) {

}

})

.catch((error) => {

console.error(error);

})

},

(error) => console.log(error),

{ timeout: 20000, maximumAge: 1000 },

)

}

getstlCycleList() {

this.setState({

stlCycleList: stlCycleItem.map((item, index) => (

{item.name}

))

});

}

title="详细地址"

style={{ height: 66 }}

detail={

style={{ textAlign: "right", paddingHorizontal: 10, flex: 1 }}

maxLength={20}

// keyboardType="numeric"

multiline={true}//多行输入

editable={true}//是否可编辑

placeholder="请输入详细地址"

value={this.state.positionValue}

// value={this.state.positionValue2}

onChangeText={text => this.setState({ positionValue: text })}

/>

}

/>

1596624138477.jpg

这里不能写错

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值