南昌建站费用,WordPress十大免费CMS主题,wordpress批量发布文章,少儿编程免费软件2019独角兽企业重金招聘Python工程师标准   Android应用程序的用户界面可以看作是由View和View Group组成的#xff0c;从字面意思上就可以看出#xff0c;View Group是可以包含多个View的。借用官方教程的图可以更容易理解#xff1a;  说到这里#xff0c;我…  2019独角兽企业重金招聘Python工程师标准     Android应用程序的用户界面可以看作是由View和View Group组成的从字面意思上就可以看出View Group是可以包含多个View的。借用官方教程的图可以更容易理解   说到这里我们还没有解释何为View其实就是我们所看到的按钮、文本编辑框之类的。换句话说View是一些用户可以看得见的窗口小部件而ViewGroup则是用户看不见的它的作用是更好的组织和布局View。   由于我们是初学者所以可以简单的来归纳一下   Android应用程序通过 res/layout目录下的一个XML文件activity_main.xml来配置和管理程序窗口的布局。当然一个Android应用程序可能有多个程序窗口每个程序窗口都会有一个XML文件来管理它的界面布局。每个XML文件的名称可能不一样。我们这里讨论的是最简单的Android程序它是由ADT自动生成的只有一个程序窗口的程序所以它的布局文件也只有一个activity_main.xml。   如果使用ADT工程自动产生一个最简单的Android应用程序工程其默认布局的内容大致如下  RelativeLayout xmlns:androidhttp://schemas.android.com/apk/res/androidxmlns:toolshttp://schemas.android.com/toolsandroid:layout_widthmatch_parentandroid:layout_heightmatch_parenttools:context.MainActivity TextViewandroid:layout_widthwrap_contentandroid:layout_heightwrap_contentandroid:layout_centerHorizontaltrueandroid:layout_centerVerticaltrueandroid:textstring/hello_world //RelativeLayout  我们精简一下这个XML文件可能看起来会更容易一些  RelativeLayoutTextView//RelativeLayout  这个XML文件有两个元素分别是RelativeLayout和TextView其中RelativeLayout就是一个ViewGroup而TextView就是一个View。这个TextView包含在RelativeLayout之中。我们结合着程序在手机上的实际运行效果看   除了程序上方的标题栏之外整个程序窗口一片空白只有中间有一行文字信息Hello world!。   这种效果就是TextView居中显示在整个屏幕的中央。需要注意的是TextView是包裹在RelativeLayout之中的。所以确切的说应该是这个程序窗口中有一个RelativeLayout它占据了全部的屏幕而它里面又包含了一个TextView这个TextView位于RelativeLayout的中央即屏幕的中央。所以最终我们只看到了一个TextView它没有边框。   我们回过头来再看看activity_main.xml文件。   首先我们仅看RelativeLayout的属性  RelativeLayout xmlns:androidhttp://schemas.android.com/apk/res/androidxmlns:toolshttp://schemas.android.com/toolsandroid:layout_widthmatch_parentandroid:layout_heightmatch_parenttools:context.MainActivity   这五个属性中我们只看其中最简单的两个谁让咱是初学者呢更多的咱也看不懂android.layout_width和android.layout_height。它们分别指定了RelativeLayout的宽度和高度。它们都使用的是match_parent这个值。查金山词霸可以得知match_parent的意思是“适应父亲”。其实就是让RelativeLayout伸展到包含它的上级View的大小。而这个上级View就是这个程序的窗口了因为RelativeLayout已经是根元素了。这样RelativeLayout就占据了当前这个程序屏幕的全部。   再来看看RelativeLayout中包含的那一个TextView它也有五个属性  TextViewandroid:layout_widthwrap_contentandroid:layout_heightwrap_contentandroid:layout_centerHorizontaltrueandroid:layout_centerVerticaltrueandroid:textstring/hello_world /  属性中的android:layout_width和android:layout_height我们已经知道分别表示的是宽度和高度了。但是这里使用的值不一样是wrap_content。还是金山词霸wrap是包裹、缠绕、盘绕的意思content是书的内容的意思我们意译就是包裹文字内容以文字内容为大小换句话说TextView里的文本信息占据多大的空间TextView就多大。   这里我们可以试着把wrap_content换成match_parent以下是实际效果       初一看难于理解为什么Hello world!会出现在左上角我的分析是因为我们让TextView扩充到了RelativeLayout的全部大小这样其中的文字就只是一部分内容了那么按照惯例文字就是居左上对齐的。   android:layout_centerHorizontal和android:layout_centerVertical这两个属性从字面意思上就可以理解了一个是水平居中一个是垂直居中。值的选择要么是true要么是false。   这里我做了个试验不论宽度和高度设置为match_parent还是wrap_content居中不居中效果都与上图是一样的Hello world!居左上角显示。原理稍稍想想就明白了这里就不再罗嗦了。   最后讲一个比较重要的属性这个一次还讲不完以后还会补充。   TextView有一个属性是android:textstring/hello_world。注意这里是hello_world两个单词之间是有一个下划线的不是最终手机屏幕上面显示的那个Hello world!。简单的讲这里是将TextView要显示的内容定义成了一个字符串它的名字是hello_world而TextView真正要显示的是这个字符串的值。那么这个字符串的值又在何处呢   在res/values目录下有一个strings.xml文件答案就在这里。    ?xml version1.0 encodingutf-8?
resourcesstring nameapp_nameMy Temp App/stringstring namehello_worldHello world!/stringstring namemenu_settingsSettings/string/resources 分析这个文件在resources元素中包含有三个string元素它们都有一个名字还有一个值。相信大家一看就明白了。我们程序中显示的字符串信息都在这里定义了包括程序的名字屏幕上显示的字符串还有菜单键里显示的菜单名。   既然我们找到了hello_world那么我们可以简单试验一下只要修改Hello world!为别的信息就可以了  ?xml version1.0 encodingutf-8?
resourcesstring nameapp_nameMy Temp App/stringstring namehello_world这是我的第一个Android程序/stringstring namemenu_settingsSettings/string/resources  实际效果如下图所示       OK这一次笔记就到此吧这篇博文够长了^0^            转载于:https://my.oschina.net/allenyao/blog/103374