나는 listview
에서 인터넷에서 이미지를 다운로드하고 표시하려면 Volley NetworkImageView
을 사용합니다. 이제 사용할 수있는 네트워크가 없을 때 Volley NetworkImageView
에 저장된 이미지를 표시하려고합니다. 내가Volley NetworkImageView를 오프라인으로 만드는 법
Entry entry = SingletonRequestQueue.getInstance(context).getRequestQueue().getCache().get(imageURL);
entry.data
가 null가 아닌 사용하는 경우 때문에 Volley
이미 키로 URL
에 의해 이미지를 캐시합니다. 하지만 내 문제는 그 이미지 해상도가 높은하고 지연을 많이 만들기 때문에 내가
Bitmap b = BitmapFactory.decodeByteArray(entry.data, 0, entry.data.length);
을 사용할 수 없습니다 나는 다시 내가 디코딩을 취소 스크롤 때 listview
asynctask
볼 작성해야하기 때문에 바퀴를 재발견 할 필요가있다
Volley NetworkImageView
더 네트워크가 없을 때를 보여주기 위해 자신의 DiskLRUCache을 사용할 수 있도록 몇 가지 트릭을 할 수 있습니다 ... 최고의 insample 가치를 발견하고, 메모리 캐시에 창조하는
bitmap
재활용.
아이디어가 있으십니까?
내 코드 :
public class SingletonRequestQueue {
private static SingletonRequestQueue mInstance;
private RequestQueue mRequestQueue;
private ImageLoader mImageLoader;
private static Context mCtx;
private LruBitmapCache mLruBitmapCache;
private SingletonRequestQueue(Context context) {
mCtx = context;
mRequestQueue = getRequestQueue();
mLruBitmapCache = new LruBitmapCache(LruBitmapCache.getCacheSize(context));
mImageLoader = new ImageLoader(mRequestQueue,mLruBitmapCache);
}
public static synchronized SingletonRequestQueue getInstance(Context context) {
if (mInstance == null) {
mInstance = new SingletonRequestQueue(context);
}
return mInstance;
}
public RequestQueue getRequestQueue() {
if (mRequestQueue == null) {
// getApplicationContext() is key, it keeps you from leaking the
// Activity or BroadcastReceiver if someone passes one in.
mRequestQueue = Volley.newRequestQueue(mCtx.getApplicationContext(),new OkHttpStack());
// mRequestQueue = Volley.newRequestQueue(mCtx.getApplicationContext());
}
return mRequestQueue;
}
public <T> void addToRequestQueue(Request<T> req) {
getRequestQueue().add(req);
}
public ImageLoader getImageLoader() {
return mImageLoader;
}
public LruBitmapCache getLruBitmapCache() {
return mLruBitmapCache;
}
public void setLruBitmapCache(LruBitmapCache lruBitmapCache) {
mLruBitmapCache = lruBitmapCache;
}
}
내 어댑터 : 나는 DiskLRUCache
및 Volley
을 사용하여 프로젝트를 만든
public IssueListAdapter(Context context, int resource, List<Issue> objects) {
super(context, resource, objects);
this.context = context;
this.mIssueList = objects;
mImageLoader = SingletonRequestQueue.getInstance(context).getImageLoader();
}
public static class ViewHolder{
public NetworkImageView mNetworkImageView;
public TextView mFee;
public TextView mName;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if(convertView == null){
holder = new ViewHolder();
LayoutInflater inflater =
(LayoutInflater) context.getSystemService(Activity.LAYOUT_INFLATER_SERVICE);
convertView = inflater.inflate(R.layout.gridview_issuelist_item, parent, false);
holder.mNetworkImageView = (NetworkImageView)convertView.findViewById(R.id.NetworkImageView_MainActivity_issue_image);
holder.mName = (TextView)convertView.findViewById(R.id.TextView_MainActivity_name);
holder.mFee = (TextView)convertView.findViewById(R.id.TextView_MainActivity_fee);
Utility.settingTypfaceFont(context, holder.mName);
Utility.settingTypfaceFont(context, holder.mFee);
convertView.setTag(holder);
}else{
holder = (ViewHolder)(convertView.getTag());
}
final Issue issue = mIssueList.get(position);
holder.mName.setText(issue.getTitle());
holder.mFee.setText(String.valueOf(issue.getFee()));
String imageURL = issue.getPublicCover();
holder.mNetworkImageView.setImageUrl(imageURL, mImageLoader);
holder.mNetworkImageView.setDefaultImageResId(R.drawable.placeholder2);;
/*
Entry entry = SingletonRequestQueue.getInstance(context).getRequestQueue().getCache().get(imageURL);
if(entry != null && entry.data != null){
byte[] imageByte = entry.data;
loadBitmap(imageByte, holder.mNetworkImageView,imageURL);
}else{
holder.mNetworkImageView.setImageUrl(imageURL, mImageLoader);
}*/
return convertView;
}
@Override
public int getCount() {
if(mIssueList != null){
return mIssueList.size();
}
else{
return 0;
}
}
public List<Issue> getIssueList() {
return mIssueList;
}
}
' NetworkImageView'는 개발자가 만든 메모리 캐시와 Volley 자체에서 만든 디스크 캐시의 2 단계 캐시를 사용합니다. 이미지가 메모리 캐시에서 먼저 체크 된 다음 디스크 캐시가 발견되지 않으면 네트워크 요청 만 배치됩니다. 따라서 오프라인 모드에서 작동하게하려면 추가 작업이 필요 없습니다. 문제가 있는지 코드를 공유 할 수 있습니까? –
@ManishMulimani 귀하의 도움에 많은 감사드립니다, 내 질문을 업데이 트했습니다. 문제는 내가 애플 리케이션을 닫고 이미지의 자리 표시 자만 다시 열면 이미지 아래의 텍스트가 모두 제대로로드되지만 이미지는 그렇지 않다는 것입니다. 감사합니다. – mmlooloo
ImageLoader가 이미 getRequestQueue(). getCache()와 같지 않은 캐시를 체크 한 다음 ImageLoader를 다시 구현하면 Context 멤버를 추가하고 캐시 된 이미지를 확인하면 ImageLoader는 이미 isCached (String requestUrl, int maxWidth, int maxHeight) 귀하의 질문에 첫 번째 줄을 사용하십시오. src code ImageLoader : https://android.googlesource.com/platform/frameworks/volley/+/master/src/com/android/volley/toolbox/ImageLoader.java – Yazan