2014-11-09 1 views
0

У меня есть реализация ArrayAdapter здесь, которая отвечает за заполнение списка, которое отображает несколько видов, среди которых значок поиска. Прямо сейчас, я пытаюсь реализовать OnSeekBarChangeListener для этих поисковых баров. У меня есть TextView рядом с стрелкой, отображающей текущий прогресс. Тем не менее, у меня возникают проблемы с обновлением этого TextView всякий раз, когда пользователь перемещает поисковый барьер. Когда вызывается метод onProgessChanged, я не могу просто вызвать expertItem.currentValue.setText (progress), потому что тогда объект propertyItem должен быть объявлен окончательным. Теперь, если бы я это сделал, предложение my else больше не работало бы, поскольку я, очевидно, не могу назначить новое значение для конечного объекта.Изменение атрибутов объекта во внутреннем классе

Какой был бы лучший способ действий здесь?

public View getView(int position, View convertView, ViewGroup parent){ 
    View row = convertView; 
    CompetenceItem competenceItem = null; 
    if (row == null) { 

     ... 

     competenceItem = new CompetenceItem(); 
     competenceItem.seekbar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() { 
      int progressChanged = 0; 

      @Override 
      public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser){ 
       progressChanged = progress; 
      } 

      ... 

     }); 
     competenceItem.currentValue = (TextView) row.findViewById(R.id.textview_header_competence_current_value); 
     row.setTag(competenceItem); 
    } else { 
     competenceItem = (CompetenceItem) row.getTag(); 
    } 

    //competenceItem gets filled with data here 

    return row; 
} 

static class CompetenceItem{ 
    TextView title; 
    SeekBar seekbar; 
    TextView currentValue; 
} 
+0

Сделать его членом класса активности вместо локальной конечной переменной –

+0

Сделать временную ссылку «final» на тот же самый объект «propertyItem», а затем использовать это в анонимном классе. – DeeV

ответ

0

Я не пробовал это, но, может быть, вы могли бы GER избавиться от пункта else asigning (CompetenceItem) row.getTag() в качестве значения по умолчанию в объявлении CompetenceItem. Затем вы можете позвонить competenceItem.currentValue.setText(progress) в предложении if.

+0

Я не думаю, что я достаточно подробно изложил свою проблему в своем оригинальном посте. Моя проблема в том, что currentValue нужно обновлять всякий раз, когда вызывается onProgressChanged. – Anubis

+0

Да, но, похоже, вы не можете назвать 'компетенцияItem.currentValue.setText (progress)' потому что 'CompetenceItem' должен быть объявлен как final ... но если вы объявите его как final, то в' else', вы можете не использовать ' t присваивает любое значение 'CompetenceItem'. Поэтому мой ответ таков: declare 'CompetenceItem' как final и называть' компетенцияItem.currentValue.setText (progress) 'в вашем' onProgressChanged' методе (и, конечно же, избавиться от предложения 'else'). –