2016-07-25 73 views
3

我有一个回收站视图,它正在使用通用图像加载程序进行填充。Recycler查看Scroll上的随机图像

@Override 
public MasonryView onCreateViewHolder(ViewGroup parent, int viewType) { 
    View layoutView = LayoutInflater.from(parent.getContext()).inflate(R.layout.grid_item, parent, false); 
    MasonryView masonryView = new MasonryView(layoutView); 
    //layoutView.setOnClickListener(new MyOnClickListener()); 
    //imageLoader.destroy(); 
    imageLoader.init(ImageLoaderConfiguration.createDefault(context)); 
    options = new DisplayImageOptions.Builder() 
      .cacheInMemory(true) 
      .resetViewBeforeLoading(true) 
      .cacheOnDisk(true) 
      .considerExifParams(false) 
      .bitmapConfig(Bitmap.Config.RGB_565) 
      .build(); 

    return masonryView; 
} 

@Override 
public void onBindViewHolder(final MasonryView holder, int position) { 

    imageLoader 
      .displayImage(IMAGE_URLS[position], holder.imageView, options, new SimpleImageLoadingListener() { 
       @Override 
       public void onLoadingStarted(String imageUri, View view) { 
        holder.donut_progress.setVisibility(View.VISIBLE); 
        holder.donut_progress.setProgress(0); 
       } 

       @Override 
       public void onLoadingFailed(String imageUri, View view, FailReason failReason) { 

        holder.onLoadImage.setVisibility(View.GONE); 
       } 

       @Override 
       public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) { 
        holder.onLoadImage.setVisibility(View.GONE); 
        holder.donut_progress.setVisibility(View.GONE); 
       } 
      }, new ImageLoadingProgressListener() { 
       @Override 
       public void onProgressUpdate(String imageUri, View view, int current, int total) { 
        holder.donut_progress.setProgress(Math.round(100.0f * current/total)); 
       } 
      }); 


} 

正如您所看到的imageloader和DisplayOptions在CreateView中定义的。

图像显示成功,但在滚动图像时正在洗牌。

以下是我对custom_recycler_grid_item XML

<?xml version="1.0" encoding="utf-8"?> 
<FrameLayout 
xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:tools="http://schemas.android.com/tools" 
xmlns:custom="http://schemas.android.com/apk/res-auto" 
android:layout_width="wrap_content" 
android:layout_height="wrap_content" 
android:background="#00000000" 
android:orientation="vertical"> 

    <ImageView 
     android:id="@+id/img" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:adjustViewBounds="true"/> 
    !-- android:scaleType="centerCrop" --! 


    <ImageView 
     android:id="@+id/onLoadImage" 
     android:layout_width="50dp" 
     android:layout_height="50dp" 
     android:src="@drawable/camera_cross" 
     android:layout_marginLeft="50dp" 
     android:layout_marginTop="50dp" 
     android:visibility="gone"/> 

    <progressIndicators.DonutProgress 
     android:layout_marginLeft="50dp" 
     android:layout_marginTop="50dp" 
     android:id="@+id/donut_progress" 
     android:layout_width="50dp" 
     android:layout_height="50dp" 
     custom:donut_unfinished_stroke_width="1dp" 
     custom:donut_finished_stroke_width="1dp" 
     custom:donut_progress="50"/> 

</FrameLayout> 

我的主要碎片,具有recyclerView

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout 
xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:app="http://schemas.android.com/apk/res-auto" 
android:orientation="vertical" android:layout_width="match_parent" 
android:layout_height="match_parent"> 

<android.support.v7.widget.RecyclerView 
    android:id="@+id/masonry_grid" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:layout_weight="0.1" 
    app:layout_behavior="@string/appbar_scrolling_view_behavior" /> 


</LinearLayout> 

不过,我还设置 adapter.setHasStableIds(真);

+0

安置自己的XML代码 – vinoth12594

+0

好吧进出口张贴我custom_item.xml –

+0

您添加了android:滚动条=“垂直”在你的回收站视图 – vinoth12594

回答

2

我完全解决了这个问题。

问题出在我的RecyclerWidget高度和宽度。

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout 
xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:app="http://schemas.android.com/apk/res-auto" 
android:orientation="vertical" android:layout_width="match_parent" 
android:layout_height="match_parent"> 

<android.support.v7.widget.RecyclerView 
    android:id="@+id/masonry_grid" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_weight="0.1" 
    app:layout_behavior="@string/appbar_scrolling_view_behavior" /> 


</LinearLayout> 

我不得不设置我的高度和宽度来包装内容。

0

通用图像加载程序异步任务操作。在通用图像加载器中,他们使用了OkHTTP客户端服务器操作。这就是你的图像混洗的原因。尝试使用Glide加载图像,这是更好的方法。并且通过这个例子here

简单,快捷的方式来加载图像。 (itemView.getContext())。load(Datas.getRequestURL())。centerCrop()。into(mStaticMap);

+0

问题不在布局中。 –

+0

我马上试试 –

+0

结果甚至更糟。 –

0

显示占位符,直到原始图像加载,同样的问题也发生在我的情况,所以我遵循这种方法。

为此在您的发射器(前)活动

//定制的显示选项

DisplayImageOptions options = new DisplayImageOptions.Builder() 
     .showImageOnFail(R.drawable.placeholder_steve) 
     .showImageForEmptyUri(R.drawable.placeholder_steve) 
     .showImageOnLoading(R.drawable.placeholder_steve) 
     .bitmapConfig(Bitmap.Config.RGB_565) 
     .considerExifParams(true) 
     .cacheInMemory(true) 
     .cacheOnDisk(true) 
     .build(); 

//配置

ImageLoaderConfiguration config = new ImageLoaderConfiguration.Builder(getApplicationContext()) 
     .defaultDisplayImageOptions(options) 
     /*.diskCache(lruDiskCache)*/ 
     .build(); 
ImageLoader.getInstance().init(config); 
+0

我有一个圆形的进展,直到图像成功加载 –

+0

@Abdul Ahad我没有尝试过循环进度,但没有进展它的工作原理。 –

+0

最初设置带有可绘制图像的位图,直到原始图像加载。最终的位图thumbBitmap = BitmapFactory.decodeResource(context.getResources(),R.drawable.placeholder_steve); –

0

问题是与

holder.onLoadImage.setVisibility(View.GONE);

你必须谨慎,你如何设置可见性消失,然后使其可见。最后,它是显示可见性并未显示的相同查看者。如果你确保

holder.onLoadImage.setVisibility(View.VISIBLE)

在onBindHolder的开头()。你应该罚款