先看下效果
public class MainActivity extends Activity {
private MyAdapter myAdapter;
private ListView listView;
private List<String> list;
private View footView;
private ImageView ivDown;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
listView = (ListView) findViewById(R.id.listview);
// 获得页脚布局
footView = getLayoutInflater().inflate(R.layout.view_foot, null);
ivDown = (ImageView) footView.findViewById(R.id.iv_down);
initData();
initEvent();
}
/**
* 初始化数据
*/
private void initData() {
// 初始化模拟数据
simulateData();
// 添加页脚视图
listView.addFooterView(footView);
ivDown.setImageDrawable(getResources()
.getDrawable(R.drawable.icon_down));
// 适配
myAdapter = new MyAdapter(MainActivity.this, list);
listView.setAdapter(myAdapter);
}
/**
* 初始化点击事件
*/
private void initEvent() {
ivDown.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View view) {
// 判断getCount()数据的数量,如果等于3点击后就设置getCount()为全部数量,设置修改标识,刷新。
// 否则,相反。
if (myAdapter.getCount() == 3) {
myAdapter.addItemNum(list.size());
ivDown.setImageDrawable(getResources().getDrawable(
R.drawable.icon_up));
myAdapter.notifyDataSetChanged();
} else {
myAdapter.addItemNum(3);
ivDown.setImageDrawable(getResources().getDrawable(
R.drawable.icon_down));
myAdapter.notifyDataSetChanged();
}
}
});
}
/**
* 模拟数据
*
* @return
*/
private List<String> simulateData() {
list = new ArrayList<String>();
for (int i = 0; i < 10; i++) {
String circleStr = "蓝色威尼斯城" + (i + 1) + "座";
list.add(circleStr);
}
return list;
}
}
public class MyAdapter extends BaseAdapter {
private List<String> list;
private LayoutInflater inflater;
private int itemCount = 3;
public MyAdapter(Context context, List<String> list) {
this.list = list;
inflater = LayoutInflater.from(context);
}
@Override
public int getCount() {
// 这里是关键
// 如果数据数量大于3,只显示3条数据。这里数量自己定义。
// 否则,显示全部数量。
if (list.size() > 3)
{
return itemCount;
}else
{
return list.size();
}
}
@Override
public Object getItem(int position) {
return list.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder viewHolder = null;
if (convertView == null) {
viewHolder = new ViewHolder();
convertView = inflater.inflate(R.layout.item_simple_listview, null);
viewHolder.tvCircleName = (TextView) convertView.findViewById(R.id.tv_circie_name);
convertView.setTag(viewHolder);
}else
{
viewHolder = (ViewHolder) convertView.getTag();
}
viewHolder.tvCircleName.setText(list.get(position));
return convertView;
}
class ViewHolder
{
TextView tvCircleName;
}
/**
* 点击后设置Item的数量
* @param number
*/
public void addItemNum(int number)
{
itemCount = number;
}
}
通过,公共方法addItemNum来修改getCount()的显示,这里起了主要作用!
三、总结
由于项目比较急,所以就用了这种很简单的方法实现,基本上满足了需求。在这里只做了三件事:
① 添加页脚视图。
② 点击页脚视图时,进行判断显示。
③ 修改Adapter的getCount()的值。