HierarchyViewer中的viewNode获取与解析方式

本文具体解释,连接上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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值