为了实现点击listView中item中的某个TextView,展示此item中隐藏的布局,再次点击隐藏此布局的这个功能,刚开始我在adapter的getView() 方法中加了给这个textView中加了一个点击事件。
textView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (hideView.getVisibility() == View.VISIBLE) {
hideView.setVisibility(View.GONE);
} else {
hideView.setVisibility(View.VISIBLE);
}
})
但是这样就会出现点击显示隐藏部分的时候,listView最下面的item被挤出屏幕,且listView无法滑动。
解决方法
刚开始,我想到的第一个解决办法是重绘ListView的高度,这种方法网上有很多,所以就不介绍了。这个方法虽然可行,但我感觉却有些杀鸡用牛刀了。
于是就有了第二种方法。众所周知ListView有个notifyDataSetChanged()方法。这个方法是数据改变时调用则会刷新整个ListView。我在item布局所对应的实体类中添加了一个boolean类型的变量用于判断是否显示还是隐藏。
比如实体类如下:
public class VipCoupon {
public String id;
public String name;
public String deadline;
/**
* 是否显示隐藏的布局,属于ui使用的变量,与业务无关
*/
public boolean isShow;
}
然后在listViwe的adapter的getView()方法中做如下处理
final VipCoupon voucher = mList.get(position);
if(voucher.isShow){//isShow刚开始默认为false
holder.mUserDesc.setVisibility(View.VISIBLE);
} else {
holder.mUserDesc.setVisibility(View.GONE);
}
//当点击item的textView时
holder.textView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
voucher.isShow = !voucher.isShow;
//最后记得刷新
notifyDataSetChanged();
}
});