TreeView控件用来显示信息的分级视图,如同Windows里的资源管理器的目录。TreeView控件中的各项信息都有一个与之相关的Node对象。TreeView显示Node对象的分层目录结构,每个Node对象均由一个Label对象和其相关的位图组成。在建立TreeView控件后,我们可以展开和折叠、显示或隐藏其中的节点。TreeView控件一般用来显示文件和目录结构、文档中的类层次、索引中的层次和其他具有分层目录结构的信息。
思路是:按照类似于“树”的结构组织数据,界面上直接利用大家经常用的listview实现的。下面这个是节点信息的类:
public class PDFOutlineElement {
private String id;//当前节点的id
private String outlineTitle ;//节点上面显示的信息
private boolean mhasParent ; //是否有父节点
private boolean mhasChild ;//是否有孩子节点
private String parent;//父节点的id
private int level;//当前节点所在的层次
}
首先是这个level,是很关键的,他表示的是当前节点所在的层次,正是他帮助我们在界面上显示出来了层次效果,其实这个树形结构并不是树形结构,所有的数据都维护在一个ArrayList里面,某一个节点A下面有子节点B、C,其实A、B、C这三个节点在ArrayList里面是顺序存放的,如果A的层次是level,那个他的子节点的层次是level+1,我们在getView()的时候我们可以不借助系统自动给我们画上,而是可以自己指定他的位置holder.icon.setPadding(25 * (level + 1), holder.icon.getPaddingTop(), 0, holder.icon.getPaddingBottom());,这样他的子节点便具有了缩进的效果。
然后是如何实现“展开”和 “缩回”的效果,其实这个只不过 是当单击摸个节点的时候,如果这个节点下面有子节点而且是“缩回”的,就把他的所有的子节点都从那个ArrayList里面删除调,然后 notifyDataSetChanged(),同理就是“展开”的时候,就是在这个节点后面添加子节点到ArrayList里面,然后 notifyDataSetChanged()。
明白了这个思路,getView:
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
/*if (convertView == null) {*/
convertView = mInflater.inflate(R.layout.outline, null);
holder = new ViewHolder();
holder.text = (TextView) convertView.findViewById(R.id.text);
holder.icon = (ImageView) convertView.findViewById(R.id.icon);
convertView.setTag(holder);
/*} else {
holder = (ViewHolder) convertView.getTag();
}*/
int level = mfilelist.get(position).getLevel();//每次根据节点的层次绘制显示的位置
holder.icon.setPadding(25 * (level + 1), holder.icon
.getPaddingTop(), 0, holder.icon.getPaddingBottom());
holder.text.setText(mfilelist.get(position).getOutlineTitle());
//如果有孩子而且当前是不是展开的图标设置为“+”号的图标
if (mfilelist.get(position).isMhasChild()
&& (mfilelist.get(position).isExpanded() == false)) {
holder.icon.setImageBitmap(mIconCollapse);
} else if (mfilelist.get(position).isMhasChild()
&& (mfilelist.get(position).isExpanded() == true)) {
//如果有孩子而且当前是不是展开的图标设置为“+”号的图标
holder.icon.setImageBitmap(mIconExpand);
} else if (!mfilelist.get(position).isMhasChild()){
holder.icon.setImageBitmap(mIconCollapse);
holder.icon.setVisibility(View.INVISIBLE);//这里不要设置为GONE,因为GONE不显示而且不占位置的,而INVISIBLE是不显示但是占位置的
}
return convertView;
}
分享到:
相关推荐
在android中实现类似windows的treeview效果。
主要介绍了Android TreeView效果实现方法,结合实例形式分析了Android TreeView效果的实现原理与具体技巧,并附带demo源码供读者下载,需要的朋友可以参考下
所谓TreeView就是在Windows中常见的多级列表树,在Android中系统只默认提供了ListView和ExpandableListView两种列表,最多只支持到二级列表的实现,所以如果想要实现三级和更多层次的列表,就需要我们自己来做一些...
本例子是一个自定义TreeView的树形结构控件,真实效果如下图所示,实现方式是用两个树形节点类集合分别去存储所有节点(List
下面上演示效果图,时长25秒,手机卡见谅。 复选框有两种设计模式: 1、子节点选中则父节点选中,适合多级多item下方便了解哪些被选中; 2、子节点全部选中父节点才选中,更符合日常逻辑,适合少数量以及少层级。 ...
该源码由源码天堂android源码代码片段免费提供的,效果可以支持了左侧的抽屉效果特效,一款android开发的超爽的android抽屉效果,点击按钮可以看到抽屉渐入渐出的动画效果。
QML 中没有直接提供类似 android 的ExpandableListView二级列表控件,treeView,但是用 treeView 实在是有些不方便,并且达不到想要的效果,所以干脆用 ListView 来扩展一个。
本项目包含三种,底部导航栏的实现。一种是以Fragment实现的;一种以Framelayout添加View的形式实现,一种是ViewPager实现的。
TreeViewAndroid树形控件通过ListView实现,判断每个item属于树的第几层,设置其缩进值达到效果。
本文实例为大家分享了android实现菜单三级树展示的具体代码,供大家参考,具体内容如下 以下是部分代码,完整代码请在最下面点击下载: 【MainActivity】 public void treeOnClick() { // TODO Auto-generated ...
用QML中的listview来实现树形二级列表(类似android ExpandableListView控件) 2.QML阴影字体 QML实现阴影字体效果,可定义阴影颜色及阴影大小等 3.QML-Light-Ani-font QML实现发光呼吸动画字体效果 4,QML渐变...