HierarchyViewer中的viewNode获取与解析方式

来源:互联网 发布:ubuntu输入密码后卡住 编辑:程序博客网 时间:2024/06/15 12:40

本文具体解释,连接上viewServer以后,利用“DUMP”+hash_code命令来获取到含有所有AppUI信息的字符串的解析

 

树状结构的解析:

1.     while ((line = in.readLine()) != null) 这里,每一行就是一个控件的所有信息,即之后保存的viewNode

2.     如何如何分层?这个是我之前一直的疑问,获取到的信息都是一连串的字符串,这里,我们注意到一个while循环

while (line.charAt(depth) == ' ')

                    depth++;

             

在我们获取到的文本信息中,前面有几个空格,就是代表当前是第几层,当前的viewNode保存在currentNode中,当前的深度,保存在currentDepth中。举个例子,当前的line前有4个空格,表示深度是4层,currentDepth是4,说明当前的viewNode的父亲就是currentNode.parent,这样,在ViewNode的构造函数中,就能清楚的将父类,子类结构表示清楚,从而形成一个树状结构

 

3.     获取根节点,这个很简单,只需要写个while循环,判断currentNode.parent == null, 就能得到根节点

 

关于每个空间信息的字符串解析

 

首先,每个空间字符串信息的格式是 name@hash_code data,name和hash_code内容比较少,所以比较好分割

 

1.     data的分割:

data中是由很多个属性组合在一起的,格式是name=length,value其中,length是指value的字符长度。因此,只要每次找到“=”并定义一个start变量,就能很容易的讲字符串给划分开来,保存的属性保存在property这个类中,再添加到properties这个list中

 

2.     对properties中的name按照字典序进行排序

 

3.     获取UI的一些属性,貌似有两种格式,比如mLeft和layout:mLeft,所以需要判断,如果两个都没有,数值就为默认值(0)

 

 

0 0
原创粉丝点击