当前位置: 首页 > news >正文

Android 基础入门教程View与ViewGroup的概念

2.1 View与ViewGroup的概念

分类Android 基础入门教程

本节引言

告别了第一章,迎来第二章——Android中的UI(User Interface)组件的详解, 而本节我们要学习的是所有控件的父类View和ViewGroup类!突发奇想,直接翻译官方文档对 这两个东西的介绍吧,对了,天朝原因,google上不去,Android developer上不去,我们可以 改hosts或者用科学上网,当然也可以像笔者一样使用国内的API镜像,这里分享个吧: http://androiddoc.qiniudn.com/guide/topics/ui/overview.html 这个镜像是5.0的API!


UI Overview


在Android APP中,所有的用户界面元素都是由View和ViewGroup的对象构成的。View是绘制在屏幕上的用户能与之交互的一个对象。而ViewGroup则是一个用于存放其他View(和ViewGroup)对象的布局容器! Android为我们提供了一个View和ViewGroup子类的集合,集合中提供了一些常用的输入控件(比如按钮和文本域)和各种各样的布局模式(比如线性或相对布局)

User Interface Layout


你的APP的用户界面上的每一个组件都是使用View和ViewGroup对象的层次结构来构成的,比如 图 1。每个ViewGroup都是要给看不见的用于组织子View的容器,而它的子View可能是输入控件 或者在UI上绘制了某块区域的小部件。有了层次树,你就可以根据自己的需要,设计简单或者复 杂的布局了(布局越简单性能越好)

图 1.一个UI布局的层次结构的插图

定义你的布局,你可以在代码中实例化View对象并且开始构建你的树,但最容易和最高效的方式来定义你的布局则是使用一个XML文件,用XML来构成布局更加符合人的阅读习惯,而XML类似与HTML 使用XML元素的名称代表一个View。所以< TextView >元素会在你的界面中创建一个TextView控件,而一个< LinearLayout >则会创建一个LinearLayout的容器! 举个例子,一个简单简单的垂直布局上面有一个文本视图和一个按钮,就像下面这样:

<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" > <TextView android:id="@+id/text" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="I am a TextView" /> <Button android:id="@+id/button" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="I am a Button" /> </LinearLayout>

当你的App加载上述的布局资源的时候,Android会将布局中的每个节点进行实例化成一个个对象,然后你可以为这些定义一些额外的行为,查询对象的状态,或者修改布局。 完整创建UI布局的引导,请参考XML Layouts

User Interface Components


你无需全部用View和ViewGroup对象来创建你的UI布局。Android给我们提供了一些app控件,标准的UI布局,你只需要定义内容。这些UI组件都有其属性介绍的API文档,比如操作栏,对话框和状态通知栏等。


本节小结

好吧,翻译可能比较拗口,哎,英语盲尽力了,简单归纳下上述内容:

Android里的图形界面都是由View和ViewGroup以及他们的子类构成的:View:所有可视化控件的父类,提供组件描绘和时间处理方法ViewGroup:View类的子类,可以拥有子控件,可以看作是容器 Android UI中的控件都是按照这种层次树的结构堆叠得,而创建UI布局的方式有两种, 自己在Java里写代码或者通过XML定义布局,后者显得更加方便和容易理解! 也是我们最常用的手段!另外我们一般很少直接用View和ViewGroup来写布局,更多的 时候使用它们的子类控件或容器来构建布局!

恩呢,对View和ViewGroup有个大概了解即可,平时我们是不会直接用的,一般是自定义View的时候 才会使用这两个东西!

http://www.cnnetsun.cn/news/4897.html

相关文章:

  • 【ACWing】4982. 进制
  • 如何用一张图征服审稿人❓​跟着Nature学作图丨森林图、韦恩图、upset图、生存曲线图、漏斗图、环形图、和弦图、词云图、关联图、瀑布图、条形图、面积图
  • 8 个专科生答辩 PPT 工具,AI 格式优化推荐
  • Wan2.2-T2V-A14B在灾难应急演练视频自动生成中的作用
  • 如何用Wan2.2-T2V-A14B实现高保真720P视频自动生成?
  • Dify+PDF解密全流程详解,99%的人都忽略的关键步骤
  • C#下UDP通信性能探究
  • L-ink_Card终极指南:STM32L0 Keil工程配置与NFC墨水屏开发实战
  • TorrServer 实用指南:高效种子流媒体服务器
  • Wan2.2-T2V-5B如何实现秒级响应?技术细节曝光
  • Wan2.2-T2V-A14B能否替代传统视频剪辑?一线创作者这样说
  • 14、iOS界面开发:自定义视图、自动布局、尺寸类及交互特性解析
  • 15、移动应用网络优化与用户体验提升
  • 5、Objective-C 内存管理与编程技巧深度解析
  • 3步搞定Bagisto容器化部署:新手也能搭建高可用电商平台
  • Directory Lister 终极指南:一键搭建高效文件浏览系统
  • 开源WMS终极指南:基于.NET 9.0的仓库管理系统完整教程
  • Wan2.2-T2V-A14B如何实现机械运动的精确建模?
  • 3个技巧让z命令成为你的终端导航神器
  • CinoLib:颠覆传统的高性能多面体网格处理引擎
  • 什么是内存泄漏?你在项目中是怎么排查OOM问题的?常用的JVM调优参数你知道哪些?
  • Esprima终极指南:轻松掌握JavaScript代码解析的5大核心技巧
  • 证件照在家拍攻略:记住这3点,你也能拍出让人眼前一亮的证件照
  • 智慧校园建设中的技术选型之道:让每一分投入都物有所值
  • Silvaco TCAD中文用户手册:半导体仿真入门到精通完整指南
  • openssh-master代码分析-sandbox-rlimit.c
  • baresip实战指南:SIP账户配置从入门到精通
  • 测试报告不再单调:用Allure2生成高大上的测试报告
  • Ultimate Vocal Remover GUI:快速上手音频分离工具完整指南
  • 错过将淘汰!PHP开发者必须掌握的低代码组件化新范式