Android核心基础-4.Android 用户界面View

来源:互联网 发布:php输出99乘法表 编辑:程序博客网 时间:2024/06/01 12:53

一、五大布局Layout

  1. LinearLayout————–线性布局
  2. RelativeLayout———–相对布局
  3. AbsoluteLayout———绝对布局
  4. TableLayout————–表格布局
  5. FrameLayout————帧布局

1.1 LinearLayout 线性布局

android:orientation="horizontal"        制定线性布局的排列方式     水平 horizontal       垂直 verticalgravity 控制当前控件内容显示区域layout_gravity 当前控件在父元素的位置Layout_weightSumLayout_weight 额外空间分配(权重)android:visibility="invisible"  控制布局是否显示    显示 visible  不显示,但占空间 invisible  隐藏 gone

1.2 RelativeLayout 相对布局

android:layout_toRightOf    在指定控件的右边android:layout_toLeftOf     在指定控件的左边android:layout_above        在指定控件的上边android:layout_below        在指定控件的下边android:layout_alignBaseline跟指定控件水平对齐android:layout_alignLeft    跟指定控件左对齐android:layout_alignRight   跟指定控件右对齐android:layout_alignTop     跟指定控件顶部对齐android:layout_alignBottom  跟指定控件底部对齐android:layout_alignParentLeft      是否跟父布局左对齐android:layout_alignParentTop       是否跟父布局顶部对齐android:layout_alignParentRight     是否跟父布局右对齐android:layout_alignParentBottom    是否跟父布局底部对齐android:layout_centerVertical   在父布局中垂直居中android:layout_centerHorizontal 在父布局中水平居中android:layout_centerInParent   在父布局中居中

1.3 AbsoluteLayout 绝对布局

android:layout_x    指定控件在父布局的x轴坐标android:layout_y    指定控件在父布局的y轴坐标

1.4 FrameLayout 帧布局

帧布局每次添加的控件都显示在最上面,最后显示在界面上的是最后添加的一个控件

1.5 TableLayout 表格布局

android:shrinkColumns       收缩列android:stretchColumns      拉伸列android:collapseColumns     隐藏列android:layout_column       指定列(作用在列的身上)android:layout_span         合并列(作用在列的身上)TableRow单元行里的单元格的宽度小于默认的宽度时就不起作用,其默认是fill_parent,高度可以自定义大小  

二、Android中的显示单位

 px (pixels)像素      一般HVGA代表320x480像素,这个用的比较多。 dip或dp (device independent pixels)设备独立像素    这个和设备硬件有关,一般为了支持WVGA、HVGA和QVGA 推荐使用这个,不依赖像素。 sp (scaled pixels — best for text size)比例像素    主要处理字体的大小,可以根据系统的字体自适应。除了上面三个显示单位,下面还有几个不太常用: in (inches)英寸 mm (millimeters)毫米   pt (points)点,1/72英寸为了适应不同分辨率,不同的像素密度,推荐使用dip ,文字使用sp。
常见的密度比值:    240*320 的密度比值是: 0.75    320*480 的密度比值是: 1.0    480*800 的密度比值是: 1.5float density = getResources().getDisplayMetrics().density;

三、Android 测试

3.1 测试简介

  • 黑盒测试: 是以用户的角度,从输入数据与输出数据的对应关系出发进行测试的。

  • 白盒测试: 又称结构测试、透明盒测试、逻辑驱动测试或基于代码的测试。

  • 单元测试: 又称模块测试,是开发者编写的一小段代码,用于检验被测代码的一个很小的、很明确的功能是否正确。

  • 功能测试: 根据产品特性、操作描述和用户方案,测试一个产品的特性和可操作行为以确定它们满足设计需求。

  • 压力测试: 主体向被观察者布置一定量任务和作业,借以观察个体完成任务的行为。

  • 集成测试: 是单元测试的逻辑扩展。它的最简单的形式是:两个已经测试过的单元组合成一个组件,并且测试它们之间的接口

3.2 压力测试

DOS命令:monkey -p <应用程序包名> -v 事件数量测试整个系统:adb shell monkey -v 100 (-v指定模拟测试的事件数量)测试某个程序:adb shell monkey -p <程序的包名> -v 事件的数量eg1:adb shell monkey -v 1000eg2:adb shell monkey -p net.dxs.sms -v 1000

3.3 单元测试

在实际开发中,开发Android软件的过程需要不断的进行测试,而使用Junit测试框架,是正规Android开发的必用技术,在Junit中可以得到组件,可以模拟发送事件和检测程序处理的正确性。

  1. 第一步:首先在AndroidManifase.xml中加入如下代码
<?xml version="1.0" encoding="utf-8"?><manifest xmlns:android="http://schemas.android.com/apk/res/android"    package="net.dxs.testprovider"    android:versionCode="1"    android:versionName="1.0" >    <uses-sdk        android:minSdkVersion="8"        android:targetSdkVersion="18" />    <instrumentation        android:name="android.test.InstrumentationTestRunner"        android:targetPackage="net.dxs.testprovider" />    <application        android:allowBackup="true"        android:icon="@drawable/ic_launcher"        android:label="@string/app_name"        android:theme="@style/AppTheme" >        <uses-library android:name="android.test.runner" />        <activity            android:name="net.dxs.testprovider.MainActivity"            android:label="@string/app_name" >            <intent-filter>                <action android:name="android.intent.action.MAIN" />                <category android:name="android.intent.category.LAUNCHER" />            </intent-filter>        </activity>    </application></manifest>

上面targetPackage指定的包要和应用的package相同。
2. 第二步:编写单元测试代码(选择要测试的方法,右键点击“Run As”->”Android Junit Test”);

package net.dxs.testprovider;import android.content.ContentResolver;import android.content.ContentValues;import android.net.Uri;import android.test.AndroidTestCase;public class ProviderTest extends AndroidTestCase {    public void test1() {        //获取ContentResolver        ContentResolver resolver = getContext().getContentResolver();        //指定ContentProvider的Uri        Uri uri = Uri.parse("content://DxsProvider");        //对指定Uri调用删除方法        resolver.delete(uri, null, null);        resolver.query(uri, null, null, null, null);    }    public void testInsert(){        ContentResolver resolver = getContext().getContentResolver();        Uri uri = Uri.parse("content://DxsProvider");        ContentValues values = new ContentValues();        values.put("name", "深情小建");        values.put("balance", 20000);        resolver.insert(uri, values);    }}
0 0
原创粉丝点击