我试图使用简单的适配器将Sqlite数据库的内容放入listview。 我正在使用arraylist>获得所有的价值观。它会显示在列表视图中,但每次运行它时,值似乎都会重复。 我该怎么办? 这是我的代码
ArrayList<HashMap<String, String>>val=new ArrayList<HashMap<String,String>>();
Databasehandler db=new Databasehandler(this);
private ListView lv;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.contacts);
val=db.getAllContacts();
final ListView lv=(ListView)findViewById(R.id.listView1);
if(val.size()!=0)
{
ListAdapter ad=new SimpleAdapter(Contact.this,val,R.layout.v,new String[]{"contacts"},new int[]{R.id.textView2});
lv.setAdapter(ad);
}
答案 0 :(得分:1)
只需在onCreate方法之前声明ArrayList,如...
ArrayList<HashMap<String, String>>val = null;
如果要将检索到的值放入ArrayList中,请初始化此ArrayList,如...
val=new ArrayList<HashMap<String,String>>();
答案 1 :(得分:1)
我认为问题在于您的列表适配器(简单适配器)。请检查你的列表适配器的getView()是添加视图,只需检查你的适配器跟随...
只需使用此自定义适配器,
public class CustomAdapter extends BaseAdapter {
private List<SearchObjects> mObjects = null;
private LayoutInflater mInflater = null;
public CustomAdapter (Context context, List<SearchObjects> mData) {
mObjects = mData;
mInflater = LayoutInflater.from(context);
}
public int getCount() {
return mObjects.size();
}
public Object getItem(int position) {
return mObjects.get(position);
}
public long getItemId(int position) {
return position;
}
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if (convertView == null)
{
convertView = mInflater.inflate(R.layout.search_items_single_row,null);
holder = new ViewHolder();
holder.txtvName = (TextView) convertView.findViewById(R.id.txtvItemName);
convertView.setTag(holder);
}
else
holder = (ViewHolder) convertView.getTag();
holder.txtvName.setText(mObjects.get(position).getDL_TRADENAME());
return convertView;
}
private class ViewHolder {
TextView txtvName = null;
}
}
&安培;称之为,
mCustomListAdapter = new RxNewSearchDrugsListAdapter(getActivity(), mSearchObjects);
mListView.setAdapter(mCustomListAdapter );
答案 2 :(得分:0)
您是否检查了数据库。它是否有重复的值???
如果不是 - 只有在列表
中已存在值时才尝试在Arraylist中添加值for(each..str){
if(!myArrList.contains(str)){
myArrList.add(str);
}
修改强>
由于您在重新运行时遇到问题。请确保数据库不会重新填充具有保存值的行 OR
重新初始化你的arraylists .eg myArrList = new ArrayList<String>();