需求说要地图上展示的是mark,不是infowindow,加载出网络图片,由于app的marker比较多,没有达到需要的效果。
看了看高德地图api中有这个方法
markerOption.icon(BitmapDescriptorFactory.fromBitmap(BitmapFactory.decodeResource(getResources(),R.drawable.location_marker)));
fromBitmap里面的参数也可以是bitmap,于是可以自定义一个View把这个view转成bitmap。
这是做好所有工作以后,发现有的图片能显示出来,有的显示不出来。
由于加载图片的时候是异步的,有时候会在图片还没有加载完成的时候,view已经被转成bitmap,而这时Glide还在加载图片图,当glide加载工作完成时,要把图片展示在imageView上时,发现已经找不到这个imageView的id了,因此导致有些marker显示不出来图片。
于是我就添加了一个Glide图片加载完成的监听,在Glide图片加载完成之时再去把View转成bitmap,如下代码所示
Glide.with(this).load(list.get(i).getGasLogoSmall()). placeholder(R.mipmap.gas_small_logo) .transform(new GlideCircleTransform(getActivity())) .error(R.mipmap.gas_small_logo) // .listener(new RequestListener<String, GlideDrawable>() { // @Override // public boolean onException(Exception e, String model, Target<GlideDrawable> target, boolean isFirstResource) { // // return false; // } // // @Override // public boolean onResourceReady(GlideDrawable resource, String model, Target<GlideDrawable> target, boolean isFromMemoryCache, boolean isFirstResource) { Bitmap bitmap = convertViewToBitmap(view); // markerOption = new MarkerOptions().icon(BitmapDescriptorFactory.fromBitmap(bitmap)).... // aMap.addMarker(markerOption); // return false; // } // }) .into(imageView)
代码写完之后调试,发现还是不行,有的图片还是展示不出来,于是又苦思冥想,查找资料,发现自己错了,Glide在调用into方法的时候才去展示的图片,而RequestListener只表示图片加载的结果,这时并未在imageView 上展示,当还没有显示图片的imageView时候转bitmap,当然在marker上也显示不出来,是我对Glide框架了解的不够深,其实into()方法里不只可以填充imageView,还可以放SimpleTarget.于是又这样写了一下
Glide.with(this).load(list.get(i).getGasLogoSmall()). placeholder(R.mipmap.gas_small_logo) .transform(new GlideCircleTransform(getActivity())) .error(R.mipmap.gas_small_logo) .into(new SimpleTarget<GlideDrawable>() { @Override public void onResourceReady(GlideDrawable resource, GlideAnimation<? super GlideDrawable> glideAnimation) { //展示图片 imageView.setImageDrawable(resource); textView.setText(list.get(I).getGasName() + ""); Bitmap bitmap = convertViewToBitmap(view); markerOption = new MarkerOptions().icon(BitmapDescriptorFactory.fromBitmap(bitmap)) .position..; aMap.addMarker(markerOption); } });
就这样,在显示图片之后把View转bitmap,都完美的显示在了marker上
BitmapDescriptorFactory.fromView(view)即使这样还是有的图片加载不出来,查看fromView源码,其实内里也是把view转成了Bitmap