本文参考Hongyang大神文章 http://blog.csdn.net/lmj623565791/article/details/40212367 ,自己写个demo记录下。
先看效果图:
总思路:
将每条数据都看作是listview的一个item,按照它们之间的关系,将这些item由上到下排序。然后将每个item设置为不同的显示状态,再加上点击每个item会联动其他相应item的显示状态改变,这样就达到了树状结构导航的目的。
1、将每条原始数据都转化为节点数据,因为每个节点数据里有:
a、子节点、父节点:这个很重要,因为每条数据的缩进、图标的设置、是否展示,都要依据每条数据间的父子关系来进行判断展示;
b、左边距的空格数:设置缩进,以展现树状结构效果
c、展开的状态:说明此节点目前是否展开
2、在适配器配置这条节点数据的View时,依据这条节点数据的各个属性,来做不同的展示,以达到最终树状结构展示效果的目的。
写完这个demo,让我深刻的认识到了一个道理:
每个控件其实都对应一条数据,“控件展示状态的改变”本质上其实就是“它所对应的那条数据中的某个参数改变了”而已。
原始数据Bean:
public class Bean {
@TreeId
int id;
@TreePid
int pid;
@TreeLabel
String name;
public Bean(int id, int pid, String name) {
this.id = id;
this.pid = pid;
this.name = name;
}
}
节点数据Node:
public class Node {
public Node(int id, int pid, String name) {
this.id = id;
this.pid = pid;
this.name = name;
}
int id;
int pid;
String name;
/**
* 子节点
*/
List<Node> children = new ArrayList<>();
/**
* 父节点
*/
Node parent;
/**
* 前面有几个单位的空格
*/
int level;
/**
* 是否是展开状态
*/
boolean isExpand = false;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public int getPid() {
return pid;
}
public void setPid(int pid) {
this.pid = pid;
}
public List<Node> getChildren() {
return children;
}
public Node getParent() {
return par