1

我试图创建列表视图,但在方向改变时会遇到一些问题。问题是:当我改变屏幕列表视图的方向时,在列表中添加重复的列表项。如何限制此数据更改

代码是:

   public class DayPlannerActivity extends Activity {

    private TextView txtHeader;
    private Context mContext;
    private ListView lvDayplanner;
    private DayPlannerAdapter adapter;
    private Activity activity;
    private static Vector<DayPlanner> list = new Vector<DayPlanner>();
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.dayplanner);
        mContext = this;    
        activity = this;
        txtHeader = (TextView) findViewById(R.id.txtHeader);
        txtHeader.setText(R.string.haivlate);
        String[] Checks = {"select","Check1","Check2"};
        DayPlanner dp = new  DayPlanner("11:00 PM", Checks);
        list.add(dp);
        dp = new  DayPlanner("12:00 PM", Checks);
        list.add(dp);
        lvDayplanner = (ListView) findViewById(R.id.lvDayplanner);
        adapter= new DayPlannerAdapter(activity,list);
        lvDayplanner.setAdapter(adapter);
   }

}

列表适配器:

   public class DayPlannerAdapter extends BaseAdapter {

    private Activity mActivity;
    private static Vector<DayPlanner> list;
    private static LayoutInflater inflater;
    public DayPlannerAdapter ( Activity _activity,Vector<DayPlanner> _list) {
        mActivity = _activity;
        list = _list;
        inflater = (LayoutInflater)mActivity.getSystemService(mActivity.LAYOUT_INFLATER_SERVICE);
    }

    public static class ViewHolder{
        public TextView txtScheduledTime;
        public Spinner spnrChecks;
        public Button btnGo;
    }

    @Override
    public int getCount() {
        // TODO Auto-generated method stub
        return list.size();
    }

    @Override
    public Object getItem(int position) {
        // TODO Auto-generated method stub
        return position;
    }

    @Override
    public long getItemId(int position) {
        // TODO Auto-generated method stub
        return position;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        // TODO Auto-generated method stub

         View vi=convertView;
            ViewHolder holder;
            if(convertView==null){
                vi = inflater.inflate(R.layout.dayplanner_listitem, null);
                holder=new ViewHolder();
                holder.txtScheduledTime=(TextView)vi.findViewById(R.id.txtScheduledTime);
                holder.spnrChecks = (Spinner) vi.findViewById(R.id.spnrChecks);
                holder.btnGo = (Button) vi.findViewById(R.id.btnGo);
                vi.setTag(holder);
            }
            else
              holder=(ViewHolder)vi.getTag();

            holder.txtScheduledTime.setText(list.get(position).getScheduledTime());
            ArrayAdapter<String> spnrAdapter=new ArrayAdapter<String>(mActivity,
                    android.R.layout.simple_spinner_item, list.get(position).getChecks());
            spnrAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);   
            holder.spnrChecks.setAdapter(spnrAdapter);

            holder.btnGo.setOnClickListener(new OnClickListener() {

                @Override
                public void onClick(View v) {
                    // TODO Auto-generated method stub
                     Intent i = new Intent();
                     i.setClass(mActivity,DayPlannerFormActivity.class);
                     mActivity.startActivity(i);
                }
            });

        return vi;
    }

}
4

3 回答 3

3

由于 AndroidView会在方向更改时自动保存 s 状态,因此您需要一种方法来知道它是否不是第一次调用onCreate. 幸运的是,这很容易:覆盖onSaveInstanceState,甚至存储 1 个值,以使您的捆绑包onCreate不为空。

@Override
public void onSaveInstanceState(Bundle outInstanceState) {
    outInstanceState.putInt("value", 1);
}

然后,当重新创建活动时,参数in 不会savedInstanceStateonCreate空。因此,只需进行测试:

if(savedInstanceState != null)

在将数据添加到视图之前。

于 2012-01-20T13:36:34.950 回答
2

这是因为您的日程安排对象列表是静态的,因此当您更改视图的方向时,它会重新创建活动,但是由于在 java 中不会重新创建静态对象,而是为该类型保存,它使列表具有两个相同的对象。

于 2012-01-20T13:38:00.267 回答
0

这里的聚会太晚了,仍然会回答,因为它可能对其他人有用。我也遇到了同样的问题,它已被解决PROPERLY implementing the view holder design pattern

于 2015-05-17T09:41:31.113 回答