`
senlinwuran
  • 浏览: 15479 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

实现Android 中的TreeView效果

阅读更多

   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 TreeView

    在android中实现类似windows的treeview效果。

    Android TreeView效果实现方法(附demo源码下载)

    主要介绍了Android TreeView效果实现方法,结合实例形式分析了Android TreeView效果的实现原理与具体技巧,并附带demo源码供读者下载,需要的朋友可以参考下

    Android UI 之实现多级树形列表TreeView示例

    所谓TreeView就是在Windows中常见的多级列表树,在Android中系统只默认提供了ListView和ExpandableListView两种列表,最多只支持到二级列表的实现,所以如果想要实现三级和更多层次的列表,就需要我们自己来做一些...

    Android例子源码自定义TreeView的树形结构控件

    本例子是一个自定义TreeView的树形结构控件,真实效果如下图所示,实现方式是用两个树形节点类集合分别去存储所有节点(List

    Android TreeView实现带复选框树形组织结构

    下面上演示效果图,时长25秒,手机卡见谅。 复选框有两种设计模式: 1、子节点选中则父节点选中,适合多级多item下方便了解哪些被选中; 2、子节点全部选中父节点才选中,更符合日常逻辑,适合少数量以及少层级。 ...

    左侧的抽屉效果特效

    该源码由源码天堂android源码代码片段免费提供的,效果可以支持了左侧的抽屉效果特效,一款android开发的超爽的android抽屉效果,点击按钮可以看到抽屉渐入渐出的动画效果。

    QML ListView实现树形二级列表(类似 android ExpandableListView控件)

    QML 中没有直接提供类似 android 的ExpandableListView二级列表控件,treeView,但是用 treeView 实在是有些不方便,并且达不到想要的效果,所以干脆用 ListView 来扩展一个。

    三种导航栏实现效果

    本项目包含三种,底部导航栏的实现。一种是以Fragment实现的;一种以Framelayout添加View的形式实现,一种是ViewPager实现的。

    TreeView:Android树形控件

    TreeViewAndroid树形控件通过ListView实现,判断每个item属于树的第几层,设置其缩进值达到效果。

    android实现菜单三级树效果

    本文实例为大家分享了android实现菜单三级树展示的具体代码,供大家参考,具体内容如下 以下是部分代码,完整代码请在最下面点击下载: 【MainActivity】 public void treeOnClick() { // TODO Auto-generated ...

    Qt-QML-Example:Qt,QML示例集合

    用QML中的listview来实现树形二级列表(类似android ExpandableListView控件) 2.QML阴影字体 QML实现阴影字体效果,可定义阴影颜色及阴影大小等 3.QML-Light-Ani-font QML实现发光呼吸动画字体效果 4,QML渐变...

Global site tag (gtag.js) - Google Analytics