关于百度地图点聚合自定义布局

2020-10-27  本文已影响0人  安卓_背包客
        val mLayoutInflater = LayoutInflater.from(mContext)
        val inflate = mLayoutInflater.inflate(R.layout.item_baidu_marker, null)

自定义布局中使用LinearLayout 中 android:layout_height 只能使用“wrap_content”
然后BitmapDescriptorFactory.fromView(inflate) 才能使用
下面是百度demo 中抽出的工具类名字,


image.png

把这些类抽出就可以使用
至于显示聚合数需要修改“DefaultClusterRenderer”这个类的常量

//显示聚合常量
    private static final int[] BUCKETS = {2,3,4,5,6,7,8,9,10, 20, 50, 100, 200, 500, 1000};
//多少开始显示聚合  
  private static final int MIN_CLUSTER_SIZE = 2;


    /**
     * Determine whether the cluster should be rendered as individual markers or a cluster.
     */
    protected boolean shouldRenderAsCluster(Cluster<T> cluster) {
        return cluster.getSize() >=MIN_CLUSTER_SIZE;
    }

至于使用方式

//初始化点聚合管理类
mClusterManager = new ClusterManager<MyItem>(this, mBaiduMap);

//ClusterItem接口的实现类
public class MyItem implements ClusterItem {
    LatLng mPosition;
    public MyItem(LatLng position) {
        mPosition = position;
    }
    @Override
    public LatLng getPosition() {
        return mPosition;
    }
    @Override
    public BitmapDescriptor getBitmapDescriptor() {
        return BitmapDescriptorFactory
                .fromResource(R.drawable.icon_gcoding);
    }
}
// 添加Marker点
LatLng llA = new LatLng(39.963175, 116.400244);
LatLng llB = new LatLng(39.942821, 116.369199);
List<MyItem> items = new ArrayList<MyItem>();
items.add(new MyItem(llA));
items.add(new MyItem(llB));
mClusterManager.addItems(items);

我的demo 使用

public class MarkerClusterItem : ClusterItem {
    private var mTitle: String? = null
    private var mPositon: LatLng? = null
    private var mContext: Context? = null

    constructor(
        mContext: Context,
        mTitle: String?,
        mPositon: LatLng?) {
        this.mTitle = mTitle
        this.mPositon = mPositon
        this.mContext = mContext }
    override fun getPosition(): LatLng {
        return mPositon!!
    }

    override fun getBitmapDescriptor(): BitmapDescriptor {
        val mLayoutInflater = LayoutInflater.from(mContext)
        val inflate = mLayoutInflater.inflate(R.layout.item_baidu_marker, null)
        val mTv = inflate.findViewById<TextView>(R.id.tv_item_baidu_marker_title)
        val mIv = inflate.findViewById<ImageView>(R.id.iv_item_baidu_marker_logo)
      //todo do you String
        return BitmapDescriptorFactory.fromView(inflate)
    }
}




   mMapStatus = MapStatus.Builder().target(getLatlngContent(mLatlng)).zoom(15f).build()
        mClusterManger = ClusterManager(this, mBaiDuMap)
 addMarker()
        mClusterManger?.addItems(mListMarkerLatlng)
        mBaiDuMap?.setOnMapLoadedCallback(this)
        mBaiDuMap?.animateMapStatus(MapStatusUpdateFactory.newMapStatus(mMapStatus))
        mBaiDuMap?.apply {
            setOnMapStatusChangeListener(mClusterManger)
            setOnMarkerClickListener(mClusterManger)
        }
        mClusterManger?.apply {
            setOnClusterClickListener {                   
                false
            }
            setOnClusterItemClickListener {
          
                    T.showToast(this@OrderSelectionMapActivity, "内容为空")
                val movePoint = LatLng(it.position.latitude, it.position.longitude)
                mBaiDuMap?.animateMapStatus(
                    MapStatusUpdateFactory.newLatLngZoom(movePoint, 20f)
                false
            }
        }

聚点刷新
          addMarker()
            mClusterManger?.apply {
                addItems(mListMarkerLatlng)
                cluster()
            }
      
上一篇下一篇

猜你喜欢

热点阅读