【Android 界面效果25】android中include标签的使用
在一个项目中我们可能会需要用到相同的布局设计,如果都写在一个xml文件中,代码显得很冗余,并且可读性也很差,所以我们可以把相同布局的代码单独写成一个模块,然后用到的时候可以通过<include /> 标签来重用layout代码。
app_title.xml:
- <?xml version="1.0" encoding="utf-8"?>
- <RelativeLayout android:id="@+id/titleLayout" android:layout_width="fill_parent" android:layout_height="wrap_content"
- android:background="@drawable/bt" xmlns:android="http://schemas.android.com/apk/res/android">
- <TextView android:text="@string/login" android:id="@+id/title" android:textSize="20px" android:textColor="@color/white"
- android:layout_width="wrap_content" android:layout_centerInParent="true" android:layout_height="wrap_content"/>
- <Button android:text="返回" android:id="@+id/refresh" android:layout_width="wrap_content" android:layout_height="wrap_content"
- android:layout_alignParentRight="true" android:focusable="false" android:textColor="@color/white"
- android:background="@drawable/okbutton" android:layout_marginRight="3px"/>
- </RelativeLayout>
app_tradelogin.xml:
- <?xml version="1.0" encoding="utf-8"?>
- <!-- android:layout_below与 android:layout_above 是必须设置的,否则界面不规则,不设置android:layout_above本界面没有滑动效果-->
- <ScrollView android:layout_below="@+id/titleLayout" android:layout_above="@+id/appbottom" android:layout_width="fill_parent"
- android:layout_height="fill_parent" android:layout_centerInParent="true" xmlns:android="http://schemas.android.com/apk/res/android">
- <LinearLayout android:id="@+id/theWholeLinearLayout" android:orientation="vertical" android:layout_width="fill_parent"
- android:layout_height="wrap_content" android:paddingLeft="10px" android:paddingTop="6px" android:paddingRight="10px" >
- <LinearLayout android:id="@+id/linearLayoutLeft" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="wrap_content">
- <TableLayout android:id="@+id/widget43" android:layout_width="fill_parent"
- android:layout_height="fill_parent" android:orientation="vertical"
- xmlns:android="http://schemas.android.com/apk/res/android" android:stretchColumns="1">
- <TableRow >
- <!-- 引用定义好的TextView样式,如果这里的属性和样式里定义的属性重复,则这里会替换样式里定义的属性-->
- <TextView android:id="@+id/traderName" android:text="@string/traderName" style="@style/StyleTextInfo1" mce_style="@style/StyleTextInfo1"/>
- <Spinner android:id="@+id/traderNameS" android:layout_width="fill_parent" android:layout_height="wrap_content">
- </Spinner>
- </TableRow>
- <TableRow>
- <TextView android:id="@+id/departName" android:text="@string/departName" style="@style/StyleTextInfo1" mce_style="@style/StyleTextInfo1"/>
- <Spinner android:id="@+id/departNameS" android:layout_width="fill_parent" android:layout_height="wrap_content"/>
- </TableRow>
- <TableRow >
- <TextView android:id="@+id/strComponyName" android:text="@string/accType" style="@style/StyleTextInfo1" mce_style="@style/StyleTextInfo1"/>
- <Spinner android:id="@+id/accTyte" android:layout_width="fill_parent" android:layout_height="wrap_content"/>
- </TableRow>
- <TableRow >
- <TextView android:id="@+id/strUserAcc" android:text="@string/userAcc" style="@style/StyleTextInfo1" mce_style="@style/StyleTextInfo1"/>
- <EditText android:id="@+id/accEditText" android:text="" android:numeric="decimal" style="@style/StyleEditText1" mce_style="@style/StyleEditText1"/>
- </TableRow>
- <TableRow >
- <TextView android:id="@+id/userPwd" android:text="@string/userPWD" style="@style/StyleTextInfo1" mce_style="@style/StyleTextInfo1"/>
- <EditText android:id="@+id/userPwdET" android:text="" android:password="true" style="@style/StyleEditText1" mce_style="@style/StyleEditText1"/>
- </TableRow>
- <TableRow >
- <TextView android:id="@+id/commPwd" android:text="@string/commPWD" style="@style/StyleTextInfo1" mce_style="@style/StyleTextInfo1"/>
- <EditText android:id="@+id/commPwdET" android:text="" android:password="true" style="@style/StyleEditText1" mce_style="@style/StyleEditText1"/>
- </TableRow>
- </TableLayout>
- </LinearLayout>
- <LinearLayout android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="wrap_content">
- <LinearLayout android:id="@+id/linearLayoutTab1" android:layout_height="wrap_content"
- android:layout_width="fill_parent" android:orientation="horizontal">
- <LinearLayout android:id="@+id/linearLayoutTab2" android:layout_height="wrap_content"
- android:layout_width="fill_parent" android:orientation="horizontal" android:layout_weight="1">
- <CheckBox android:id="@+id/recordAcc" android:layout_width="wrap_content" android:layout_height="wrap_content"/>
- <TextView android:id="@+id/commPwd" android:text="@string/saveUserAcc" style="@style/StyleTextInfo1" mce_style="@style/StyleTextInfo1"/>
- </LinearLayout>
- <LinearLayout android:id="@+id/linearLayoutTab2" android:layout_height="wrap_content"
- android:layout_width="fill_parent" android:orientation="horizontal" android:layout_weight="1">
- <CheckBox android:id="@+id/hideAcc" android:layout_width="wrap_content" android:layout_height="wrap_content"/>
- <TextView android:id="@+id/commPwd" android:text="@string/ycUserAcc" style="@style/StyleTextInfo1" mce_style="@style/StyleTextInfo1"/>
- </LinearLayout>
- </LinearLayout>
- <LinearLayout android:id="@+id/linearLayoutTab1" android:layout_height="wrap_content"
- android:layout_width="fill_parent" android:orientation="horizontal">
- <LinearLayout android:layout_width="220px" android:layout_height="wrap_content" android:orientation="horizontal"
- android:gravity="center">
- <Button android:id="@+id/confirmexch" android:gravity="center" android:layout_width="wrap_content"
- android:layout_height="50px" android:textSize="22dp" android:text="@string/login" android:layout_weight="1"
- android:focusable="false" android:textColor="@color/white" android:background="@drawable/buttonl"/>
- </LinearLayout>
- <LinearLayout android:id="@+id/linearLayoutTab" android:layout_height="wrap_content"
- android:layout_width="fill_parent" android:gravity="center">
- <ImageView android:layout_width="wrap_content" android:layout_height="50px" android:id="@+id/myImage"/>
- </LinearLayout>
- </LinearLayout>
- </LinearLayout>
- </LinearLayout>
- </ScrollView>
app_bottom.xml:
- <?xml version="1.0" encoding="utf-8"?>
- <LinearLayout android:id="@+id/appbottom" android:orientation="vertical" android:layout_width="fill_parent"
- android:layout_height="wrap_content" android:layout_alignParentBottom="true"
- xmlns:android="http://schemas.android.com/apk/res/android">
- <LinearLayout android:orientation="horizontal" android:layout_width="fill_parent"
- android:layout_height="wrap_content" android:background="@drawable/light">
- <ImageView android:id="@+id/about" android:layout_width="30px" android:layout_height="wrap_content" android:src="@drawable/ttt"
- android:layout_alignParentLeft="true"/>
- <TextView android:id="@+id/light" android:layout_width="fill_parent" android:layout_height="wrap_content" android:textColor="@color/black"/>
- </LinearLayout>
- <LinearLayout android:orientation="horizontal" android:layout_width="fill_parent"
- android:layout_height="wrap_content" android:background="@drawable/mainmenu">
- <Button android:id="@+id/quotButton" android:layout_weight="1" android:layout_width="52px" android:layout_height="wrap_content"
- android:textColor="@color/white" android:text="" android:background="@drawable/button1"/>
- <Button android:id="@+id/entrustButton" android:layout_weight="1" android:layout_width="52px" android:layout_height="wrap_content"
- android:textColor="@color/white" android:text="" android:background="@drawable/button1"/>
- <Button android:id="@+id/queryButton" android:layout_weight="1" android:layout_width="52px" android:layout_height="wrap_content"
- android:textColor="@color/white" android:text="" android:background="@drawable/button1"/>
- <Button android:id="@+id/yinZhengButton" android:layout_weight="1" android:layout_width="52px" android:layout_height="wrap_content"
- android:textColor="@color/white" android:text="" android:background="@drawable/button1"/>
- <Button android:id="@+id/recordButton" android:layout_weight="1" android:layout_width="52px" android:layout_height="wrap_content"
- android:textColor="@color/white" android:text="" android:background="@drawable/button1"/>
- <Button android:id="@+id/logoutButton" android:layout_weight="1" android:layout_width="52px" android:layout_height="wrap_content"
- android:textColor="@color/white" android:text="" android:background="@drawable/button1"/>
- </LinearLayout>
- </LinearLayout>
tradelogin_portrait.xml:
- <?xml version="1.0" encoding="utf-8"?>
- <RelativeLayout android:layout_width="fill_parent" android:layout_height="fill_parent" style="@style/StyleLayoutMain" mce_style="@style/StyleLayoutMain"
- xmlns:android="http://schemas.android.com/apk/res/android">
- <!-- include标签内不能设置RelativeLayout属性,如android:layout_alignParentBottom,因为不起作用 -->
- <!-- include标签内设置id属性后(android:id),其引用的布局layout内的id属性就不起作用了,怀疑是其引用的layout外层包裹了一层include标签
- 或者是覆盖了其内的属性id-->
- <!-- 如果没有include标签,所有布局代码都写在一个xml文件中,界面会显得很冗余,可读性很差。而且界面加载的时候是按照顺序加载的,前面的布局不能
- 调用其后面的布局id。而采用include后,一个include中可以引用其后的include中的布局id属性 -->
- <include android:id="@id/titleLayout" layout="@layout/app_title" />
- <include layout="@layout/app_tradelogin"/>
- <include layout="@layout/app_bottom"/>
- </RelativeLayout>
效果如下:

【Android 界面效果25】android中include标签的使用的更多相关文章
- android中include标签使用详解
android中include标签是为了便于控件的覆用的一个很好解决方案. 但是也有一些需要注意的地方,下面是本人在项目中碰到过的一个问题,做此记录,便于以后查看. include标签用法. ...
- Android中include标签的使用
在Android的开发中,我们知道布局文件可以让我们很方便的对各个UI控件进行位置安排跟属性设置,而在程序中可以直接取得控件并赋予对应操作功能.但是,如果是一个复杂的界面设计,我们把所有布局都放在一个 ...
- Android中include标签的使用(打开引用布局,隐藏当前布局)
在开发app的时候,有时候一个布局会反复用到,可以把反复用到的布局单独写一个xml文件,什么时候用到就用includ标签引入xml 下面是我写的反复用到的一个xml,里面有2个button,一个Tex ...
- 【Android 界面效果19】Android中shape的使用
Android中常常使用shape来定义控件的一些显示属性,今天看了一些shape的使用,对shape有了大体的了解,稍作总结: 先看下面的代码: <shape> ...
- 【Android 界面效果32】ImageView中XML属性src和background的区别
background会根据ImageView组件给定的长宽进行拉伸,而src就存放的是原图的大小,不会进行拉伸. src是图片内容(前景),bg是背景,可以同时使用. 此外:scaleType只对sr ...
- 【Android 界面效果30】Android中ImageSwitcher结合Gallery展示SD卡中的资源图片
本文主要是写关于ImageSwitcher结合Gallery组件如何展示SDCard中的资源图片,相信大家都看过API Demo 中也有关于这个例子的,但API Demo 中的例子是展示工程中Draw ...
- 【Android 界面效果12】EditText中的多行输入问题
------- 源自梦想.永远是你IT事业的好友.只是勇敢地说出我学到! ---------- 我们在使用EditText进行多行输入的时候,通常的写法如下: <EditText android ...
- 【Android 界面效果31】Android--侧滑菜单应用的实现
侧滑菜单应用现在非常多,而且实现方式也多种多样.通过在网上的多方查找,我找到郭霖少侠的这篇文章:http://blog.csdn.net/guolin_blog/article/details/874 ...
- 【Android 界面效果21】Android ViewPager使用详解
这是谷歌官方给我们提供的一个兼容低版本安卓设备的软件包,里面包囊了只有在安卓3.0以上可以使用的api.而viewpager就是其中之一利用它,我们可以做很多事情,从最简单的导航,到页面菜单等等.那如 ...
随机推荐
- class int
class int(object): """ int(x=0) -> integer int(x, base=10) -> integer Convert a ...
- 在ASP.NET MVC中验证checkbox 必须选中 (Validation of required checkbox in Asp.Net MVC)
转载自 http://blog.degree.no/2012/03/validation-of-required-checkbox-in-asp-net-mvc/ Why would you want ...
- makefile中一些符号的含义
关于gnu make的详细介绍参看http://www.gnu.org/software/make/manual/make.html 规则 让我们先来粗略地看一看Makefile的规则. targ ...
- DP练习(概率,树状,状压)
http://vjudge.net/contest/view.action?cid=51211#overview 花了好长时间了,终于把这个专题做了绝大部分了 A:HDU 3853 最简单的概率DP求 ...
- 浅析 JavaScript 中的闭包(Closures)
a { text-decoration: none; color: #4094c7 } h4,h5 { margin: 0; font-weight: 700; color: inherit; lin ...
- C:矩形相交、相包含、相离关系判断
矩形相交 包含 问题.参考 假定矩形是用一对点表达的(minx, miny) (maxx, maxy),那么两个矩形 rect1{(minx1, miny1)(maxx1, maxy1)} ...
- 使用virtualenvwrapper隔离python环境
今天使用的是virtualenvwrapper,相较于使用virtualenv, 好处就是把所有环境都放在同一目录下管理,以便更好的管理及切换. 首先需要确认有 pip 是否已经安装, 若没有需要先安 ...
- VS2010开发环境最佳字体及配色[转]
从地址:http://www.dev-club.net/xiangxixinxi/42010072906150537/201103010518006.html 获取的,整理如下: 环境:VS2010字 ...
- 28.怎样在Swift中实现单例?
1.回忆一下OC中的单例实现 //AFNetworkReachabilityManager中的单例,省略了其他代码 @interface AFNetworkReachabilityManager : ...
- ps:探索按钮按起落下的技巧
(从死了一次又一次终于挂掉的百度空间中抢救出来的,发表日期 2014-07-10) 先上图: 那个看上去想按下去的,那个看上去像自然地呢? 显而易见: 第一像按下去的,第二个像自然地. 原因: 渐变: ...