Android 百度地图标点定位,动画标点

2 篇文章 0 订阅
1 篇文章 0 订阅

前期实现与”定位”中步骤相同,参考:
代码片段中:

import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.widget.Toast;

import com.baidu.mapapi.SDKInitializer;
import com.baidu.mapapi.map.BaiduMap;
import com.baidu.mapapi.map.BitmapDescriptor;
import com.baidu.mapapi.map.BitmapDescriptorFactory;
import com.baidu.mapapi.map.MapView;
import com.baidu.mapapi.map.Marker;
import com.baidu.mapapi.map.MarkerOptions;
import com.baidu.mapapi.map.Overlay;
import com.baidu.mapapi.map.OverlayOptions;
import com.baidu.mapapi.model.LatLng;

import java.util.ArrayList;

public class MainActivity extends AppCompatActivity {
    MapView mMapView = null;
    private BaiduMap baiduMap;
    private Marker marker;
    BitmapDescriptor bdA = BitmapDescriptorFactory.fromResource(R.drawable.icon_marka);
    BitmapDescriptor bdB = BitmapDescriptorFactory.fromResource(R.drawable.icon_markb);
    BitmapDescriptor bdC = BitmapDescriptorFactory.fromResource(R.drawable.icon_markc);

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        //在使用SDK各组件之前初始化context信息,传入ApplicationContext
        //注意该方法要再setContentView方法之前实现
        SDKInitializer.initialize(getApplicationContext());
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //获取地图控件引用
        mMapView = (MapView) findViewById(R.id.bmapView);
        baiduMap = mMapView.getMap();
        //可以有普通地图  卫星地图  空白地图三种样式
        //baiduMap.setMapType(BaiduMap.MAP_TYPE_NORMAL);//普通地图,也是默认地图、
        //空白地图  基础地图瓦片不会被渲染,在地图类型汇总设置为NONE,将不会使用流量下载基础地图的瓦片图层
      //  baiduMap.setMapType(BaiduMap.MAP_TYPE_NORMAL);
        baiduMap.setMapType(BaiduMap.MAP_TYPE_SATELLITE);//卫星地图
     //   baiduMap.setTrafficEnabled(true);//实时交通地图
      //  baiduMap.setBaiduHeatMapEnabled(true);//热力地图
        //-----------------------坐标--------------------------
        // 百度地图上展示覆盖物,需要使用的是BD09坐标
        //定义maker坐标点
        LatLng latLng = new LatLng(39.963175, 116.400244);//初始画时候的经纬度
        //构建Marker图标
        BitmapDescriptor bitmap = BitmapDescriptorFactory.fromResource(R.drawable.icon_gcoding);
        //构建markerOption ,用于在地图上添加Marker
        OverlayOptions options = new MarkerOptions()
                .position(latLng)//设置marker的位置
                .icon(bitmap)    //设置marker的图标
                .zIndex(9)       //设置marker所在的层级
                .draggable(true);//设置手势的拖拽
        //在地图上添加Marker
        marker = (Marker) baiduMap.addOverlay(options);
       //设置监听方法  注意拖拽的时候是长按拖拽
      baiduMap.setOnMarkerDragListener(new BaiduMap.OnMarkerDragListener() {
          @Override
          public void onMarkerDrag(Marker marker) {
              Toast.makeText(MainActivity.this, "拖拽了", Toast.LENGTH_SHORT).show();
              //拖拽中
          }

          @Override
          public void onMarkerDragEnd(Marker marker) {
             //拖拽结束
              LatLng position = marker.getPosition();
              double longitude = position.longitude;
              double latitude = position.latitude;
              Log.i("xxx",longitude+","+latitude);

          }

          @Override
          public void onMarkerDragStart(Marker marker) {
            //开始拖拽
          }
      });
        //3.3.0之后  SDK提供了给Marker增加动画的能力,具体实现:
        //通过marker的icon设置一组图片,实现帧动画  再通过period设置多少帧刷新一次图片资源
        ArrayList<BitmapDescriptor> giftList = new ArrayList<>();

        giftList.add(bdA);
        giftList.add(bdB);
        giftList.add(bdC);
        LatLng latLng2 = new LatLng(39.763175, 116.300244);//初始画时
        OverlayOptions ooD=new MarkerOptions().position(latLng2).icons(giftList)
                .zIndex(0).period(10);
        baiduMap.addOverlay(ooD);

        //实现Marker的点击
        baiduMap.setOnMarkerClickListener(new BaiduMap.OnMarkerClickListener() {
            @Override
            public boolean onMarkerClick(Marker marker) {
                //判断对应的Marker
                if (marker==marker){
                    Intent intent = new Intent(MainActivity.this, OtherActivity.class);
                    startActivity(intent);
                }
                return false;
            }
        });


    }
    @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();
    }
}

在资源文件中添加相关的图片
清单文件中:

<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
    <uses-permission android:name="android.permission.INTERNET"/>
    <uses-permission android:name="com.android.launcher.permission.READ_SETTINGS" />
    <uses-permission android:name="android.permission.WAKE_LOCK"/>
    <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.GET_TASKS" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
    <uses-permission android:name="android.permission.WRITE_SETTINGS" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"></uses-permission>
    <uses-permission android:name="android.permission.READ_PHONE_STATE"></uses-permission>
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
    <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"></uses-permission>
 <meta-data
            android:name="com.baidu.lbsapi.API_KEY"
            android:value="HfKDnEBT8GCu3P1NzW3Kt5IkYVuCgjsH" />
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值