Android----高德地图多个Marker加载网络图片出现图片不显示问题

需求说要地图上展示的是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

猜你喜欢

转载自blog.csdn.net/qq_25749749/article/details/80585313