生活指南——让生活变得更简单

高德地图定位api_高德定位代码

课程:

高德地图怎样实现实时定位,得到当前地点的坐标,位置

开发指南第三章定位信息前半部分的代码实现的功能是:当手机采集的地理位置(经纬度)发生改变时在界面上显示出改变后的经纬度。如果开发过android原生定位程序的开发者应该对这部分代码不陌生,中规中矩,先注册位置监听服务,然后当位置发生改变后出发onLocationChanged()方法。现在请在官网上下载示例代码,导入工程后开启包com.amap.cn.apis.location中的MyLocation.java文件,该文件实现的主要功能是:初始化地图并且实现首次定位,地图会自动移动到定位点,我们一会便要基于这个文件来完成地图自动实时定位的功能。

高德地图javascript api和 定位api的区别

何页面调用百度图直接想要插入页面调用百度图代码即

百度图调用API址:

1.设置定位:直接搜索要找位置即

调用百度图代码

2.设置图:设置图式显示功能等

3.添加标注:添加要标注自定义坐标位置

4.获取代码:点击获取代码即要插入百度图入百度图代码

要插入部代码行

高德地图jsapi定位,用wifi 打开gps,精度是30米 然后用4G打开gps 精度 600米,怎么让4G定位的精度也在30

这个结论不够科学。

首先,高德地图,以及百度、腾讯、谷歌等等所有其他地图,都没有获取GPS卫星信号进行定位的能力,而只是利用手机GPS模块的定位成果,因此,把GPS定位是否准确归之于哪个地图,是不科学的。

其次,GPS与WIFI哪个定位更准确,也要分情况。就目前技术水平而言,GPS定位精度一般在2-20米左右,最高可达2米以下,最低一般不会超过200米;而WIFI定位精度是不确定的,有时可能很精确,也可以达到10米级,但通常误差会比较大,误差几百米、几公里,甚至定位到外省市去,都是可能的。

归纳一下,当GPS定位条件差定位误差大,WIFI定位条件好定位误差小的情况下,楼主所说的情况有可能出现。但只是一种偶然现象。

android开发如何用高德地图进行模拟定位.

一、 要实现高德地图定位呢,首先需要做好以下几步准备:

1. 在高德开放平台注册帐号

2. 在开发中下载Android平台下的地图SDK和定位SDK文件

进入相关下载下载自己想要的功能或文件,图只是截取了地图SDK的页面,定位SDK也是一样,按自己想要的文件下载。下载完成后解压得到:

- 3D地图包解压后得到:3D地图显示包“AMap_3DMap_VX.X.X_时间.jar”和库文件夹(包含armeabi、arm64-v8a等库文件)。

- 2D地图包解压后得到:2D地图显示包“AMap_2DMap_VX.X.X_时间.jar ”

- 定位SDK下载并解压得到定位包“AMap_Location_V2.x.x.jar“

3. 添加jar包,将jar包放入工程的libs目录下。

对于每个jar文件,右键-选择Add As Library,导入到工程中。或者使用菜单栏 选择 File -Project Structure-Modules- Dependencies。点击绿色的加号选择File dependency. 然后选择要添加的jar包即可,此时build.gradle中会自动生成如下信息。

创建自己的应用(创建过程内需要的SHA1已经的博客讲过)

开发环境已经配置好了,接下来就是敲代码了。

二、 首先我们要做的就是将地图显示出来,通过以下几步操作,即可在应用中使用高德地图SDK:

第一步:添加用户key 在工程的“ AndroidManifest.xml ”文件如下代码中添加您的用户 Key。

application

android:allowBackup="true"

android:icon="@mipmap/ic_launcher"

android:label="@string/app_name"

android:supportsRtl="true"

android:theme="@style/AppTheme"

meta-data

android:name="com.amap.api.v2.apikey"

android:value="c9df032baec3ec50b1e089768ea4672b" /123456789

第二步:添加所需权限 在工程的“ AndroidManifest.xml ”文件中进行添加。

//地图包、搜索包需要的基础权限

uses-permission android:name="android.permission.INTERNET" /

uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /

uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /

uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /

uses-permission android:name="android.permission.READ_PHONE_STATE" /

uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /

//定位包、导航包需要的额外权限(注:基础权限也需要)

uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /

uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS" /

uses-permission android:name="android.permission.ACCESS_MOCK_LOCATION" /

uses-permission android:name="android.permission.CHANGE_WIFI_STATE" /1234567891011121314

第三步:在布局xml文件中添加地图控件。

com.amap.api.maps2d.MapView

android:id="@+id/map_view"

android:layout_width="match_parent"

android:layout_height="match_parent" /1234

第四步,创建地图Activity,管理地图生命周期。

public class MainActivity extends Activity {

private MapView mMapView = null;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

//获取地图控件引用

mMapView = (MapView) findViewById(R.id.map_view);

//在activity执行onCreate时执行mMapView.o

mMapView.onCreate(savedInstanceState);

}

@Override

protected void onDestroy() {

super.onDestroy();

//在activity执行onDestroy时执行mMapView.onDestroy(),实现地图生命周期管理

mMapView.onDestroy();

}

@Override

protected void onResume() {

super.onResume();

//在activity执行onResume时执行mMapView.onResume (),实现地图生命周期管理

mMapView.onResume();

}

@Override

protected void onPause() {

super.onPause();

//在activity执行onPause时执行mMapView.onPause (),实现地图生命周期管理

mMapView.onPause();

}

@Override

protected void onSaveInstanceState(Bundle outState) {

super.onSaveInstanceState(outState);

//在activity执行onSaveInstanceState时执行mMapView.onSaveInstanceState (outState),实现地图生命周期管理

mMapView.onSaveInstanceState(outState);

}

}12345678910111213141516171819202122232425262728293031323334353637

注意:一定要有mMapView.onCreate(savedInstanceState);

第二步:启动定位功能:

1. 在主线程中获得地图对象AMap,并设置定位监听且实现LocationSource接口:

public class MainActivity extends Activity implements LocationSource{1

if (aMap == null) {

aMap = mMapView.getMap();

//设置显示定位按钮 并且可以点击

UiSettings settings = aMap.getUiSettings();

aMap.setLocationSource(this);//设置了定位的监听,这里要实现LocationSource接口

// 是否显示定位按钮

settings.setMyLocationButtonEnabled(true);

aMap.setMyLocationEnabled(true);//显示定位层并且可以触发定位,默认是flase

}123456789

2. 配置定位参数,启动定位

//初始化定位

mLocationClient = new AMapLocationClient(getApplicationContext());

//设置定位回调监听,这里要实现AMapLocationListener接口,AMapLocationListener接口只有onLocationChanged方法可以实现,用于接收异步返回的定位结果,参数是AMapLocation类型。

mLocationClient.setLocationListener(this);

//初始化定位参数

mLocationOption = new AMapLocationClientOption();

//设置定位模式为Hight_Accuracy高精度模式,Battery_Saving为低功耗模式,Device_Sensors是仅设备模式

mLocationOption.setLocationMode(AMapLocationClientOption.AMapLocationMode.Hight_Accuracy);

//设置是否返回地址信息(默认返回地址信息)

mLocationOption.setNeedAddress(true);

//设置是否只定位一次,默认为false

mLocationOption.setOnceLocation(false);

//设置是否强制刷新WIFI,默认为强制刷新

mLocationOption.setWifiActiveScan(true);

//设置是否允许模拟位置,默认为false,不允许模拟位置

mLocationOption.setMockEnable(false);

//设置定位间隔,单位毫秒,默认为2000ms

mLocationOption.setInterval(2000);

//给定位客户端对象设置定位参数

mLocationClient.setLocationOption(mLocationOption);

//启动定位

mLocationClient.startLocation();12345678910111213141516171819202122

高精度定位模式:

在这种定位模式下,将同时使用高德网络定位和GPS定位,优先返回精度高的定位

低功耗定位模式:

在这种模式下,将只使用高德网络定位

仅设备定位模式:

在这种模式下,将只使用GPS定位。

3. 实现AMapLocationListener接口,获取定位结果:

public class MainActivity extends Activity implem

@Override

public void onLocationChanged(AMapLocation aMapLocation) {

if (aMapLocation != null) {

if (aMapLocation.getErrorCode() == 0) {

//定位成功回调信息,设置相关消息

aMapLocation.getLocationType();//获取当前定位结果来源,如网络定位结果,详见官方定位类型表

aMapLocation.getLatitude();//获取纬度

aMapLocation.getLongitude();//获取经度

aMapLocation.getAccuracy();//获取精度信息

SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

Date date = new Date(aMapLocation.getTime());

df.format(date);//定位时间

aMapLocation.getAddress();//地址,如果option中设置isNeedAddress为false,则没有此结果,网络定位结果中会有地址信息,GPS定位不返回地址信息。

aMapLocation.getCountry();//国家信息

aMapLocation.getProvince();//省信息

aMapLocation.getCity();//城市信息

aMapLocation.getDistrict();//城区信息

aMapLocation.getStreet();//街道信息

aMapLocation.getStreetNum();//街道门牌号信息

aMapLocation.getCityCode();//城市编码

aMapLocation.getAdCode();//地区编码

// 如果不设置标志位,此时再拖动地图时,它会不断将地图移动到当前的位置

if (isFirstLoc) {

//设置缩放级别

aMap.moveCamera(CameraUpdateFactory.zoomTo(17));

//将地图移动到定位点

aMap.moveCamera(CameraUpdateFactory.changeLatLng(new LatLng(aMapLocation.getLatitude(), aMapLocation.getLongitude())));

//点击定位按钮 能够将地图的中心移动到定位点

mListener.onLocationChanged(aMapLocation);

//获取定位信息

StringBuffer buffer = new StringBuffer();

buffer.append(aMapLocation.getCountry() + ""

+ aMapLocation.getProvince() + ""

+ aMapLocation.getCity() + ""

+ aMapLocation.getProvince()

+ aMapLocation.getDistrict() + ""

+ aMapLocation.getStreet() + ""

+ aMapLocation.getStreetNum());

Toast.makeText(getApplicationContext(), buffer.toString(), Toast.LENGTH_LONG).show();

isFirstLoc = false;

}

} else {

//显示错误信息ErrCode是错误码,errInfo是错误信息,详见错误码表。

Log.e("AmapError", "location Error, ErrCode:"

+ aMapLocation.getErrorCode() + ", errInfo:"

+ aMapLocation.getErrorInfo());

Toast.makeText(getApplicationContext(), "定位失败", Toast.LENGTH_LONG).show();

}

}

}123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051

4.关于停止定位

@Override

protected void onDestroy() {

super.onDestroy();

mapView.onDestroy();

//mLocationClient.stopLocation();//停止定位

mLocationClient.onDestroy();//销毁定位客户端。

//销毁定位客户端之后,若要重新开启定位请重新New一个AMapLocationClient对象。

}

//激活定位

@Override

public void activate(OnLocationChangedListener onLocationChangedListener) {

mListener = onLocationChangedListener;

}

@Override

public void deactivate() {

mListener = null;

}12345678910111213141516171819

android使用高德定位sdk获取的城市名称怎样让其他的界面进行调用

第一步,我们需要下载SDK

第二步,解压后,将jar包放进libs文件夹中,并加入环境变量中。

第三步,在AndroidManifest.xml文件中配置权限:

!--用于进行网络定位--

uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/

!--用于访问GPS定位--

uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/

!--用于获取运营商信息,用于支持提供运营商信息相关的接口--

uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/

!--用于访问wifi网络信息,wifi信息会用于进行网络定位--

uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/

!--用于获取wifi的获取权限,wifi信息会用来进行网络定位--

uses-permission android:name="android.permission.CHANGE_WIFI_STATE"/

!--用于访问网络,网络定位需要上网--

uses-permission android:name="android.permission.INTERNET"/

!--用于读取手机当前的状态--

uses-permission android:name="android.permission.READ_PHONE_STATE"/

!--用于写入缓存数据到扩展存储卡--

uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/

!--用于申请调用A-GPS模块--

uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS"/

并在application标签中添加:

meta-data

android:name="com.amap.api.v2.apikey"

android:value="你申请的key" /

service android:name="com.amap.api.location.APSService" /

第四步,测试代码:

import android.support.v7.app.AppCompatActivity;

import android.os.Bundle;

import android.util.Log;

import com.amap.api.location.AMapLocation;

import com.amap.api.location.AMapLocationClient;

import com.amap.api.location.AMapLocationClientOption;

import com.amap.api.location.AMapLocationListener;

public class MainActivity extends AppCompatActivity {

//声明AMapLocationClient类对象

public AMapLocationClient mLocationClient = null;

//声明定位回调监听器

public AMapLocationListener mLocationListener = new MyAMapLocationListener();

//声明AMapLocationClientOption对象

public AMapLocationClientOption mLocationOption = null;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

init();

}

private void init() {

//初始化定位

mLocationClient = new AMapLocationClient(getApplicationContext());

//设置定位回调监听

mLocationClient.setLocationListener(mLocationListener);

//初始化AMapLocationClientOption对象

mLocationOption = new AMapLocationClientOption();

//设置定位模式为AMapLocationMode.Hight_Accuracy,高精度模式。

mLocationOption.setLocationMode(AMapLocationClientOption.AMapLocationMode.Hight_Accuracy);

//获取一次定位结果:

//该方法默认为false。

mLocationOption.setOnceLocation(false);

//获取最近3s内精度最高的一次定位结果:

//设置setOnceLocationLatest(boolean b)接口为true,启动定位时SDK会返回最近3s内精度最高的一次定位结果。如果设置其为true,setOnceLocation(boolean b)接口也会被设置为true,反之不会,默认为false。

mLocationOption.setOnceLocationLatest(true);

//设置是否返回地址信息(默认返回地址信息)

mLocationOption.setNeedAddress(true);

//设置是否允许模拟位置,默认为false,不允许模拟位置

mLocationOption.setMockEnable(false);

//关闭缓存机制

mLocationOption.setLocationCacheEnable(false);

//给定位客户端对象设置定位参数

mLocationClient.setLocationOption(mLocationOption);

//启动定位

mLocationClient.startLocation();

}

private class MyAMapLocationListener implements AMapLocationListener {

@Override

public void onLocationChanged(AMapLocation aMapLocation) {

if (aMapLocation != null) {

if (aMapLocation.getErrorCode() == 0) {

Log.e("位置:", aMapLocation.getAddress());

} else {

//定位失败时,可通过ErrCode(错误码)信息来确定失败的原因,errInfo是错误信息,详见错误码表。

Log.e("AmapError", "location Error, ErrCode:"

+ aMapLocation.getErrorCode() + ", errInfo:"

+ aMapLocation.getErrorInfo());

}

}

}

}

}

  • 评论列表:
  •  访客
     发布于 2022-07-04 08:28:08  回复该评论
  • 问GPS定位--uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/!--用于获取运营商信息,用于支持提供运营商信息相关的接口--uses-permission android:name="a
  •  访客
     发布于 2022-07-04 05:23:59  回复该评论
  • ocationClientOption对象mLocationOption = new AMapLocationClientOption();//设置定位模式为AMapLocationMode.Hight_Accuracy,高精
  •  访客
     发布于 2022-07-04 07:11:34  回复该评论
  • ess(true); //设置是否只定位一次,默认为false mLocationOption.setOnceLocation(false); //设置是否强制刷新WIFI,默认为强制刷新 mLocationOption.setWifiAc
  •  访客
     发布于 2022-07-04 09:04:28  回复该评论
  • ld.gradle中会自动生成如下信息。 创建自己的应用(创建过程内需要的SHA1已经的博客讲过) 开发环境已经配置好了,接下来就是敲代码了。二、 首先我们要做的就是将地图显示出来,通过以下几步操作,即
  •  访客
     发布于 2022-07-04 08:32:06  回复该评论
  • } }}1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950514.关于停止定位 @Overr

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

Copyright Your WebSite.Some Rights Reserved.