声明布局
可以通过两种方式声明布局:
(1)在 XML 中声明 UI 元素:优点是可以更好地将应用的外观与控制应用行为的代码隔离。例如,您可以创建适用于不同屏幕方向、不同设备屏幕尺寸和不同语言的 XML 布局。
(2)运行时实例化布局元素。(通过编程创建元素,并修改属性)。
-> 所以大多数情况下会选择第一种方法声明布局,即在 Android 项目 res/layout/目录中以 .xml扩展名保存文件。
编译
在onCreate()种进行加载:
public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main_layout); }
属性
每个视图对象和 ViewGroup 对象都支持各自的各类 XML 属性。某些属性是视图对象的专用属性(例如,TextView 支持 textSize属性)
⚠ 注意:属性可以被继承。例如某些属性通用于所有 View 对象,因为它们继承自根 View 类(如 id属性)
- id -
任何视图对象都可能具有关联的整型 ID,此 ID 用于在结构树中对 View 对象进行唯一标识。标准语法为:
android:id="@+id/my_button"
说明:@ 符号将其标识为 ID 资源。加号表示这是一个新的资源名称,创建该名称并将其添加到我们 R.java文件中。
Android 框架还提供了许多其他 ID 资源。引用不需要加号,但必须添加 android软件包命名空间, 如下:
android:id="@android:id/empty"
- 布局参数 -
名为 layout_something 的 XML 布局属性
每个 ViewGroup 类都会实现一个扩展 ViewGroup.LayoutParams
的嵌套类。此子类包含的属性类型会根据需要为视图组的每个子视图定义尺寸和位置。
⚠ 注意:所有视图组都必须包括宽度和高度(layout_width
和 layout_height),常使用以下常量之一来设置宽度或高度:
● wrap_content 视图将其大小调整为内容所需的尺寸
● match_parent(在 API 级别 8 之前名为 fill_parent
)视图尽可能采用其父视图组所允许的最大尺寸
-> 建议不要使用绝对单位(如像素)来指定布局宽度和高度, 而是使用相对测量单位,如密度无关像素单位 (dp
)、 wrap_content 或 match_parent, 有助于确保应用在各类尺寸的设备屏幕上正确显示。
- 布局位置 -
getLeft(): 返回视图的矩形的水平向左(或称 X 轴) 坐标。
getTop(): 返回表示视图的矩形的垂直向上(或称 Y 轴)坐标。
getWidth():视图的宽
getHeight():视图的高
getRight()=getLeft()+getWidth():返回视图矩形的右边缘
getBottom()=getTop()+getHeight():返回视图矩形的下边缘
- 尺寸、内边距和外边距 -
视图实际上具有两对宽度和高度值。
(1)测量宽度和测量高度: getMeasuredWidth()
和 getMeasuredHeight() -> 定义视图想要在其父项内具有的大小。
(2)宽度和高度: getWidth()和 getHeight() -> 定义视图在绘制时和布局后在屏幕上的实际尺寸
(3)内边距 [setPadding(int, int, int, int)](https://developer.android.com/reference/android/view/View.html#setPadding(int, int, int, int))
方法设置内边距,并通过调用getPaddingLeft()、getPaddingTop()、getPaddingRight()和 getPaddingBottom()进行查询。
尽管视图可以定义内边距,但它并不支持外边距。 不过,视图组可以提供此类支持。
常见布局
Android 中的布局分为两种:
● 静态布局:线性布局,相对布局,web布局
● 动态布局(AdapterView,即适配器支持的布局):列表布局/ListView,网格布局(GridView)-> 可以往下拉,内容未事先预定
我们这里只说明第二种:
动态布局/AdapterView:
Adapter作为该AdapterView与数据之间的桥梁。Android提供了很多个Adapter的子类,用于检索不同种类的数据,并且构建不同的AdapterView视图。最常见的有两种:ArrayAdapter和SimpleCursorAdapter。
1. ArrayAdapter
数据来源:数组
举例:参数分别为
(1)Context, (2)数组中每个字符串所在的 TextView的布局,(3)字符串数组
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, myStringArray);
然后在ListView种调用setAdapter():
ListView listView = (ListView) findViewById(R.id.listview); listView.setAdapter(adapter);
附文待解释:要想自定义每个项的外观,您可以重写数组中各个对象的 toString()方法。或者,要想为 TextView之外的每个项创建视图(例如,如果您想为每个数组项创建一个 ImageView
),请扩展 ArrayAdapter类并重写 [getView()](https://developer.android.com/reference/android/widget/ArrayAdapter.html#getView(int, android.view.View, android.view.ViewGroup))以返回您想要为每个项获取的视图类型
2. SimpleCursorAdapter
数据来源:Cursor(该接口提供对由数据库查询返回的结果集的随机读写访问。)
使用时必须指定要为Cursor中的每个行使用的布局,以及应该在哪些布局视图中插入Cursor中的哪些列。
处理点击事件
您可以通过实现 AdapterView.OnItemClickListener界面来响应 AdapterView中每一项上的点击事件。
// Create a message handling object as an anonymous class.private OnItemClickListener mMessageClickedHandler = new OnItemClickListener() { public void onItemClick(AdapterView parent, View v, int position, long id) { // Do something in response to the click }};listView.setOnItemClickListener(mMessageClickedHandler);