marker 设置资源图片比较简单,使用marker.setIcon(BitmapDescriptorFactory.fromResource("资源id")) 即可。
设置网络图片就比较麻烦了,高德并没有提供内置的加载网络图片的方法
解决思路:
1,将图片加载到ImageView中
2,通过ImageView获取Bitmap
3,使用BitmapDescriptorFactory.fromBitmap()方法将Bitmap设置进去
开始实现,写一个布局文件marker_layout,布局中用到了 开源库 CircleImageView
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical">
<de.hdodenhof.circleimageview.CircleImageView
android:id="@+id/iv_head"
android:layout_width="15dp"
android:layout_height="15dp" />
</LinearLayout>
初始化控件
View view = LayoutInflater.from(getApplicationContext()).inflate(R.layout.marker_layout, null)
CircleImageView iv_head = (CircleImageView) view.findViewById(R.id.iv_head)
使用glide加载网络图片
Glide.with( getApplicationContext())
.load("url")
.into( new GlideDrawableImageViewTarget(iv_head) {
@Override
public void onResourceReady(GlideDrawable drawable, GlideAnimation anim) {
super.onResourceReady(drawable, anim);
Bitmap bitmap = getViewBitmap(view);
mMoveMarker.setIcon(BitmapDescriptorFactory.fromBitmap(bitmap));
}
});
getViewBitmap(view)方法是获取Bitmap。
public Bitmap getViewBitmap(View view) {
view.setDrawingCacheEnabled(true)
view.measure(View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED),
View.MeasureSpec.makeMeasureSpec(0,View.MeasureSpec.UNSPECIFIED))
view.layout(0,0,view.getMeasuredWidth(),view.getMeasuredHeight())
view.buildDrawingCache()
return Bitmap.createBitmap(view.getDrawingCache())
}
以上就是marker显示网络图片,如有错误请指出,谢谢!