TCP三次握手及四次挥手详细图解
2013-11-05 16:42
363 查看
PopupWindow
[功能]
PopupWindow 作为一种用户提醒 而且其开销也比Activity要小
[代码 步骤]
1. 定义布局 供PopupWindow使用 如:hello.xml
2. 通过LayoutInflater 得到hello.xml 的 View view
3. 创建PopupWindow pop 使用上面布局文件view
4. 弹出PopupWindow
* 定义布局文件:main.xml 包括一个Button
* 弹出:有2种方式:一个是下拉方式 一个是指定位置
- 下拉:
- 指定位置:
5. 取消
6. 其他问题:
* 发现很多人对PopupWindow 里面包含ListView后 对具体哪个item被点击的获取有疑问 所以就顺便测试一下 发现和普通用法一样啊 没什么特别之处啊 现在把用法和大家分享分享
写道
因为ListView是展开显示的 会导致不美观 所以以Spinner为例
6.1. 定义包含Spinner 的布局文件 hello.xml
6.2. 得到Spinner的实例:spinner
6.3. 绑定Spinner与具体数据 本例以联系人为例
写道
别忘了联系人访问权限:
<uses-permission android:name="android.permission.READ_CONTACTS" />
6.4. 具体item的获取:
写道
updateTitle(int) 用来把位置在标题中显示
public void updateTitle(int i){
this.setTitle("HelloPop:"+i);
}
6.5. emulator 运行截图:
[功能]
PopupWindow 作为一种用户提醒 而且其开销也比Activity要小
[代码 步骤]
1. 定义布局 供PopupWindow使用 如:hello.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="fill_parent" android:layout_height="fill_parent" android:padding="10dp" > <ImageView android:id="@+id/image" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/robot" /> <LinearLayout android:orientation="vertical" android:layout_width="wrap_content" android:layout_height="wrap_content" android:paddingLeft="20dip" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="HelloPop!" /> <Button android:id="@+id/helloButton" android:layout_width="100dip" android:layout_height="wrap_content" android:text="OK" /> </LinearLayout> </LinearLayout>
2. 通过LayoutInflater 得到hello.xml 的 View view
view = this.getLayoutInflater().inflate(R.layout.hello, null);
3. 创建PopupWindow pop 使用上面布局文件view
pop = new PopupWindow(view,500,200);
4. 弹出PopupWindow
* 定义布局文件:main.xml 包括一个Button
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:id="@+id/main" android:layout_width="fill_parent" android:layout_height="fill_parent" > <TextView android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="pop demo!" /> <Button android:id="@+id/button" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="to pop!" /> </LinearLayout>
* 弹出:有2种方式:一个是下拉方式 一个是指定位置
- 下拉:
findViewById(R.id.button).setOnClickListener(new View.OnClickListener() { public void onClick(View v) { // TODO Auto-generated method stub pop.showAsDropDown(v); } });
- 指定位置:
findViewById(R.id.button).setOnClickListener(new View.OnClickListener() { public void onClick(View v) { // TODO Auto-generated method stub pop.showAtLocation(findViewById(R.id.main), Gravity.CENTER, 20, 20); } });
5. 取消
view.findViewById(R.id.helloButton).setOnClickListener(new View.OnClickListener() { public void onClick(View v) { // TODO Auto-generated method stub pop.dismiss(); } });
6. 其他问题:
* 发现很多人对PopupWindow 里面包含ListView后 对具体哪个item被点击的获取有疑问 所以就顺便测试一下 发现和普通用法一样啊 没什么特别之处啊 现在把用法和大家分享分享
写道
因为ListView是展开显示的 会导致不美观 所以以Spinner为例
6.1. 定义包含Spinner 的布局文件 hello.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" > <LinearLayout android:orientation="horizontal" android:layout_width="fill_parent" android:layout_height="wrap_content" > <ImageView android:id="@+id/image" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/robot" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="HelloPop!" /> </LinearLayout> <Spinner android:id="@+id/spinner" android:layout_width="wrap_content" android:layout_height="40dip"/> </LinearLayout>
6.2. 得到Spinner的实例:spinner
spinner = (Spinner)view.findViewById(R.id.spinner);
6.3. 绑定Spinner与具体数据 本例以联系人为例
public void specifySpinner(){ Cursor c = getContentResolver().query(People.CONTENT_URI, null, null, null, null); SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, android.R.layout.simple_list_item_1,c, new String[] {People.NAME}, new int[] {android.R.id.text1}); adapter.setDropDownViewResource( android.R.layout.simple_spinner_dropdown_item); spinner.setAdapter(adapter); }
写道
别忘了联系人访问权限:
<uses-permission android:name="android.permission.READ_CONTACTS" />
6.4. 具体item的获取:
spinner.setOnItemSelectedListener(new OnItemSelectedListener(){ public void onItemSelected(AdapterView<?> adapter,View v, int pos, long id) { updateTitle(pos); } public void onNothingSelected(AdapterView<?> arg0) { // TODO Auto-generated method stub } });
写道
updateTitle(int) 用来把位置在标题中显示
public void updateTitle(int i){
this.setTitle("HelloPop:"+i);
}
6.5. emulator 运行截图:
相关文章推荐
- TCP三次握手及四次挥手详细图解
- TCP三次握手及四次挥手详细图解
- TCP三次握手及四次挥手详细图解
- TCP三次握手及四次挥手详细图解
- TCP三次握手及四次挥手详细图解
- TCP三次握手及四次挥手详细图解
- TCP三次握手及四次挥手详细图解(转)
- [互联网面试笔试汇总C/C++-25] TCP三次握手及四次挥手详细图解
- TCP三次握手及四次挥手详细图解
- TCP三次握手及四次挥手详细图解
- TCP 三次握手建立连接,四次挥手断开连接,图解详细分析
- TCP三次握手及四次挥手详细图解
- TCP三次握手及四次挥手详细图解
- TCP协议中的三次握手和四次挥手(图解)
- TCP协议中的三次握手和四次挥手(图解)
- TCP协议中的三次握手和四次挥手(图解)
- TCP协议中的三次握手和四次挥手(图解)
- TCP协议中的三次握手和四次挥手(图解)
- TCP三次握手以及四次挥手图解
- TCP协议中的三次握手和四次挥手(图解)&&TCP/IP 七层网络模型