ZNDS智能电视网 推荐当贝市场

TV应用下载 / 资源分享区

软件下载 | 游戏 | 讨论 | 电视计算器

综合交流 / 评测 / 活动区

交流区 | 测硬件 | 网站活动 | Z币中心

新手入门 / 进阶 / 社区互助

新手 | 你问我答 | 免费刷机救砖 | ROM固件

查看: 12947|回复: 0
上一主题 下一主题
[案例]

学习Android界面设计的超级利器HierarchyView.bat

[复制链接]
跳转到指定楼层
楼主
发表于 2013-8-28 16:27 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
   
我看到别人的程序,想学习人家的UI布局是怎么做的,如何能窥探一二?
   
在学习ViewGroup和Layout时我们可能会有一个疑问,如果我在Xml布局文件中不放置Layout,直接放TextView等组件的时候,它是用什么方式布局的?
解决方法:   
Android的SDK中自带了一个查看UI布局层级结构的工具:HierarchyView.bat。在模拟器运行的情况下,使用该工具可以将当前的Activity中的UI组件们以对象树的形式展现出来,每一个组件所包含的属性也能窥探得到。在对象树上的任意节点可以看到该节点及以下节点的显示效果。使用HierarchyView能深入全面的理解xml布局文件,更可以通过它来学习别人优秀的布局技巧。
      
(看到那个不起眼的hierachyview.bat文件没,哎,竟然它是学习Android界面设计的超级利器)
  
  从图中可以看到QQ登录界面中的核心部分是用相对布局摆放的,甚至可以看到有的TextView还用的是IDE自动起的ID:TextView01。
下面我们解决第二个问题:找到默认的布局方式是什么?
我们建一个新项目,Main.xml中只放一个TextView,
<?xml version="1.0" encoding="utf-8"?>   
<TextView android:text="hi" android:id="@+id/TV"   
    android:layout_width="wrap_content" android:layout_height="wrap_content"   
    xmlns:android="http://schemas.android.com/apk/res/android"></TextView>
   
看看他的布局层次是什么样的:
     
我们可以看到顶级元素是个PhoneWindow,其下有一个线性布局LinearLayout,再下面有一个应用程序标题条,
      
标题条是由一个帧布局FrameLayout和一个TextView组成。   
我们自己写的TextView也放在了一个Layout里,这个Layout就是ID叫做content的FrameLayout。
     
接下来我们再创建一个带有LinearLayout的程序,看看他的层次结构来确定一下,那个ID是content的FrameLayout是固有的还是因为没布局元素由系统自动加上去的。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout android:id="@+id/LinearLayout01"   
    android:layout_width="fill_parent" android:layout_height="fill_parent"   
    xmlns:android="http://schemas.android.com/apk/res/android">   
    <TextView android:text="haha" android:id="@+id/TextView01"   
        android:layout_width="wrap_content" android:layout_height="wrap_content"></TextView>   
</LinearLayout>
下面是新程序的UI界面层次结构图:
     
这一次我们同样看到了那个Id是content的Framelayout:) 这说明它是窗口布局结构里固有的。
</font

上一篇:Android 利用Java反射技术阻止通过按钮关闭对话框
下一篇:缩小Android模拟器的显示尺寸
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|新帖|标签|软件|Sitemap|ZNDS智能电视网 ( 苏ICP备2023012627号 )

网络信息服务信用承诺书 | 增值电信业务经营许可证:苏B2-20221768 丨 苏公网安备 32011402011373号

GMT+8, 2025-5-17 11:18 , Processed in 0.125045 second(s), 13 queries , Redis On.

Powered by Discuz!

监督举报:report#znds.com (请将#替换为@)

© 2007-2025 ZNDS.Com

快速回复 返回顶部 返回列表