当前位置: 编程技术>移动开发
本页文章导读:
▪Animation兑现界面转动 Animation实现界面转动
刚做完,只是实验一下,很粗糙,代码也没整理,很乱
......
▪ 透过适配器给AdapterView绑定数据 通过适配器给AdapterView绑定数据
使用AdapterView来绑定数据AdapterView是一个ViewGroup子类, 它的子View是有一个Adapter决定的, 而该Adapter绑定某种类型的数据. AdapterView在你希望显示储存的数据(相对.........
▪ RelativeLayout的懂得 RelativeLayout的理解
一、概述 在开发中推荐尽量使用RelativeLayout可以增强其适应不同屏幕的灵活性。该布局根据widgets之间关系和widget与父容器之间的关系来确定布局。例如可以设置A在父.........
[1]Animation兑现界面转动
来源: 互联网 发布时间: 2014-02-18
Animation实现界面转动
刚做完,只是实验一下,很粗糙,代码也没整理,很乱
刚做完,只是实验一下,很粗糙,代码也没整理,很乱
[2] 透过适配器给AdapterView绑定数据
来源: 互联网 发布时间: 2014-02-18
通过适配器给AdapterView绑定数据
使用AdapterView来绑定数据
AdapterView是一个ViewGroup子类, 它的子View是有一个Adapter决定的, 而该Adapter绑定某种类型的数据. AdapterView在你希望显示储存的数据(相对于资源字符串或者图片)时比较有用.
Gallery, ListView, 和 Spinner是AdapterView子类的例子, 你可以使用它们绑定特定类型的数据并按照一定方式来显示它们.
AdapterView对象有两个主要任务:
* 在布局中显示数据
* 处理用户的选择
Filling the Layout with Data 为布局填充数据
将数据插入布局一般是通过将AdapterView类绑定到一个Adapter完成的. Adapter从一个外部资源获取数据(可能是代码直接提供,也可能是从设备上的一个数据库查到的数据组成的一个列表).
下列代码做了两件事情:
1. 使用一个已有的View创建了一个Spinner, 并将其绑定到一个新的ArrayAdapter, 后者从本地资源中读取一个颜色的数组.
2. 从一个View创建另一个 Spinner对象并将它绑定到一个新的SimpleCursorAdapter, 后者将读取设备上的联系人名字.
// Get a Spinner and bind it to an ArrayAdapter that
// references a String array.
Spinner s1 = (Spinner) findViewById(R.id.spinner1);
ArrayAdapter adapter = ArrayAdapter.createFromResource(
this, R.array.colors, android.R.layout.simple_spinner_item);
adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
s1.setAdapter(adapter);
// Load a Spinner and bind it to a data query.
private static String[] PROJECTION = new String[] {
People._ID, People.NAME
};
Spinner s2 = (Spinner) findViewById(R.id.spinner2);
Cursor cur = managedQuery(People.CONTENT_URI, PROJECTION, null, null);
SimpleCursorAdapter adapter2 = new SimpleCursorAdapter(this,
android.R.layout.simple_spinner_item, // Use a template
// that displays a
// text view
cur, // Give the cursor to the list adatper
new String[] {People.NAME}, // Map the NAME column in the
// people database to...
new int[] {android.R.id.text1}); // The "text1" view defined in
// the XML template
adapter2.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
s2.setAdapter(adapter2);
注意必须People._ID 列必须和CursorAdapter 一起使用, 否则你会得到异常.
如果在你的应用程序生命周期中, 你改变了你的Adapter管理的数据, 你应该调用notifyDataSetChanged(). 这将使附加的View刷新.
Handling User Selections 处理用户选择
使用AdapterView.OnItemClickListener来获取用户的选择.
// 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)
{
// Display a messagebox.
Toast.makeText(mContext,"You've got an event",Toast.LENGTH_SHORT).show();
}
};
// Now hook into our object and set its onItemClickListener member
// to our class handler object.
mHistoryView = (ListView)findViewById(R.id.history);
mHistoryView.setOnItemClickListener(mMessageClickedHandler)
AdapterView:
声明
欢迎转载,但请保留文章原始出处:)
博客园:http://www.cnblogs.com/
Android中文翻译组:http://code.taobao.org/project/view/404/
正文
一、结构
public abstract class AdapterView<T extends Adapter> extends ViewGroup
java.lang.Object
android.view.View
android.view.ViewGroup
android.widget.AdapterView<T extends android.widget.Adapter>
直接子类
AbsListView, AbsSpinner
间接子类
ExpandableListView, Gallery, GridView, ListView, Spinner
二、概述
AdapterView 是内容由 Adapter 来决定的视图类。
参见 ListView、GridView、Spinner 和 Gallery 等常见子类。
三、常量
public static final int INVALID_POSITION
代表无效的位置。有效值的范围是 0 到当前适配器项目数减 1 。
常量值: -1 (0xffffffff)
public static final long INVALID_ROW_ID
代表空或者无效的行ID。
常量值: -9223372036854775808 (0x8000000000000000)
public static final int ITEM_VIEW_TYPE_HEADER_OR_FOOTER
当条项是列表头或列表尾时,调用 getItemViewType(int) 函数的返回值。
常量值: -2 (0xfffffffe)
public static final int ITEM_VIEW_TYPE_IGNORE
当适配器禁止条项的视图再利用时,调用 getItemViewType(int) 函数的返回值。
常量值: -1 (0xffffffff)
四、构造函数
public AdapterView (Context context)
构造函数
public AdapterView (Context context, AttributeSet attrs)
构造函数
public AdapterView (Context context, AttributeSet attrs, int defStyle)
构造函数
五、公共方法
public void addView (View child)
该类不支持该方法,如果调用将抛出 UnsupportedOperationException 异常。
参数
child 忽略
异常
UnsupportedOperationException 调用该方法时
public void addView (View child, int index)
该类不支持该方法,如果调用将抛出 UnsupportedOperationException 异常。
参数
child 忽略。
index 忽略。
抛出
UnsupportedOperationException 调用该方法时
public void addView (View child, int index, ViewGroup.LayoutParams params)
该类不支持该方法,如果调用将抛出 UnsupportedOperationException 异常。
参数
child 忽略。
index 忽略。
params 忽略。
抛出
UnsupportedOperationException 调用该方法时
public void addView (View child, ViewGroup.LayoutParams params)
该类不支持该方法,如果调用将抛出 UnsupportedOperationException 异常。
参数
child 忽略。
params 忽略。
抛出
UnsupportedOperationException 调用该方法时
public boolean dispatchPopulateAccessibilityEvent (AccessibilityEvent event)
分发 AccessibilityEvent 事件到 该视图 的子视图中。
参数
event 事件。
返回值
如果事件分发完成,返回真。
public abstract T getAdapter ()
返回当前与该小部件关联的适配器。
返回值
用于提供视图内容的适配器。
public int getCount ()
返回值
与 AdapterView 相关联的适配器的条目数量。(该值是数据条目的数量, 可能大于可见的视图的数量。)
public View getEmptyView ()
当前适配器无内容时,AdapterView 会显示特殊的空视图。 空视图用于告诉用户,该 AdapterView 没有数据。
返回值
适配器为空时显示的视图。
public int getFirstVisiblePosition ()
返回显示在屏幕上的第一个元素在适配器中所处的位置。
返回值
在适配器数据集中的位置。
public Object getItemAtPosition (int position)
取得列表中指定位置的数据。
参数
position 要取得数据的位置。
返回值
列表中指定位置的数据。
public long getItemIdAtPosition (int position)
(译者注:关于此方法的分析,参见这里。)
public int getLastVisiblePosition ()
返回显示在屏幕上的最后一个元素在适配器中所处的位置。
返回值
在适配器数据集中的位置。
public final AdapterView.OnItemClickListener getOnItemClickListener ()
返回值
点击 AdapterView 中的条目时执行的回调函数;没有设置时返回空。
public final AdapterView.OnItemLongClickListener getOnItemLongClickListener ()
返回值
取得长按 AdapterView 中的条目时执行的回调函数的监听器;未设置则返回空。
public final AdapterView.OnItemSelectedListener getOnItemSelectedListener ()
public int getPositionForView (View view)
取得适配器项目对应的视图或其子视图在适配器的数据中所处的位置。
参数
view 适配器条目或其后代的视图。调用时该项目在 AdapterView 中必须可见。
返回值
视图在适配器数据集中的位置;如果视图不在数据列表中或当前不可见,则返回 INVALID_POSITION。
public Object getSelectedItem ()
返回值
当前选中条目对应的数据;无选中条目时返回空。
public long getSelectedItemId ()
返回值
当前选中条目相应的 ID;无选中条目则返回 INVALID_ROW_ID。
public int getSelectedItemPosition ()
返回当前选中项目在适配器数据中的位置。
返回值
返回从零开始的位置(索引)信息,没有选择条目时返回 INVALID_POSITION。
public abstract View getSelectedView ()
返回值
当前选中条目对应的视图;无选中条目时返回空。
public boolean performItemClick (View view, int position, long id)
如果定义了 OnItemClickListener 则调用它。
参数
view AdapterView 中被点击的视图。
position 视图在适配器中的索引。
id 点击的条目的行 ID。
返回值
如果成功调用了定义的 OnItemClickListener 则返回真;否则返回假。
public void removeAllViews ()
该类不支持该方法,如果调用将抛出 UnsupportedOperationException 异常。
抛出
UnsupportedOperationException调用该方法时
public void removeView (View child)
该类不支持该方法,如果调用将抛出 UnsupportedOperationException 异常。
参数
child 忽略。
抛出
UnsupportedOperationException调用该方法时
public void removeViewAt (int index)
该类不支持该方法,如果调用将抛出 UnsupportedOperationException 异常。
参数
index 忽略。
抛出
UnsupportedOperationException调用该方法时
public abstract void setAdapter (T adapter)
设置用于为该小部件的视图提供用于显示的数据的适配器。
参数
adapter 用于创建视图内容的适配器。
public void setEmptyView (View emptyView)
设置适配器内容为空时显示的视图。
public void setFocusable (boolean focusable)
设置该视图是否可以获取焦点。 设为假时,可以确保在触控模式中该视图不能得到焦点。
参数
focusable 设为真时,该视图可以得到焦点。
public void setFocusableInTouchMode (boolean focusable)
设置在触控模式下该视图是否可以获取焦点。 设为真时,可以保证视图可以得到焦点。
参数
focusable 设为真时,该视图在触控模式下可以得到焦点。
public void setOnClickListener (View.OnClickListener l)
注册点击该视图时执行的回调函数。如果该视图不可点击,会将其改为可以点击的状态。
参数
l 事件发生时运行的回调函数。
public void setOnItemClickListener (AdapterView.OnItemClickListener listener)
注册单击 AdapterView 中的条目时执行的回调函数。
参数
listener 将要调用的回调。
public void setOnItemLongClickListener (AdapterView.OnItemLongClickListener listener)
注册长按 AdapterView 中的条目时执行的回调函数。
参数
listener 事件发生时运行的回调函数。
public void setOnItemSelectedListener (AdapterView.OnItemSelectedListener listener)
注册选中 AdapterView 中的条目时执行的回调函数。
参数
listener 事件发生时运行的回调函数。
public abstract void setSelection (int position)
设置当前选择条目。为了支持无障碍功能,重写该方法的子类必须首先调用父类的该方法。
参数
position 选择的数据条目的索引(从零开始)。
六、保护方法
protected boolean canAnimate ()
指示视图组是否能够在首次布局后为其子视图提供动画效果的显示。
返回值
如果子视图可以使用动画效果则返回真,否则返回假。
protected void dispatchRestoreInstanceState (SparseArray<Parcelable> container)
为了防止适配器生成的视图被解冻而重写。
参数
container 保存有之前存储的状态信息的 SparseArray。
protected void dispatchSaveInstanceState (SparseArray<Parcelable> container)
为了防止适配器生成的视图被冻结而重写。
参数
container 保存视图状态的 SparseArray。
protected void onLayout (boolean changed, int left, int top, int right, int bottom)
该视图设置其子视图的大小及位置时调用。派生类可以重写此方法,并为其子类布局。
参数
changed 是否为视图设置了新的大小和位置。
left 相对于父视图的左侧的位置。
top 相对于父视图的顶部的位置。
right 相对于父视图的右侧的位置。
bottom 相对于父视图的底部的位置。
使用AdapterView来绑定数据
AdapterView是一个ViewGroup子类, 它的子View是有一个Adapter决定的, 而该Adapter绑定某种类型的数据. AdapterView在你希望显示储存的数据(相对于资源字符串或者图片)时比较有用.
Gallery, ListView, 和 Spinner是AdapterView子类的例子, 你可以使用它们绑定特定类型的数据并按照一定方式来显示它们.
AdapterView对象有两个主要任务:
* 在布局中显示数据
* 处理用户的选择
Filling the Layout with Data 为布局填充数据
将数据插入布局一般是通过将AdapterView类绑定到一个Adapter完成的. Adapter从一个外部资源获取数据(可能是代码直接提供,也可能是从设备上的一个数据库查到的数据组成的一个列表).
下列代码做了两件事情:
1. 使用一个已有的View创建了一个Spinner, 并将其绑定到一个新的ArrayAdapter, 后者从本地资源中读取一个颜色的数组.
2. 从一个View创建另一个 Spinner对象并将它绑定到一个新的SimpleCursorAdapter, 后者将读取设备上的联系人名字.
// Get a Spinner and bind it to an ArrayAdapter that
// references a String array.
Spinner s1 = (Spinner) findViewById(R.id.spinner1);
ArrayAdapter adapter = ArrayAdapter.createFromResource(
this, R.array.colors, android.R.layout.simple_spinner_item);
adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
s1.setAdapter(adapter);
// Load a Spinner and bind it to a data query.
private static String[] PROJECTION = new String[] {
People._ID, People.NAME
};
Spinner s2 = (Spinner) findViewById(R.id.spinner2);
Cursor cur = managedQuery(People.CONTENT_URI, PROJECTION, null, null);
SimpleCursorAdapter adapter2 = new SimpleCursorAdapter(this,
android.R.layout.simple_spinner_item, // Use a template
// that displays a
// text view
cur, // Give the cursor to the list adatper
new String[] {People.NAME}, // Map the NAME column in the
// people database to...
new int[] {android.R.id.text1}); // The "text1" view defined in
// the XML template
adapter2.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
s2.setAdapter(adapter2);
注意必须People._ID 列必须和CursorAdapter 一起使用, 否则你会得到异常.
如果在你的应用程序生命周期中, 你改变了你的Adapter管理的数据, 你应该调用notifyDataSetChanged(). 这将使附加的View刷新.
Handling User Selections 处理用户选择
使用AdapterView.OnItemClickListener来获取用户的选择.
// 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)
{
// Display a messagebox.
Toast.makeText(mContext,"You've got an event",Toast.LENGTH_SHORT).show();
}
};
// Now hook into our object and set its onItemClickListener member
// to our class handler object.
mHistoryView = (ListView)findViewById(R.id.history);
mHistoryView.setOnItemClickListener(mMessageClickedHandler)
AdapterView:
声明
欢迎转载,但请保留文章原始出处:)
博客园:http://www.cnblogs.com/
Android中文翻译组:http://code.taobao.org/project/view/404/
正文
一、结构
public abstract class AdapterView<T extends Adapter> extends ViewGroup
java.lang.Object
android.view.View
android.view.ViewGroup
android.widget.AdapterView<T extends android.widget.Adapter>
直接子类
AbsListView, AbsSpinner
间接子类
ExpandableListView, Gallery, GridView, ListView, Spinner
二、概述
AdapterView 是内容由 Adapter 来决定的视图类。
参见 ListView、GridView、Spinner 和 Gallery 等常见子类。
三、常量
public static final int INVALID_POSITION
代表无效的位置。有效值的范围是 0 到当前适配器项目数减 1 。
常量值: -1 (0xffffffff)
public static final long INVALID_ROW_ID
代表空或者无效的行ID。
常量值: -9223372036854775808 (0x8000000000000000)
public static final int ITEM_VIEW_TYPE_HEADER_OR_FOOTER
当条项是列表头或列表尾时,调用 getItemViewType(int) 函数的返回值。
常量值: -2 (0xfffffffe)
public static final int ITEM_VIEW_TYPE_IGNORE
当适配器禁止条项的视图再利用时,调用 getItemViewType(int) 函数的返回值。
常量值: -1 (0xffffffff)
四、构造函数
public AdapterView (Context context)
构造函数
public AdapterView (Context context, AttributeSet attrs)
构造函数
public AdapterView (Context context, AttributeSet attrs, int defStyle)
构造函数
五、公共方法
public void addView (View child)
该类不支持该方法,如果调用将抛出 UnsupportedOperationException 异常。
参数
child 忽略
异常
UnsupportedOperationException 调用该方法时
public void addView (View child, int index)
该类不支持该方法,如果调用将抛出 UnsupportedOperationException 异常。
参数
child 忽略。
index 忽略。
抛出
UnsupportedOperationException 调用该方法时
public void addView (View child, int index, ViewGroup.LayoutParams params)
该类不支持该方法,如果调用将抛出 UnsupportedOperationException 异常。
参数
child 忽略。
index 忽略。
params 忽略。
抛出
UnsupportedOperationException 调用该方法时
public void addView (View child, ViewGroup.LayoutParams params)
该类不支持该方法,如果调用将抛出 UnsupportedOperationException 异常。
参数
child 忽略。
params 忽略。
抛出
UnsupportedOperationException 调用该方法时
public boolean dispatchPopulateAccessibilityEvent (AccessibilityEvent event)
分发 AccessibilityEvent 事件到 该视图 的子视图中。
参数
event 事件。
返回值
如果事件分发完成,返回真。
public abstract T getAdapter ()
返回当前与该小部件关联的适配器。
返回值
用于提供视图内容的适配器。
public int getCount ()
返回值
与 AdapterView 相关联的适配器的条目数量。(该值是数据条目的数量, 可能大于可见的视图的数量。)
public View getEmptyView ()
当前适配器无内容时,AdapterView 会显示特殊的空视图。 空视图用于告诉用户,该 AdapterView 没有数据。
返回值
适配器为空时显示的视图。
public int getFirstVisiblePosition ()
返回显示在屏幕上的第一个元素在适配器中所处的位置。
返回值
在适配器数据集中的位置。
public Object getItemAtPosition (int position)
取得列表中指定位置的数据。
参数
position 要取得数据的位置。
返回值
列表中指定位置的数据。
public long getItemIdAtPosition (int position)
(译者注:关于此方法的分析,参见这里。)
public int getLastVisiblePosition ()
返回显示在屏幕上的最后一个元素在适配器中所处的位置。
返回值
在适配器数据集中的位置。
public final AdapterView.OnItemClickListener getOnItemClickListener ()
返回值
点击 AdapterView 中的条目时执行的回调函数;没有设置时返回空。
public final AdapterView.OnItemLongClickListener getOnItemLongClickListener ()
返回值
取得长按 AdapterView 中的条目时执行的回调函数的监听器;未设置则返回空。
public final AdapterView.OnItemSelectedListener getOnItemSelectedListener ()
public int getPositionForView (View view)
取得适配器项目对应的视图或其子视图在适配器的数据中所处的位置。
参数
view 适配器条目或其后代的视图。调用时该项目在 AdapterView 中必须可见。
返回值
视图在适配器数据集中的位置;如果视图不在数据列表中或当前不可见,则返回 INVALID_POSITION。
public Object getSelectedItem ()
返回值
当前选中条目对应的数据;无选中条目时返回空。
public long getSelectedItemId ()
返回值
当前选中条目相应的 ID;无选中条目则返回 INVALID_ROW_ID。
public int getSelectedItemPosition ()
返回当前选中项目在适配器数据中的位置。
返回值
返回从零开始的位置(索引)信息,没有选择条目时返回 INVALID_POSITION。
public abstract View getSelectedView ()
返回值
当前选中条目对应的视图;无选中条目时返回空。
public boolean performItemClick (View view, int position, long id)
如果定义了 OnItemClickListener 则调用它。
参数
view AdapterView 中被点击的视图。
position 视图在适配器中的索引。
id 点击的条目的行 ID。
返回值
如果成功调用了定义的 OnItemClickListener 则返回真;否则返回假。
public void removeAllViews ()
该类不支持该方法,如果调用将抛出 UnsupportedOperationException 异常。
抛出
UnsupportedOperationException调用该方法时
public void removeView (View child)
该类不支持该方法,如果调用将抛出 UnsupportedOperationException 异常。
参数
child 忽略。
抛出
UnsupportedOperationException调用该方法时
public void removeViewAt (int index)
该类不支持该方法,如果调用将抛出 UnsupportedOperationException 异常。
参数
index 忽略。
抛出
UnsupportedOperationException调用该方法时
public abstract void setAdapter (T adapter)
设置用于为该小部件的视图提供用于显示的数据的适配器。
参数
adapter 用于创建视图内容的适配器。
public void setEmptyView (View emptyView)
设置适配器内容为空时显示的视图。
public void setFocusable (boolean focusable)
设置该视图是否可以获取焦点。 设为假时,可以确保在触控模式中该视图不能得到焦点。
参数
focusable 设为真时,该视图可以得到焦点。
public void setFocusableInTouchMode (boolean focusable)
设置在触控模式下该视图是否可以获取焦点。 设为真时,可以保证视图可以得到焦点。
参数
focusable 设为真时,该视图在触控模式下可以得到焦点。
public void setOnClickListener (View.OnClickListener l)
注册点击该视图时执行的回调函数。如果该视图不可点击,会将其改为可以点击的状态。
参数
l 事件发生时运行的回调函数。
public void setOnItemClickListener (AdapterView.OnItemClickListener listener)
注册单击 AdapterView 中的条目时执行的回调函数。
参数
listener 将要调用的回调。
public void setOnItemLongClickListener (AdapterView.OnItemLongClickListener listener)
注册长按 AdapterView 中的条目时执行的回调函数。
参数
listener 事件发生时运行的回调函数。
public void setOnItemSelectedListener (AdapterView.OnItemSelectedListener listener)
注册选中 AdapterView 中的条目时执行的回调函数。
参数
listener 事件发生时运行的回调函数。
public abstract void setSelection (int position)
设置当前选择条目。为了支持无障碍功能,重写该方法的子类必须首先调用父类的该方法。
参数
position 选择的数据条目的索引(从零开始)。
六、保护方法
protected boolean canAnimate ()
指示视图组是否能够在首次布局后为其子视图提供动画效果的显示。
返回值
如果子视图可以使用动画效果则返回真,否则返回假。
protected void dispatchRestoreInstanceState (SparseArray<Parcelable> container)
为了防止适配器生成的视图被解冻而重写。
参数
container 保存有之前存储的状态信息的 SparseArray。
protected void dispatchSaveInstanceState (SparseArray<Parcelable> container)
为了防止适配器生成的视图被冻结而重写。
参数
container 保存视图状态的 SparseArray。
protected void onLayout (boolean changed, int left, int top, int right, int bottom)
该视图设置其子视图的大小及位置时调用。派生类可以重写此方法,并为其子类布局。
参数
changed 是否为视图设置了新的大小和位置。
left 相对于父视图的左侧的位置。
top 相对于父视图的顶部的位置。
right 相对于父视图的右侧的位置。
bottom 相对于父视图的底部的位置。
[3] RelativeLayout的懂得
来源: 互联网 发布时间: 2014-02-18
RelativeLayout的理解
一、概述
在开发中推荐尽量使用RelativeLayout可以增强其适应不同屏幕的灵活性。该布局根据widgets之间关系和widget与父容器之间的关系来确定布局。例如可以设置A在父容器的底部对齐,B在A的上方。
设置RelativeLayout的两大类主要的属性,如下:
1.widget与所在容器(Container)的关系
android:layout_alignParentTop
android:layout_alignParentBottom
android:layout_alignParentLeft
android:layout_centerHorizontal
......
2.widgets之间关系
android:layout_above
android:layout_below
android:layout_toLeft
android:layout_toRight
android:layout_alignTop
......
注意:widgets的出现先后顺序值得注意。被参照的widget必须保证已经出现了的。
二、实例分析
【效果图】
【代码要点】
main.xml
view plaincopy to clipboardprint?
1. <?xml version="1.0" encoding="utf-8"?>
2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
3. android:orientation="vertical"
4. android:layout_width="fill_parent"
5. android:layout_height="wrap_content"
6. android:padding="5px"
7. >
8. <TextView
9. android:id="@+id/label"
10. android:layout_width="wrap_content"
11. android:layout_height="wrap_content"
12. android:text="URL:"
13. android:paddingTop="10px"
14. />
15. <EditText
16. android:id="@+id/entry"
17. android:layout_width="fill_parent"
18. android:layout_height="wrap_content"
19. android:layout_toRightOf="@id/label"
20. />
21. <Button
22. android:id="@+id/button1"
23. android:layout_width="wrap_content"
24. android:layout_height="wrap_content"
25. android:text="OK"
26. android:layout_below="@id/entry"
27. android:layout_alignRight="@id/entry"
28. />
29. <Button
30. android:id="@+id/button2"
31. android:layout_width="wrap_content"
32. android:layout_height="wrap_content"
33. android:text="Cancel"
34. android:layout_toLeftOf="@+id/button1"
35. android:layout_alignBottom="@+id/button1"
36. />
37. </RelativeLayout>
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="wrap_content" android:padding="5px" > <TextView android:id="@+id/label" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="URL:" android:paddingTop="10px" /> <EditText android:id="@+id/entry" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_toRightOf="@id/label" /> <Button android:id="@+id/button1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="OK" android:layout_below="@id/entry" android:layout_alignRight="@id/entry" /> <Button android:id="@+id/button2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Cancel" android:layout_toLeftOf="@+id/button1" android:layout_alignBottom="@+id/button1" /> </RelativeLayout>
三、margin和padding的区别
一、概述
在开发中推荐尽量使用RelativeLayout可以增强其适应不同屏幕的灵活性。该布局根据widgets之间关系和widget与父容器之间的关系来确定布局。例如可以设置A在父容器的底部对齐,B在A的上方。
设置RelativeLayout的两大类主要的属性,如下:
1.widget与所在容器(Container)的关系
android:layout_alignParentTop
android:layout_alignParentBottom
android:layout_alignParentLeft
android:layout_centerHorizontal
......
2.widgets之间关系
android:layout_above
android:layout_below
android:layout_toLeft
android:layout_toRight
android:layout_alignTop
......
注意:widgets的出现先后顺序值得注意。被参照的widget必须保证已经出现了的。
二、实例分析
【效果图】
【代码要点】
main.xml
view plaincopy to clipboardprint?
1. <?xml version="1.0" encoding="utf-8"?>
2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
3. android:orientation="vertical"
4. android:layout_width="fill_parent"
5. android:layout_height="wrap_content"
6. android:padding="5px"
7. >
8. <TextView
9. android:id="@+id/label"
10. android:layout_width="wrap_content"
11. android:layout_height="wrap_content"
12. android:text="URL:"
13. android:paddingTop="10px"
14. />
15. <EditText
16. android:id="@+id/entry"
17. android:layout_width="fill_parent"
18. android:layout_height="wrap_content"
19. android:layout_toRightOf="@id/label"
20. />
21. <Button
22. android:id="@+id/button1"
23. android:layout_width="wrap_content"
24. android:layout_height="wrap_content"
25. android:text="OK"
26. android:layout_below="@id/entry"
27. android:layout_alignRight="@id/entry"
28. />
29. <Button
30. android:id="@+id/button2"
31. android:layout_width="wrap_content"
32. android:layout_height="wrap_content"
33. android:text="Cancel"
34. android:layout_toLeftOf="@+id/button1"
35. android:layout_alignBottom="@+id/button1"
36. />
37. </RelativeLayout>
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="wrap_content" android:padding="5px" > <TextView android:id="@+id/label" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="URL:" android:paddingTop="10px" /> <EditText android:id="@+id/entry" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_toRightOf="@id/label" /> <Button android:id="@+id/button1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="OK" android:layout_below="@id/entry" android:layout_alignRight="@id/entry" /> <Button android:id="@+id/button2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Cancel" android:layout_toLeftOf="@+id/button1" android:layout_alignBottom="@+id/button1" /> </RelativeLayout>
三、margin和padding的区别
最新技术文章: