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

一、五大布局Layout

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

1.1 LinearLayout 线性布局

android:orientation="horizontal"        
制定线性布局的排列方式     
水平 horizontal       
垂直 vertical
gravity 控制当前控件内容显示区域
layout_gravity 当前控件在父元素的位置
Layout_weightSum
Layout_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.5

float 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 1000
eg2: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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值