过年了,把电脑和其他设备带回家,继续做事。
今天做一个删除功能,用ListView展示从SQLite数据库中查出来的记录,然后删除其中几条之后,ListView中也要移除对应的View,以下是一开始的写法:
for(Sample sample : selectedSamples){
SampleManager.get(getActivity()).deleteSample(Long.parseLong(sample.getId()));
for(View view : selectedViews){
lv.removeView(view);
也就是说,在数据库中删除一条记录之后,紧跟着直接用ListView的remove() 方法删掉对应的View,但是这样报错:
java.lang.UnsupportedOperationException: removeView(View) is not supported in AdapterView
说明不能直接用ListView的remove()方法。于是网上查了查,找到了新的方法,而且也更合理:
for(Sample sample : selectedSamples){
SampleManager.get(getActivity()).deleteSample(Long.parseLong(sample.getId()));
((SampleCursor)adapter.getCursor()).requery();
adapter.notifyDataSetChanged();
lv.setAdapter(adapter);
也就是说:
1. 对应的cursor要重新查询一边,
2. 然后适配器adapter调用notifiyDataSetChanged()方法,
3. 最后重新设置一下ListView的adapter
过年了,把电脑和其他设备带回家,继续做事。今天做一个删除功能,用ListView展示从SQLite数据库中查出来的记录,然后删除其中几条之后,ListView中也要移除对应的View,以下是一开始的写法:for(Sample sample : selectedSamples){ SampleManager.get(getActivity()).deleteSample(Long.pars
//参数2 是展现方式,参照http://developer.android.com/reference/android/R.layout.html
//参数3 是定义的数组
setListAdapter(new ArrayAdapt
android开发中我们经常会遇到listView列表中删除某一条item的需求,下面是我总结的几种实现方法:
1.第一种是从listView的最大长度开始依次递减的for循环,当遇到满足条件的item后直接调用 mOldRelation.remove(position);的方法将其移除;
private List mOldRelation=new ArrayList
.....
在最近做的一个项目中对List进行操作时报错java.lang.UnsupportedOperationException,后来发现操作的List是由数组转换而成的,通过看源码发现问题,并写测试程序如下。
public class Unsupported {
static void test(String msg, List<String> list) {
今天做项目遇到了一个问题,从Activity B返回到Activity A时数据已经更新了,但是Activity A显示的依然是老数据(数据条目从2条变成1条的时候)。
我意识到是UI的问题,想调用
listView的removeAllView方法,结果App就爆掉了。
看了下源码,原来removeAllView里写的是这样:
原文链接AdapterView 的子类 比如ListView 不能在layout中添加 子布局,或者在 代码中添加子布局。<ListView // .. other attributes>
<// other views <-- notice the children of the ListView tag
</ListView>这种布局方式,是会报错的。正确做法:<ListView /
要在Android ListView中显示图片,可以使用自定义适配器来实现。以下是实现步骤:
1. 在ListView的布局文件中添加一个ImageView控件,用于显示图片。
2. 创建一个自定义适配器,继承自BaseAdapter类。
3. 在适配器的getView()方法中,获取当前项的数据,并将图片加载到ImageView控件中。
4. 在MainActivity中,将适配器设置给ListView。
5. 准备好图片资源,可以将图片放在drawable文件夹中,或者从网络上获取。
6. 运行程序,即可看到ListView中显示了图片。
具体实现细节可以参考以下代码:
1. ListView布局文件中添加ImageView控件
<ImageView
android:id="@+id/imageView"
android:layout_width="50dp"
android:layout_height="50dp"
android:layout_marginLeft="10dp"
android:layout_marginTop="10dp"
android:layout_marginBottom="10dp"
android:scaleType="centerCrop" />
2. 自定义适配器
public class MyAdapter extends BaseAdapter {
private Context mContext;
private List<Item> mItemList;
public MyAdapter(Context context, List<Item> itemList) {
mContext = context;
mItemList = itemList;
@Override
public int getCount() {
return mItemList.size();
@Override
public Object getItem(int position) {
return mItemList.get(position);
@Override
public long getItemId(int position) {
return position;
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if (convertView == null) {
convertView = LayoutInflater.from(mContext).inflate(R.layout.list_item, parent, false);
holder = new ViewHolder();
holder.imageView = convertView.findViewById(R.id.imageView);
holder.textView = convertView.findViewById(R.id.textView);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
Item item = mItemList.get(position);
holder.textView.setText(item.getName());
// 加载图片
Glide.with(mContext)
.load(item.getImageUrl())
.into(holder.imageView);
return convertView;
private static class ViewHolder {
ImageView imageView;
TextView textView;
3. MainActivity中设置适配器
public class MainActivity extends AppCompatActivity {
private ListView mListView;
private MyAdapter mAdapter;
private List<Item> mItemList;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mListView = findViewById(R.id.listView);
// 准备数据
mItemList = new ArrayList<>();
mItemList.add(new Item("item1", R.drawable.image1));
mItemList.add(new Item("item2", R.drawable.image2));
mItemList.add(new Item("item3", R.drawable.image3));
mItemList.add(new Item("item4", R.drawable.image4));
mItemList.add(new Item("item5", R.drawable.image5));
// 创建适配器
mAdapter = new MyAdapter(this, mItemList);
// 设置适配器
mListView.setAdapter(mAdapter);
4. Item类
public class Item {
private String mName;
private int mImageResId;
private String mImageUrl;
public Item(String name, int imageResId) {
mName = name;
mImageResId = imageResId;
public Item(String name, String imageUrl) {
mName = name;
mImageUrl = imageUrl;
public String getName() {
return mName;
public int getImageResId() {
return mImageResId;
public String getImageUrl() {
return mImageUrl;
以上代码使用了Glide库来加载图片,需要在build.gradle文件中添加以下依赖:
implementation 'com.github.bumptech.glide:glide:4.12.'
annotationProcessor 'com.github.bumptech.glide:compiler:4.12.'