本文具体解释,连接上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)