Android 高德地图——地图模拟导航

mAMapNaviView.onCreate(savedInstanceState);这句话一定要写,要不地图不显示。
其他还是按着官网上的来,有个问题implements,这个类似于iOS的协议代理,他叫做接口,是所有相关的接口都要实现么?反正我是都写了的。
还有一个是模拟的时候可以调节速度,挺好玩的

package com.ditu.kaiwei.gaode2;

import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.View;
import android.widget.Button;

import com.amap.api.location.AMapLocation;
import com.amap.api.location.AMapLocationClient;
import com.amap.api.location.AMapLocationClientOption;
import com.amap.api.location.AMapLocationListener;
import com.amap.api.maps.AMap;
import com.amap.api.maps.LocationSource;
import com.amap.api.maps.MapView;
import com.amap.api.maps.model.MyLocationStyle;



public class Gaode extends AppCompatActivity implements LocationSource, AMapLocationListener {

    MapView mMapView = null;
    AMap aMap;
    MyLocationStyle myLocationStyle;

    OnLocationChangedListener mListener;
    AMapLocationClient mlocationClient;
    AMapLocationClientOption mLocationOption;

    Button daohang;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_gaode);
        //获取地图控件引用
        mMapView = (MapView) findViewById(R.id.map);
        //在activity执行onCreate时执行mMapView.onCreate(savedInstanceState),创建地图
        mMapView.onCreate(savedInstanceState);

        //初始化地图控制器对象
        aMap = mMapView.getMap();
        myLocationStyle = new MyLocationStyle();//初始化定位蓝点样式类

        aMap.setMyLocationStyle(myLocationStyle);//设置定位蓝点的Style
        aMap.getUiSettings().setMyLocationButtonEnabled(true);//设置默认定位按钮是否显示,非必需设置。

        // 设置定位监听
        aMap.setLocationSource(this);
// 设置为true表示显示定位层并可触发定位,false表示隐藏定位层并不可触发定位,默认是false
        aMap.setMyLocationEnabled(true);
// 设置定位的类型为定位模式,有定位、跟随或地图根据面向方向旋转几种
        aMap.setMyLocationType(AMap.LOCATION_TYPE_MAP_FOLLOW);

        daohang = (Button)findViewById(R.id.button2);
        daohang.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Intent intent = new Intent(); //就是他
                intent.setClass(Gaode.this,daohangA.class); //第一个是当前的上下文信息,第二个是我们要跳转的类

                startActivity(intent); //开始就是调用一个新的Activity
                Gaode.this.finish(); //完成就是关闭啊

            }
        });

    }
    @Override
    protected void onDestroy() {
        super.onDestroy();
        //在activity执行onDestroy时执行mMapView.onDestroy(),销毁地图
        mMapView.onDestroy();
        if(null != mlocationClient){
            mlocationClient.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);
    }

    @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.onDestroy();
        }
        mlocationClient = null;
    }

    @Override
    public void onLocationChanged(AMapLocation amapLocation) {
        if (mListener != null&&amapLocation != null) {
            if (amapLocation != null
                    &&amapLocation.getErrorCode() == 0) {
                mListener.onLocationChanged(amapLocation);// 显示系统小蓝点
            } else {
                String errText = "定位失败," + amapLocation.getErrorCode()+ ": " + amapLocation.getErrorInfo();
                Log.e("AmapErr",errText);
            }
        }

    }
}
### 关于高德地图轨迹功能的使用方法 #### 添加依赖库 为了在应用程序中实现高德地图的轨迹回放功能,需先配置`build.gradle`文件来引入必要的API包。对于Android应用开发而言,应该确保在项目的构建脚本里加入了如下所示的依赖项[^1]: ```gradle implementation 'com.amap.api:navi-3dmap:latest.integration' implementation 'com.amap.api:location:latest.integration' implementation 'com.amap.api:search:latest.integration' ``` 这些依赖分别用于提供三维地图显示、位置服务以及地理搜索的能力。 #### 初始化SDK并加载插件 当采用Vue框架进行Web端开发时,则需要通过安装特定的npm包来进行初始化设置,并指定要使用的插件列表。下面是一段典型的JavaScript代码片段用来完成这一操作[^4]: ```javascript import VueAMap from 'vue-amap'; Vue.use(VueAMap); VueAMap.initAMapApiLoader({ key: '<Your_AMap_Key>', // 替换成自己的Key plugin: [ 'AMap.Autocomplete', 'AMap.PlaceSearch', 'AMap.Scale', 'AMap.OverView', 'AMap.ToolBar', 'AMap.MapType', 'AMap.PolyEditor', 'AMap.CircleEditor', 'AMap.MarkerClusterer', 'AMap.MouseTool', 'AMap.Geocoder', 'AMap.Driving' ], v: '1.4.15' }); ``` 这段代码不仅完成了对高德地图JS API的基础配置,还集成了多个实用工具类和服务接口供后续调用。 #### 实现具体业务逻辑 针对具体的业务需求——即如何实现在网页或者移动设备上的轨迹回放效果,开发者可以根据实际情况选择合适的前端技术栈实施解决方案。如果是以Vue为基础的话,那么可以考虑利用Element UI这样的UI组件库辅助快速搭建界面控件,比如滑动条(`el-slider`)可用于控制播放进度;同时配合高德官方提供的文档指南编写相应的交互事件处理函数,从而达到预期的效果[^2][^3]。 例如,在页面上展示一条由一系列坐标点构成的历史行车路线,并允许用户点击按钮触发该线路按照一定速度模拟重播的过程。期间还可以加入更多个性化定制选项,像改变标记物外观形象(如更换成不同类型的交通工具图标)、调整动画帧率等特性提升用户体验感。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

赫凯

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

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

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

打赏作者

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

抵扣说明:

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

余额充值