【转】 Pro Android学习笔记(二十):用户界面和控制(8):GridView和Spinner
GridView

GridView是网格状布局,如图所示。在了解ListView后,很容易了解GridView。下面是例子的XML文件。
<?xml version="1.0" encoding="utf-8"?>
<GridView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/ui_grid"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:padding="10dip"
android:verticalSpacing="10dip"
android:horizontalSpacing="10dip"
android:columnWidth="100dip"
android:numColumns="auto_fit"
android:stretchMode="columnWidth"
android:gravity="center" />
Java代码如下:
public class UiGridViewTest extends Activity{ //注意没有像ListView那样有extends ListActivity
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.ui_gridview);
GridView gv = (GridView)findViewById(R.id.ui_grid);
//仍然以联系人为例子,获取数据源和设置adapter和之前的listview例子相同,我们对子view的设置仍选择系统自带的简单方式。
CursorLoader cursorLoader = new CursorLoader(getApplicationContext(),
ContactsContract.Contacts.CONTENT_URI,
null, null, null,
ContactsContract.Contacts.DISPLAY_NAME + " ASC");
Cursor cursor = cursorLoader.loadInBackground();
String[] cols = new String[]{ContactsContract.Contacts.DISPLAY_NAME};
int[] views = new int[]{android.R.id.text1};
SimpleCursorAdapter simAdapter = new SimpleCursorAdapter(this,
android.R.layout.simple_list_item_1,
cursor, cols, views,CursorAdapter.FLAG_REGISTER_CONTENT_OBSERVER);
//为GridView关联adapter
gv.setAdapter(simAdapter); //去查reference发现GridView的setAdapter(ListAdapter adapter),adapter要求是ListAdapter,grid是二维的,实际上一行一行地处理,每行实际也是一个list。
}
}
在前面ListView中有关数据信息的获取和触发一样可以在GridView中使用,但注意有一点不同,GridView不提供多项选择(multiple choices)。推荐阅读Android学习笔记(十三):Activity-GridView。
Spinner

这是一个spinner的例子,左边第一个图是正常显示模式,当我们点击有下小三角图标是,会显示一个下拉单。如有右边两个图所示。和之前的ListView和GridView不一样的在于,spinner有两个显示,一是普通模式,一是pop-up list模式。我们需要在代码中分别对这两个显示进行设置。下面的XML文件。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<Spinner android:id="@+id/ui_spinner"
android:prompt="@string/planets" <!-- 这个提示内容,实际并没有真实显示,只是用于说明 -->
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</LinearLayout>
代码如下:
public class UiSpinnerTest extends Activity implements OnItemSelectedListener{
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.ui_spinner);
Spinner spin = (Spinner)findViewById(R.id.ui_spinner);
//本例采用ArrayAdapter,这里的第三个参数是设置普通模式的显示,即一个简单的TextView,虽然这里可视的只是其中一个item,但整个概念和listview的一样。
ArrayAdapter<CharSequence> adapter = ArrayAdapter.createFromResource(this,
R.array.planets, android.R.layout.simple_spinner_item);
//通过setDropDownViewResource设置pop-up list的子view显示layout,我们采用了不同的layout,分别为有不同的显示效果,见上图所示。需要注意的是Android版本不同,会对layout的实际布局有不同,在API Level 17(Android 4.2.2)中,simple_spinner_dropdown_item中去掉checkMark。
//adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
adapter.setDropDownViewResource(android.R.layout.simple_list_item_single_choice);
spin.setAdapter(adapter);
//选择变化,触发OnItemSelectedListener
spin.setOnItemSelectedListener(this);
}
@Override
public void onItemSelected(AdapterView<?> arg0, View view, int pos, long index) {
Log.d("Spinner",view.toString());
Log.d("Spinner","" + ((TextView)view).getText());
//本例中普通模式的子view是TextView,而pop-up list的CheckedTextView,在onItemSelected中,给出的view是普通模式下的子view,这点需要特别注意。
Log.d("Spinner","" + pos + " " + index);
}
@Override
public void onNothingSelected(AdapterView<?> arg0) {
Log.d("Spinner","Nothing Selected");
}
}
推荐阅读Android学习笔记(十二):Activity-Spinner
相关链接: 我的Android开发相关文章
【转】 Pro Android学习笔记(二十):用户界面和控制(8):GridView和Spinner的更多相关文章
- 【转】 Pro Android学习笔记(十九):用户界面和控制(7):ListView
目录(?)[-] 点击List的item触发 添加其他控件以及获取item数据 ListView控件以垂直布局方式显示子view.系统的android.app.ListActivity已经实现了一个只 ...
- 【转】Pro Android学习笔记(十二):了解Intent(下)
解析Intent,寻找匹配Activity 如果给出component名字(包名.类名)是explicit intent,否则是implicit intent.对于explicit intent,关键 ...
- 【转】Pro Android学习笔记(十四):用户界面和控制(2):Text类控制
目录(?)[-] TextView 例子1在XML中设置autoLink属性 例子2在代码中设置autoLink属性 EditText AutoCompleteTextView MultiAutoCo ...
- 【转】Pro Android学习笔记(十):了解Intent(上)
目录(?)[-] Intent基本含义 系统的Intent Android引入了Intent的概念来唤起components,component包括:1.Activity(UI元件) 2.Servic ...
- 【转】Pro Android学习笔记(十八):用户界面和控制(6):Adapter和AdapterView
目录(?)[-] SimpleCursorAdapter 系统预置的layout ArrayAdapter 动态数据增插删排序 自定义TextView风格 其他Adapter AdapterView不 ...
- 【转】Pro Android学习笔记(十六):用户界面和控制(4):ImageView控件
目录(?)[-] XML片段 代码设置ImageView ImageView是基础的控件,它是android.widget.ImageView的继承类. XML片段 <LinearLa ...
- 【转】Pro Android学习笔记(十五):用户界面和控制(3):Button控件
目录(?)[-] 基础Button ImageButton ToggleButton CheckBox RadioButton 基础Button Button是最常用的基础控件之一,在Android中 ...
- 【转】Pro Android学习笔记(二五):用户界面和控制(13):LinearLayout和TableLayout
目录(?)[-] 布局Layout 线性布局LinearLayout 表格布局TableLayout 布局Layout Layout是容器,用于对所包含的view进行布局.layout是view的子类 ...
- 【转】Pro Android学习笔记(三十):Menu(1):了解Menu
目录(?)[-] 创建Menu MenuItem的属性itemId MenuItem的属性groupId MenuItem的属性orderId MenuItem的属性可选属性 Menu触发 onOpt ...
- 【转】 Pro Android学习笔记(三五):Menu(6):XML方式 & PopUp菜单
目录(?)[-] 利用XML创建菜单 XML的有关属性 onClick事件 Pop-up菜单 利用XML创建菜单 在代码中对每个菜单项进行设置,繁琐且修改不灵活,不能适配多国语言的要求,可以利用资源进 ...
随机推荐
- php读写csv、xml文件: SimpleExcel
实例结构: 1. csv2xml.demo.php <?php use SimpleExcel\SimpleExcel; // 这句不能少! require_once ('../lib/Simp ...
- html5 (新一代的html)
简介 h5的新特性: cavas / video / audio / cache / element / form 最小的h5文档: <!DOCTYPE html> <html> ...
- 我的Android进阶之旅------>关于android:layout_weight属性的一个面试题
最近碰到一个面试题,按照下图,由Button和EditText组成的界面下厨布局代码,解决这题目需要使用android:layout_weight的知识. 首先分析上图所示的界面可以看成一下3个部分. ...
- spring jdbcTemplate的CRUD操作
一.jdbcTemplate准备 1.导入与jdbcTemplate相关的jar包 2.设置数据库信息 3.创建jdbcTemplate对象,设置数据源 二.添加操作 1.代码 2.结果 三.修改操作 ...
- angular中按需加载js
按需加载估计是大家在使用angular之后最想解决的问题吧,因为angular的依赖机制,导致了必须在第一次加载的时候就加载所有js文件,小项目还好,稍大一点的项目如果有上百个js文件,不管是从效率还 ...
- R语言图形base系统(一)
一般R作图有三大绘图系统:base系统.ggplot2绘图系统.lattice绘图系统. 本篇主要介绍base系统绘图时的图形参数.一般用plot()函数来完成.在R中,若 ...
- python3 str和bytes转换
bytes object b = b"example" str object s = "example" #str to bytes bytes(s, enco ...
- VIM复制粘贴 的快捷键是什么
yy复制游标所在行整行.或大写一个Y. 2yy或y2y复制两行. ㄟ ,请举一反三好不好! :-) y^复制至行首,或y0.不含游标所在处字元. y$复制至行尾.含游标所在处字元. yw复制一个wor ...
- html post
post请求对应的html页面 页面效果 html代码 <html> <body> <form method="post" > First na ...
- NVM安装配置
http://www.kancloud.cn/summer/nodejs-install/71975 配置源 http://www.cnblogs.com/kaiye/p/4937191.html 安 ...