【发布时间】:2016-05-08 14:03:35
【问题描述】:
我有一个列表视图,每一行都是关于从 url 加载的文本和图像。
在第一次加载视图时,前 3 行被渲染并填充了文本,需要几秒钟才能在另一个线程中加载图像。
当我向下滚动时,新行也出现没有图像并加载它,但是当我向上滚动时,我发现之前上传的图像已经消失,只有文本存在并再次重新加载图像。
我想加载一次图像,当我向上和向下滚动图像时,一旦加载一次就不会重新加载。
这是我的代码:
public class MainActivity extends AppCompatActivity {
ListViewCountries listViewCountries =new ListViewCountries();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
listViewCountries.FillCountriesList();
setContentView(R.layout.activity_main);
CountryAdapter adapter=new CountryAdapter();
ListView lst=(ListView)findViewById(R.id.listView);
lst.setAdapter(adapter);
}
class CountryAdapter extends BaseAdapter {
@Override
public int getCount() {
return listViewCountries.Count;
}
@Override
public Object getItem(int position) {
return listViewCountries.Countries.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
List<Country> items = listViewCountries.Countries;
LayoutInflater inflater = getLayoutInflater();
View rowView = inflater.inflate(R.layout.row_cell, null);
ImageView img = (ImageView) rowView.findViewById(R.id.flagImg);
new DownloadImageTask(img).execute(items.get(position).FlagURL);
TextView name = (TextView) rowView.findViewById(R.id.countryName);
TextView description = (TextView) rowView.findViewById(R.id.shortText);
name.setText(items.get(position).Name);
description.setText(items.get(position).ShortDescription);
return rowView;
}
}
private class DownloadImageTask extends AsyncTask<String, Void, Bitmap> {
ImageView bmImage;
public DownloadImageTask(ImageView bmImage) {
this.bmImage = bmImage;
}
protected Bitmap doInBackground(String... urls) {
String urldisplay = urls[0];
Bitmap mIcon11 = null;
try {
InputStream in = new java.net.URL(urldisplay).openStream();
mIcon11 = BitmapFactory.decodeStream(in);
} catch (Exception e) {
Log.e("Error", e.getMessage());
e.printStackTrace();
}
return mIcon11;
}
protected void onPostExecute(Bitmap result) {
this.bmImage.setImageBitmap(result);
}
}
【问题讨论】:
-
答案在这篇文章中Answer Here