更新 我决定使用ExpandableListAdapter来实现这一点......因为这段代码几乎可以有效地尝试设计可扩展的listadapter已经完成的工作。
我正在使用ViewHolder的标准模式,以使ListView简单地工作......
public View getView(int position, View convertView, ViewGroup parent) {
View vi=convertView;
ViewHolder holder;
if( convertView == null ){
vi = inflater.inflate(R.layout.item, null);
holder=new ViewHolder();
holder.text=(TextView)vi.findViewById(R.id.text);
holder.image=(ImageView)vi.findViewById(R.id.image);
holder.expandButton=(ImageView)vi.findViewById(R.id.expand_button);
vi.setTag(holder);
}
else
holder=(ViewHolder)vi.getTag();
然而......我相信我的onClickListener ......出了点问题。
final String textData = texts[position];
final ViewHolder holderFinal = holder;
holder.expandButton.setVisibility(View.VISIBLE);
holder.expandButton.setOnClickListener(new View.OnClickListener()
@Override
public void onClick(View v) {
holderFinal.expandButton.setImageResource(R.drawable.expander_ic_maximized);
holderFinal.text.setText(textData);
因此,当来回滚动时,一切都显示正常....但是,无论何时展开其中一个列表项,上面的最后一行都包含属于另一行的textData。如何在onCLick监听器中获取正确的textData?
答案 0 :(得分:2)
我正在尝试同样的问题,我解决了这个问题,将listview的每个item对象都设置为一个静态类,如下所示:
所有必要的数据在ListView中显示我在静态类中定义的行,如下所示:
static class DataHolder{
Drawable extIcon;
String text;
String quantity_text;
Drawable icon;
int progressBarVisible;
int quantityTextVisible;
}
然后创建我创建的所有行:
ArrayList<DataHolder> data = new ArrayList<DataHolder>();
for ( int i=0 ; i < activitys.length ; i++ ) {
DataHolder item = new DataHolder();
item.icon = icons[i]; //an icons array
item.quantity_text = ""; //some text
item.progressBarVisible = View.GONE; //a status for a progress bar
//other data setting
}
然后是我的ArrayAdapter子类:
class ActivityList extends ArrayAdapter<DataHolder>{
public ActivityList(Context context, int textViewResourceId, ArrayList<DataHolder> objects) {
super(context, textViewResourceId, objects);
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if(convertView == null){
LayoutInflater inflater = LayoutInflater.from(HomeActivity.this);
convertView = inflater.inflate(R.layout.home_activity_item, parent, false);
holder = new ViewHolder();
holder.text = (TextView)convertView.findViewById(R.id.homeActivityText);
holder.icon = (ImageView)convertView.findViewById(R.id.homeActivityIcon);
holder.progressBar = (ProgressBar)convertView.findViewById(R.id.homeActivityQuantityPBar);
holder.quantity_text = (TextView)convertView.findViewById(R.id.homeActivityQuantity);
holder.extIcon = (ImageView)convertView.findViewById(R.id.homeActivityIconExtended);
convertView.setTag(holder);
}else{
holder = (ViewHolder) convertView.getTag();
}
holder.text.setText(getItem(position).text);
holder.icon.setImageDrawable( getItem(position).icon );
holder.quantity_text.setVisibility( getItem(position).quantityTextVisible );
holder.quantity_text.setText( getItem(position).quantity_text );
holder.progressBar.setVisibility( getItem(position).progressBarVisible );
holder.extIcon.setImageDrawable( getItem(position).extIcon );
return convertView;
}
}
最后我的列表行视图上没有按钮,但我可以通过这种方式对各种上下文进行任何操作,始终获取确切的文本。 (listView字段是ActivityList的实例) (SAVED_SEARCH是列表项位置)
((ActivityList)listView.getAdapter()).getItem(SAVED_SEARCHED).progressBarVisible = View.GONE;
((ActivityList)listView.getAdapter()).getItem(SAVED_SEARCHED).quantity_text = "any text";
((ActivityList)listView.getAdapter()).notifyDataSetChanged();
从此希望这会对你有所帮助。
答案 1 :(得分:0)
点击后尝试使用ViewHolder的postInvalidate()。
答案 2 :(得分:0)
嗨,看看我对类似问题的解决方案:
答案 3 :(得分:0)
将GlobalPostion初始化为全局变量
GlobalPosition = position
holder.expandButton.setOnClickListener(new View.OnClickListener() int localPosition = GlobalPosition @Override public void onClick(View v) {
holderFinal.expandButton.setImageResource(R.drawable.expander_ic_maximized); holderFinal.text.setText(""+texts[localPosition]); }
问题是你没有得到确切的列表位置,如果你将它存储在全局变量中,然后移动到OnClick内的局部变量你可以保留位置。 我希望这会对你有所帮助