Android之⾼德地图SDK配置及简单使⽤详解需要⽤到的东西请去下载
本次教程是对⽐着⾼德官⽹的demo⼀步步添加东西,所以需要有⼀份demo就够了。
1.打开⾼德地图的demo(AMap3DDemo),同时新建⼀个项⽬
2.将demo中的带Amap的三个jar包复制到新建项⽬的lib⽬录下,同时添加依赖项
3.在app下新建个directory—>jniLibs,然后在下⾯新建四个⽬录,如下:
4.然后拖到main⽅法中,在android下就可以看到
5.然后再demo下的so⽂件都放在四个⽬录下(四个⽬录放的东西⼀样)
6.将demo⾥⾯的权限复制到相应位置
7.将meta标签复制到相应位置同时去⾼德API官⽹申请个key填到相应位置
android简单教程8.将下⾯服务那句也复制到相应位置
9.在布局中添加个MapView
10.将主函数中location⽂件夹下的LocationModeSourceActivity.java中有⽤的东西复制到主函数中
以上,就可以实现最简单的定位
附代码
清单⽂件:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="schemas.android/apk/res/android"
package="d.myamap">
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.CHANGE_CONFIGURATION" />
<uses-permission android:name="android.permission.WAKE_LOCK" />
<uses-permission android:name="android.permission.WRITE_SETTINGS" />
<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="50b8319a5d03de4dbfa4ee6bd79756fc" />
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<!-- 定位需要的服务使⽤2.0的定位需要加上这个 -->
<service android:name="com.amap.api.location.APSService" >
</service>
</application>
</manifest>
主函数:
public class MainActivity extends AppCompatActivity implements LocationSource, AMapLocationListener {
private MapView mapView;
private AMap aMap;
private AMapLocationClient mlocationClient;
private OnLocationChangedListener mListener;
private AMapLocationClientOption mLocationOption;
@Override
protected void onCreate(Bundle savedInstanceState) {
setContentView(R.layout.activity_main);
mapView= (MapView) findViewById(R.id.map);
mapView= (MapView) findViewById(R.id.map);
init();
}
/**
* 初始化
*/
private void init() {
if (aMap == null) {
aMap = Map();
setUpMap();
}
}
/
**
* 设置⼀些amap的属性
*/
private void setUpMap() {
aMap.setLocationSource(this);// 设置定位监听
aMap.setMyLocationEnabled(true);// 设置为true表⽰显⽰定位层并可触发定位,false表⽰隐藏定位层并不可触发定位,默认是false // 设置定位的类型为定位模式,可以由定位、跟随或地图根据⾯向⽅向旋转3种
//跟随:LOCATION_TYPE_MAP_FOLLOW
//旋转:LOCATION_TYPE_MAP_ROTATE
//定位:LOCATION_TYPE_LOCATE
aMap.setMyLocationType(AMap.LOCATION_TYPE_LOCATE);
}
/**
* 定位成功后回调函数
*/
@Override
public void onLocationChanged(AMapLocation amapLocation) {
if (mListener != null && amapLocation != null) {
if (amapLocation != null
&& ErrorCode() == 0) {
Log.d("===经度:",""+Longitude());
Log.d("===纬度:",""+Latitude());
} else {
String errText = "定位失败," + ErrorCode()+ ": " + ErrorInfo();
Log.e("AmapErr",errText);
}
}
}
/**
* 激活定位
*/
@Override
public void activate(OnLocationChangedListener listener) {
mListener = listener;
if (mlocationClient == null) {
mlocationClient = new AMapLocationClient(this);
mLocationOption = new AMapLocationClientOption();
//设置定位监听
mlocationClient.setLocationListener(this);
//设置为⾼精度定位模式
mLocationOption.setLocationMode(AMapLocationClientOption.AMapLocationMode.Hight_Accuracy);
//设置定位参数
mlocationClient.setLocationOption(mLocationOption);
// 此⽅法为每隔固定时间会发起⼀次定位请求,为了减少电量消耗或⽹络流量消耗,
// 注意设置合适的定位时间的间隔(最⼩间隔⽀持为2000ms),并且在合适时间调⽤stopLocation()⽅法来取消定位请求
// 在定位结束后,在合适的⽣命周期调⽤onDestroy()⽅法
// 在单次定位情况下,定位⽆论成功与否,都⽆需调⽤stopLocation()⽅法移除请求,定位sdk内部会移除
mlocationClient.startLocation();
}
}
/**
* 停⽌定位
*/
@Override
public void deactivate() {
mListener = null;
if (mlocationClient != null) {
mlocationClient.stopLocation();
}
mlocationClient = null;
}
/**
* ⽅法必须重写
*/
@Override
protected void onResume() {
}
/**
* ⽅法必须重写
*/
@Override
protected void onPause() {
deactivate();
}
/**
* ⽅法必须重写
*/
@Override
protected void onSaveInstanceState(Bundle outState) {
}
/**
* ⽅法必须重写
*/
@Override
protected void onDestroy() {
if(null != mlocationClient){
}
}
}
布局⽂件中添加⼀个MapView即可
<com.amap.api.maps.MapView
android:id="@+id/map"
android:layout_width="match_parent"
android:layout_height="match_parent" >
</com.amap.api.maps.MapView>
遇到的错误:(下⾯这句报错)
错误类型:java.lang.UnsatisfiedLinkError: Native method not found:
com.autonavi.amap.mapcore.MapCore.nativeNewInstance:(Ljava/lang/String;Ljava/lang/String;)J 解决⽅法:将主函数中继承的v7包的AppCompatActivity改为Activity即可。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。