添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
相关文章推荐
仗义的登山鞋  ·  SparkSql ...·  1 年前    · 

过年了,把电脑和其他设备带回家,继续做事。

今天做一个删除功能,用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.'