Issue with ViewHolder selection

387 views Asked by At

I am working in an app in which I handle a ListView which is composite with ViewHolder. In this ViewHolder, I have a CheckBox. Here is my code:

private class SettingsArrayAdapter extends ArrayAdapter<Object> {

    Context context;
    ArrayList<Object> values;

    RowSettingsViewHolder vh = null;
    BigRowSettingsViewHolder bvh = null;

    @Override
    public int getItemViewType(int position) {
        if (values.get(position) instanceof RowContent) {
            return SMALL_ROW_DESIGN;
        } else
            return BIG_ROW_DESIGN;
        // return super.getItemViewType(position);
    }

    @Override
    public int getViewTypeCount() {
        return 2;
    }

    public SettingsArrayAdapter(Context context, ArrayList<Object> values) {
        super(context, R.layout.row_settings, values);
        this.context = context;
        this.values = values;
    }

    // disable selection in title row
    @Override
    public boolean isEnabled(int position) {

        return (position == 2 || position == 4 || position == 8 || position == 9 || position == 13) ? false : true;
    }

    public View getView(int position, View convertView, ViewGroup parent) {

        vh = null;
        bvh = null;
        String sharedPrefKey;
        // Log.i("VH", "vh tag: " +vh.toString());
        int type = getItemViewType(position);

        // big row excluded
        if (type == SMALL_ROW_DESIGN) {
            if (convertView == null) {
                LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
                convertView = inflater.inflate(R.layout.row_settings, parent, false);
                vh = new RowSettingsViewHolder();
                vh.titleTV = (TextView) convertView.findViewById(R.id.settings_row_title);
                vh.subtitleTV = (TextView) convertView.findViewById(R.id.settings_row_subtitle);
                vh.disclosureIV = (ImageView) convertView.findViewById(R.id.settings_disclosureIV);
                vh.checkCB = (CheckBox) convertView.findViewById(R.id.settings_cB);
                vh.separatorLine = (View) convertView.findViewById(R.id.settings_listView_separatorLine);

                int id = Resources.getSystem().getIdentifier("btn_check_holo_light", "drawable", "android");
                if (id != 0)
                    vh.checkCB.setButtonDrawable(id);

                Typeface tf = Typeface.createFromAsset(getActivity().getAssets(), "fonts/Decima Light.otf");
                vh.titleTV.setTypeface(tf);

                convertView.setTag(vh);

                Log.i("VH", "vh tag: " + vh.toString());

            } else {
                vh = (RowSettingsViewHolder) convertView.getTag();
                vh.checkCB.setOnCheckedChangeListener(null);
            }
            vh.checkCB.setFocusable(false);
            RowContent thisSetting = null;
            thisSetting = (RowContent) values.get(position);

            // set row values in view
            vh.titleTV.setText(thisSetting.getTitle());
            vh.disclosureIV.setImageDrawable(thisSetting.getDisclosureDrawable());

            // subtitle
            vh.subtitleTV.setText(thisSetting.getSubtitle());
            String title = vh.titleTV.getText().toString();
            String subtitle = vh.subtitleTV.getText().toString();
            if (subtitle.equals("NOTIFICATIONS") || subtitle.equals("MUSIC") || subtitle.equals("EMAIL") || subtitle.equals("SYSTEM")) {
                Typeface tfSubt = Typeface.createFromAsset(getActivity().getAssets(), "fonts/Decima Bold.otf");
                vh.subtitleTV.setTypeface(tfSubt);
                vh.separatorLine.setBackgroundColor(Color.BLACK);
            } else {
                Typeface tf = Typeface.createFromAsset(getActivity().getAssets(), "fonts/Decima Light.otf");
                vh.subtitleTV.setTypeface(tf);
                vh.separatorLine.setBackgroundColor(Color.LTGRAY);
            }

            // checkbox
            if (!thisSetting.needsCheckBox()) {
                vh.checkCB.setVisibility(View.INVISIBLE);
                vh.checkCB.setOnClickListener(null);
            } else {
                vh.checkCB.setVisibility(View.VISIBLE);

                if (title.equals(getResources().getString(R.string.Spotify))) {
                    vh.checkCB.setChecked(sharedPreferencesHandler_settings.isSpotifyActive());
                    sharedPrefKey = SharedPrefsHandler.spotifyKey;
                    vh.checkCB.setTag(sharedPrefKey);
                } else if (title.equals(getResources().getString(R.string.Google_Play))) {
                    vh.checkCB.setChecked(sharedPreferencesHandler_settings.isGooglePlayerActive());
                    sharedPrefKey = SharedPrefsHandler.googlePlayerKey;
                    vh.checkCB.setTag(sharedPrefKey);
                } else if (title.equals(getResources().getString(R.string.default_music_player))) {
                    vh.checkCB.setChecked(sharedPreferencesHandler_settings.isDefaultPlayerActive());
                    sharedPrefKey = SharedPrefsHandler.defaulPlayerKey;
                    vh.checkCB.setTag(sharedPrefKey);
                } else if (title.equals(getResources().getString(R.string.default_mail))) {
                    vh.checkCB.setChecked(sharedPreferencesHandler_settings.isDefaultEmailAppActive());
                    sharedPrefKey = SharedPrefsHandler.defaultEmailKey;
                    vh.checkCB.setTag(sharedPrefKey);
                } else if (title.equals(getResources().getString(R.string.Hotmail))) {
                    vh.checkCB.setChecked(sharedPreferencesHandler_settings.isHotmailActive());
                    sharedPrefKey = SharedPrefsHandler.hotmailKey;
                    vh.checkCB.setTag(sharedPrefKey);
                } else if (title.equals(getResources().getString(R.string.Gmail))) {
                    vh.checkCB.setChecked(sharedPreferencesHandler_settings.isGmailActive());
                    sharedPrefKey = SharedPrefsHandler.gmailKey;
                    vh.checkCB.setTag(sharedPrefKey);
                } else if (title.equals(getResources().getString(R.string.enable_disable_all_notif))) {
                    vh.checkCB.setChecked(sharedPreferencesHandler_settings.areAllNotifsActive());
                    sharedPrefKey = SharedPrefsHandler.allNotifsActiveKey;
                    vh.checkCB.setTag(sharedPrefKey);
                }

                vh.checkCB.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {

                    @Override
                    public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
                        // TODO Auto-generated method stub
                        // Log.i("TabSettingsActivity", "checked");
                        Log.i("VH-2", "vh tag: " + vh.toString());
                        sharedPreferencesHandler_settings.setSettingActive(SharedPrefsHandler.allNotifsActiveKey, vh.checkCB.isChecked());
                        Log.i("TabSettingsActivity", "checked: " + Boolean.toString(isChecked));
                        // Log.i("isChecked", vh.checkCB.getTag().toString());
                        Log.i("TabSettingsActivity", "vh tag: " + vh.checkCB.getTag().toString());
                        sharedPreferencesHandler_settings.setSettingActive(vh.checkCB.getTag().toString(), isChecked);
                        // Do something here.
                        Log.i("VH-ID", "vh tag: " + vh.toString());
                    }
                });

            }
        }

        // big row
        else {

            if (convertView == null) {
                LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
                convertView = inflater.inflate(R.layout.row_settings_big, parent, false);
                bvh = new BigRowSettingsViewHolder(convertView);

                convertView.setTag(bvh);
            }

            else {
                bvh = (BigRowSettingsViewHolder) convertView.getTag();
            }
            bvh.setRowData();
        }

        return convertView;
    }
}

What I am doing is stored in SharedPreferences the ViewHolder item values. When I put the tic in any CheckBox it seems that everything is ok, but if I use the scroll, the tick disappears, then I have been investigating and I did the next:

I put this line:

Log.i("VH-ID", "vh tag: " +vh.toString());

When it is creating the ViewHolder, like this I can get the ID of each ViewHolder, also I added the same line as above inside the listener method:

vh.checkCB.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
    @Override
    public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
        // TODO Auto-generated method stub
        // Log.i("TabSettingsActivity", "checked");
        Log.i("VH-2", "vh tag: " + vh.toString());
        sharedPreferencesHandler_settings.setSettingActive(SharedPrefsHandler.allNotifsActiveKey, vh.checkCB.isChecked());
        Log.i("TabSettingsActivity", "checked: " + Boolean.toString(isChecked));
        // Log.i("isChecked", vh.checkCB.getTag().toString());
        Log.i("TabSettingsActivity", "vh tag: " + vh.checkCB.getTag().toString());
        sharedPreferencesHandler_settings.setSettingActive(vh.checkCB.getTag().toString(), isChecked);
        // Do something here.
        Log.i("VH-ID", "vh tag: " + vh.toString());
    }
});

The thing is that for example when the application starts I can see all the ViewHolder ID, but when I checked in anyone I cans see how the ID is different, so it is taking a different ViewHolder that which I checked, and I do not have idea why take a different ID (ViewHolder).

I made the changes which Sufian told me, this is the code, even so now I get a unfortunatly....

public View getView(int position, View convertView, ViewGroup parent){

     vh = null;
     bvh = null;
     String sharedPrefKey;

     int type = getItemViewType(position);

     // big row excluded
     if(type == SMALL_ROW_DESIGN){
         if(convertView == null || convertView.getTag() == null){
             LayoutInflater inflater = (LayoutInflater) context
                        .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
                    convertView = inflater.inflate(R.layout.row_settings, parent, false);
                    vh = new RowSettingsViewHolder();
                    vh.titleTV = (TextView) convertView.findViewById(R.id.settings_row_title);
                    vh.subtitleTV = (TextView) convertView.findViewById(R.id.settings_row_subtitle);
                    vh.disclosureIV = (ImageView) convertView.findViewById(R.id.settings_disclosureIV);
                    vh.checkCB = (CheckBox) convertView.findViewById(R.id.settings_cB);
                    vh.separatorLine = (View)convertView.findViewById(R.id.settings_listView_separatorLine);


                    int id = Resources.getSystem().getIdentifier("btn_check_holo_light", "drawable", "android");
                    if(id!=0)
                        vh.checkCB.setButtonDrawable(id);

                    Typeface tf = Typeface.createFromAsset(getActivity().getAssets(), "fonts/Decima Light.otf");
                    vh.titleTV.setTypeface(tf);

                    vh.checkCB.setOnCheckedChangeListener(new OnCheckedChangeListener() {

                        @Override
                        public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
                            // TODO Auto-generated method stub
                            //Log.i("TabSettingsActivity", "checked");
                            sharedPreferencesHandler_settings.setSettingActive(SharedPrefsHandler.allNotifsActiveKey, vh.checkCB.isChecked());
                            Log.i("TabSettingsActivity", "checked: " +Boolean.toString(isChecked));
                            //Log.i("isChecked", vh.checkCB.getTag().toString());
                            Log.i("TabSettingsActivity", "vh tag: " +vh.checkCB.getTag().toString());
                            sharedPreferencesHandler_settings.setSettingActive(vh.checkCB.getTag().toString(), isChecked);
                            // Do something here.

                        }
                    });


                    convertView.setTag(vh);

                    Log.i("VH", "VH " +vh.toString());
                    Log.i("POSITION", "POSITION " +position);
            // init sahredPrefs if necessary
/*          if (sharedPrefsHandler == null) {
                SharedPrefsHandler.getInstance().initForNotifications(getActivity());
                sharedPrefsHandler = SharedPrefsHandler.getInstance();
            }*/


         }
         else{
             vh = (RowSettingsViewHolder) convertView.getTag();
             vh.checkCB.setTag(position);
             vh.checkCB.setChecked(vh.checkCB.isChecked());
         }

         RowContent thisSetting = null;
         thisSetting = (RowContent)values.get(position);

         // set row values in view 
         vh.titleTV.setText(thisSetting.getTitle());
         vh.disclosureIV.setImageDrawable(thisSetting.getDisclosureDrawable());

         // subtitle
         vh.subtitleTV.setText(thisSetting.getSubtitle());
         String title=vh.titleTV.getText().toString();
         String subtitle=vh.subtitleTV.getText().toString();
         if(subtitle.equals("NOTIFICATIONS") || subtitle.equals("MUSIC") || subtitle.equals("EMAIL") || subtitle.equals("SYSTEM")){
             Typeface tfSubt = Typeface.createFromAsset(getActivity().getAssets(), "fonts/Decima Bold.otf");
             vh.subtitleTV.setTypeface(tfSubt);
             vh.separatorLine.setBackgroundColor(Color.BLACK);
         }
         else{
             Typeface tf = Typeface.createFromAsset(getActivity().getAssets(), "fonts/Decima Light.otf");
             vh.subtitleTV.setTypeface(tf);
             vh.separatorLine.setBackgroundColor(Color.LTGRAY);
         }

         // checkbox         
         if(!thisSetting.needsCheckBox()){
             vh.checkCB.setVisibility(View.INVISIBLE); 
             vh.checkCB.setOnClickListener(null);
         }
         else{
             vh.checkCB.setVisibility(View.VISIBLE);



            if(title.equals(getResources().getString(R.string.Spotify))){
                 vh.checkCB.setChecked(sharedPreferencesHandler_settings.isSpotifyActive());
                 sharedPrefKey = SharedPrefsHandler.spotifyKey;
                 vh.checkCB.setTag(sharedPrefKey);
             }
             else if(title.equals(getResources().getString(R.string.Google_Play))){
                 vh.checkCB.setChecked(sharedPreferencesHandler_settings.isGooglePlayerActive());
                 sharedPrefKey = SharedPrefsHandler.googlePlayerKey;
                 vh.checkCB.setTag(sharedPrefKey);
             }
             else if(title.equals(getResources().getString(R.string.default_music_player))){
                 vh.checkCB.setChecked(sharedPreferencesHandler_settings.isDefaultPlayerActive());
                 sharedPrefKey = SharedPrefsHandler.defaulPlayerKey;
                 vh.checkCB.setTag(sharedPrefKey);
             }
             else if(title.equals(getResources().getString(R.string.default_mail))){
                 vh.checkCB.setChecked(sharedPreferencesHandler_settings.isDefaultEmailAppActive());
                 sharedPrefKey = SharedPrefsHandler.defaultEmailKey;
                 vh.checkCB.setTag(sharedPrefKey);
             }
             else if(title.equals(getResources().getString(R.string.Hotmail))){
                 vh.checkCB.setChecked(sharedPreferencesHandler_settings.isHotmailActive());
                 sharedPrefKey = SharedPrefsHandler.hotmailKey;
                 vh.checkCB.setTag(sharedPrefKey);
             }
             else if(title.equals(getResources().getString(R.string.Gmail))){
                 vh.checkCB.setChecked(sharedPreferencesHandler_settings.isGmailActive());
                 sharedPrefKey = SharedPrefsHandler.gmailKey;
                 vh.checkCB.setTag(sharedPrefKey);
             }
             else if(title.equals(getResources().getString(R.string.enable_disable_all_notif))){
                 vh.checkCB.setChecked(sharedPreferencesHandler_settings.areAllNotifsActive());
                 sharedPrefKey = SharedPrefsHandler.allNotifsActiveKey;
                 vh.checkCB.setTag(sharedPrefKey);
             }



        /*   vh.checkCB.setOnClickListener(new OnClickListener() {
                    @Override
                    public void onClick(View v) {
                        Log.i("TabSettingsActivity", "checked");
                        sharedPreferencesHandler_settings.setSettingActive(SharedPrefsHandler.allNotifsActiveKey, vh.checkCB.isChecked());
                        Log.i("isChecked", Boolean.valueOf(vh.checkCB.isChecked()).toString());
                        Log.i("isChecked", vh.checkCB.getTag().toString());
                        sharedPreferencesHandler_settings.setSettingActive(vh.checkCB.getTag().toString(), vh.checkCB.isChecked());
                        // Do something here.
                    }
                });  */
         }
     }

     //big row
     else {

         if(convertView == null){
         LayoutInflater inflater = (LayoutInflater) context
                    .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
                convertView = inflater.inflate(R.layout.row_settings_big, parent, false);
                bvh = new BigRowSettingsViewHolder(convertView);






                convertView.setTag(bvh); 
     }

         else{
             bvh = (BigRowSettingsViewHolder)convertView.getTag();
         }
         bvh.setRowData();           
     }

     return convertView;
 }

}

I hope this can help to solved the problem

Here is the LogCat:

11-25 13:19:48.671: D/dalvikvm(24077): GC_FOR_ALLOC freed 81K, 2% free 9068K/9180K, paused 15ms, total 15ms
11-25 13:19:48.671: I/dalvikvm-heap(24077): Grow heap (frag case) to 9.687MB for 842416-byte allocation
11-25 13:19:48.681: D/dalvikvm(24077): GC_FOR_ALLOC freed <1K, 2% free 9890K/10004K, paused 10ms, total 10ms
11-25 13:19:48.751: D/dalvikvm(24077): GC_FOR_ALLOC freed 24K, 1% free 10214K/10272K, paused 11ms, total 11ms
11-25 13:19:48.761: I/dalvikvm-heap(24077): Grow heap (frag case) to 17.913MB for 8294416-byte allocation
11-25 13:19:48.781: D/dalvikvm(24077): GC_FOR_ALLOC freed 1K, 1% free 18312K/18376K, paused 12ms, total 12ms
11-25 13:19:48.872: W/dalvikvm(24077): Unable to resolve superclass of Lcom/ionglasses2/ble/DfuService; (1377)
11-25 13:19:48.872: W/dalvikvm(24077): Link of class 'Lcom/ionglasses2/ble/DfuService;' failed
11-25 13:19:48.872: E/dalvikvm(24077): Could not find class 'com.ionglasses2.ble.DfuService', referenced from method com.ionglasses2.ble.DiscoveryService.startDFUService
11-25 13:19:48.872: W/dalvikvm(24077): VFY: unable to resolve const-class 1240 (Lcom/ionglasses2/ble/DfuService;) in Lcom/ionglasses2/ble/DiscoveryService;
11-25 13:19:48.872: D/dalvikvm(24077): VFY: replacing opcode 0x1c at 0x000c
11-25 13:19:48.882: I/TabNotificationsActivity(24077): get view EventosArrayAdapter
11-25 13:19:48.892: I/SharedPrefsHandler(24077): getInstance
11-25 13:19:48.902: I/SharedPrefsHandler(24077): initForNotifications
11-25 13:19:48.902: I/SharedPrefsHandler(24077): getInstance
11-25 13:19:48.902: I/SharedPrefsHandler(24077): Event: CALLS getIsEventActive: false
11-25 13:19:49.002: D/dalvikvm(24077): GC_FOR_ALLOC freed 425K, 3% free 20304K/20760K, paused 13ms, total 13ms
11-25 13:19:49.022: I/Adreno-EGL(24077): <qeglDrvAPI_eglInitialize:320>: EGL 1.4 QUALCOMM Build: I0404c4692afb8623f95c43aeb6d5e13ed4b30ddbDate: 11/06/13
11-25 13:19:49.052: D/OpenGLRenderer(24077): Enabling debug mode 0
11-25 13:19:49.052: I/TabNotificationsActivity(24077): get view EventosArrayAdapter
11-25 13:19:49.062: I/SharedPrefsHandler(24077): Event: CALLS getIsEventActive: false
11-25 13:19:49.072: I/TabNotificationsActivity(24077): get view EventosArrayAdapter
11-25 13:19:49.072: I/SharedPrefsHandler(24077): Event: SMS getIsEventActive: false
11-25 13:19:49.082: I/TabNotificationsActivity(24077): get view EventosArrayAdapter
11-25 13:19:49.082: I/SharedPrefsHandler(24077): Event: EMAIL getIsEventActive: false
11-25 13:19:49.082: I/TabNotificationsActivity(24077): get view EventosArrayAdapter
11-25 13:19:49.092: I/SharedPrefsHandler(24077): Event: TWITTER getIsEventActive: false
11-25 13:19:52.175: I/SharedPrefsHandler(24077): getInstance
11-25 13:19:52.185: I/SharedPrefsHandler(24077): initForSettings
11-25 13:19:52.185: I/SharedPrefsHandler(24077): getInstance
11-25 13:19:52.185: I/TabSettings(24077): mState: 0
11-25 13:19:52.185: E/TabSettingsActivity(24077): onResume:RegistermGattUpdateReceiver
11-25 13:19:52.205: I/VH(24077): VH com.ionglasses2.TabSettingsActivity$RowSettingsViewHolder@42c22fa8
11-25 13:19:52.205: I/POSITION(24077): POSITION 0
11-25 13:19:52.225: I/VH(24077): VH com.ionglasses2.TabSettingsActivity$RowSettingsViewHolder@42c27b78
11-25 13:19:52.225: I/POSITION(24077): POSITION 1
11-25 13:19:52.235: I/VH(24077): VH com.ionglasses2.TabSettingsActivity$RowSettingsViewHolder@42c2bda0
11-25 13:19:52.235: I/POSITION(24077): POSITION 2
11-25 13:19:52.245: I/VH(24077): VH com.ionglasses2.TabSettingsActivity$RowSettingsViewHolder@42c2fff0
11-25 13:19:52.245: I/POSITION(24077): POSITION 3
11-25 13:19:52.245: I/SharedPrefs(24077): info leida are All notif Active: true
11-25 13:19:52.245: I/SharedPrefs(24077): allNotifsActive value: true
11-25 13:19:52.245: I/TabSettingsActivity(24077): checked: true
11-25 13:19:52.245: D/AndroidRuntime(24077): Shutting down VM
11-25 13:19:52.245: W/dalvikvm(24077): threadid=1: thread exiting with uncaught exception (group=0x41615ba8)
11-25 13:19:52.255: E/AndroidRuntime(24077): FATAL EXCEPTION: main
11-25 13:19:52.255: E/AndroidRuntime(24077): Process: com.ionglasses2, PID: 24077
11-25 13:19:52.255: E/AndroidRuntime(24077): java.lang.NullPointerException
11-25 13:19:52.255: E/AndroidRuntime(24077):    at com.ionglasses2.TabSettingsActivity$SettingsArrayAdapter$1.onCheckedChanged(TabSettingsActivity.java:1341)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.CompoundButton.setChecked(CompoundButton.java:127)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at com.ionglasses2.TabSettingsActivity$SettingsArrayAdapter.getView(TabSettingsActivity.java:1430)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.AbsListView.obtainView(AbsListView.java:2263)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.ListView.makeAndAddView(ListView.java:1790)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.ListView.fillDown(ListView.java:691)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.ListView.fillFromTop(ListView.java:752)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.ListView.layoutChildren(ListView.java:1630)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.AbsListView.onLayout(AbsListView.java:2091)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.View.layout(View.java:14817)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.ViewGroup.layout(ViewGroup.java:4631)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1671)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1525)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.LinearLayout.onLayout(LinearLayout.java:1434)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.View.layout(View.java:14817)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.ViewGroup.layout(ViewGroup.java:4631)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.FrameLayout.layoutChildren(FrameLayout.java:453)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.FrameLayout.onLayout(FrameLayout.java:388)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.View.layout(View.java:14817)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.ViewGroup.layout(ViewGroup.java:4631)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.FrameLayout.layoutChildren(FrameLayout.java:453)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.FrameLayout.onLayout(FrameLayout.java:388)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.View.layout(View.java:14817)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.ViewGroup.layout(ViewGroup.java:4631)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1671)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1525)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.LinearLayout.onLayout(LinearLayout.java:1434)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.View.layout(View.java:14817)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.ViewGroup.layout(ViewGroup.java:4631)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.FrameLayout.layoutChildren(FrameLayout.java:453)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.FrameLayout.onLayout(FrameLayout.java:388)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.View.layout(View.java:14817)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.ViewGroup.layout(ViewGroup.java:4631)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1671)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1525)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.LinearLayout.onLayout(LinearLayout.java:1434)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.View.layout(View.java:14817)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.ViewGroup.layout(ViewGroup.java:4631)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.FrameLayout.layoutChildren(FrameLayout.java:453)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.widget.FrameLayout.onLayout(FrameLayout.java:388)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.View.layout(View.java:14817)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.ViewGroup.layout(ViewGroup.java:4631)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.ViewRootImpl.performLayout(ViewRootImpl.java:1987)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1744)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1000)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5670)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.Choreographer$CallbackRecord.run(Choreographer.java:761)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.Choreographer.doCallbacks(Choreographer.java:574)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.Choreographer.doFrame(Choreographer.java:544)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:747)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.os.Handler.handleCallback(Handler.java:733)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.os.Handler.dispatchMessage(Handler.java:95)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.os.Looper.loop(Looper.java:136)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at android.app.ActivityThread.main(ActivityThread.java:5017)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at java.lang.reflect.Method.invokeNative(Native Method)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at java.lang.reflect.Method.invoke(Method.java:515)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
11-25 13:19:52.255: E/AndroidRuntime(24077):    at dalvik.system.NativeStart.main(Native Method)

Finally I resolved the problem this is the code:

`vh.checkCB.setOnCheckedChangeListener(new OnCheckedChangeListener() {

                        @Override
                        public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
                            // TODO Auto-generated method stub
                            //Log.i("TabSettingsActivity", "checked");
                       //     sharedPreferencesHandler_settings.setSettingActive(SharedPrefsHandler.allNotifsActiveKey, vh.checkCB.isChecked());
                            Log.i("TabSettingsActivity", "checked: " +Boolean.toString(isChecked));
                         //   int rowPosition = (Integer)buttonView.getTag();
                            sharedPreferencesHandler_settings.setSettingActive(buttonView.getTag().toString(), isChecked);
                        //    Log.i("POSITION", "POSITION " +rowPosition);
                          //  getItem(rowPosition).setMarked(buttonView.isChecked());
                            //Log.i("isChecked", vh.checkCB.getTag().toString());
                      //      Log.i("TabSettingsActivity", "vh tag: " +vh.checkCB.getTag().toString());
                      //      sharedPreferencesHandler_settings.setSettingActive(vh.checkCB.getTag().toString(), isChecked);
                            // Do something here.

                        }
                    });


                    convertView.setTag(vh);

                    Log.i("VH", "VH " +vh.toString());
                    Log.i("POSITION", "POSITION " +position);
            // init sahredPrefs if necessary
/*          if (sharedPrefsHandler == null) {
                SharedPrefsHandler.getInstance().initForNotifications(getActivity());
                sharedPrefsHandler = SharedPrefsHandler.getInstance();
            }*/


         }
         else
             vh = (RowSettingsViewHolder) convertView.getTag();


         vh.checkCB.setTag(position);
         vh.checkCB.setChecked(vh.checkCB.isChecked());`
1

There are 1 answers

16
Sufian On BEST ANSWER

I checked what I did when I faced similar issue. I actually set the OnCheckedChangeListener only once (when the row was created i.e as inflater.inflate()). And I set the row number as tag to the CheckBox.

Following is my code:

if (convertView == null || convertView.getTag() == null) {
    holder = new Holder();
    //TODO set holder fields here
    holder.checkBox.setOnCheckedChangeListener(new OnCheckedChangeListener() {
        @Override
        public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
            int rowPosition = (Integer)buttonView.getTag();
            getItem(rowPosition).setMarked(buttonView.isChecked());
        }
    });
    convertView.setTag(holder);
}
else
    holder = (Holder) convertView.getTag();
holder.checkBox.setTag(position);
holder.checkBox.setChecked(item.isChecked());