1.Android中几个常用控件
在本章节中我们将用介绍ProgressBar、Spinner、AutoCompleteTextView、MultiAutoCompleteTextView等共四个控件的基本用法。这些控件在我们以后的工作中经常会用到的,因此这里也要求我们必须掌握这部分知识。
为了便于演示我们新创建一个项目,项目名《常用控件》。使用默认的布局文件和默认的Activity类。
布局文件如下:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity" >
<TextView
android:layout_gravity="center_horizontal"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="演示常用控件的使用" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="进度条ProgressBar"
/>
<!-- 进度条控件
android:max 进度条条总刻度
android:progress 默认进度
-->
<ProgressBar
style="@android:style/Widget.ProgressBar.Horizontal"
android:layout_height="wrap_content"
android:layout_width="match_parent"
android:max="100"
android:progress="20"
android:id="@+id/progressBar"
/>
<TextView
android:layout_marginTop="30dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="下拉列表框Spinner"
/>
<!-- 下拉列表框控件
android:entries 字符串数组常量
-->
<Spinner
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:entries="@array/cities"
android:id="@+id/spinner"
/>
<TextView
android:layout_marginTop="30dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="自动提示文本框AutoCompleteTextView"
/>
<!-- 自动提示文本框控件
android:completionThreshold 自动提示门限 默认是2,这里改成1 也就是输入一个字符即可提示
-->
<AutoCompleteTextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/auto_tv"
android:completionThreshold="1"
/>
<TextView
android:layout_marginTop="30dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="多个自动提示文本框MultiAutoCompleteTextView"
/>
<!-- 自动提示文本框控件
android:completionThreshold 自动提示门限 默认是2,这里改成1 也就是输入一个字符即可提示
-->
<MultiAutoCompleteTextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/multi_tv"
android:completionThreshold="1"
/>
</LinearLayout>
在上面布局文件清单中Spinner控件有个比较特殊的属性需要引入外部文件。android:entries="@array/cities"。该属性值是一个布局文件,需要在工程中res/values/strings.xml中添加。下面不是strings.xml的文件清单,其中黄色背景是新添加的字符串常量,作为Spinner的备选项。
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="app_name">常用控件</string>
<string name="action_settings">Settings</string>
<string name="hello_world">Hello world!</string>
<string-array name="cities">
<item>北京</item>
<item>上海</item>
<item>广州</item>
<item>深圳</item>
</string-array>
</resources>
MainActivity代码清单如下:
package com.itheima.commonWidget;
import android.app.Activity;
import android.os.Bundle;
import android.os.SystemClock;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemSelectedListener;
import android.widget.ArrayAdapter;
import android.widget.AutoCompleteTextView;
import android.widget.MultiAutoCompleteTextView;
import android.widget.ProgressBar;
import android.widget.Spinner;
import android.widget.Toast;
public class MainActivity extends Activity {
private ProgressBar progressBar;
private Spinner spinner;
private AutoCompleteTextView auto_tv;
private MultiAutoCompleteTextView multi_tv;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
/*
- 初始化控件实例
*/
progressBar = (ProgressBar) findViewById(R.id.progressBar);
auto_tv = (AutoCompleteTextView) findViewById(R.id.auto_tv);
multi_tv = (MultiAutoCompleteTextView) findViewById(R.id.multi_tv);
spinner = (Spinner) findViewById(R.id.spinner);
/** - 给spinner绑定选中事件,当选中某一项时触发该事件
-
/
spinner.setOnItemSelectedListener(new OnItemSelectedListener() {
/- 某个条目被选中后调用此函数
- 第三个参数 position 代表选中条目的索引
/
@Override
public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
/- 调用Spinner的getItemAtPosition(int position)方法,获取选中的对象
- 强制转换为String类型
/
String city = (String) spinner.getItemAtPosition(position);
Toast.makeText(MainActivity.this, "您选择的是:" + city, 0).show();
}
/
-
什么都没有选择时调用次函数
/
@Override
public void onNothingSelected(AdapterView<?> parent) {
Toast.makeText(MainActivity.this, "您什么都没选!", 0).show();
}
});
//调用本类中自定义的私有方法显示进度条控件
showProgressBar();
//创建字符串数组
String[] books = new String[]{"JavaScript网页开发","Android源码分析","深入理解JVM","Android-阳哥随堂笔记","Android-阳哥面试宝典","JavaEE入门"};
//创建ArrayAdapter,在本文档的ListView控件中介绍过,因此不再重复介绍
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1, books);
//给自动文本提示框控件设置Adapter
auto_tv.setAdapter(adapter);
//给多文本提示框控件设置Adapter
multi_tv.setAdapter(adapter);
//给多文本提示框设置分隔符,这里使用逗号作为分隔符
multi_tv.setTokenizer(new MultiAutoCompleteTextView.CommaTokenizer());
}
/-
显示进度条控件
*/
void showProgressBar() {
new Thread(new Runnable() {@Override
public void run() {
while (true) {
for (int i = 0; i < 100; i++) {
//设置进度条的进度
progressBar.setProgress(i + 1);
SystemClock.sleep(100);
}
}
}
}).start();
}
-
}
1.1.进度条ProgressBar
进度条,与进度对话框有着类似的功能,也可以直接在子线程中控制其进度的改变。不同的是进度条一般嵌入在我们自定义的布局文件中,而进度对话框则单独占据一个布局(该布局系统自带提供)。
1.2.下拉列表框Spinner
Spinner 是一个列表选择框,会在用户选择后,展示一个列表供用户进行选择。Spinner是ViewGroup的间接子类,它和其他的Android控件一样,数据需要使用Adapter进行封装。
1.3.自动提示文本框AutoCompleteTextView
AutoCompleteTextView和EditText组件类似,都可以输入文本。AutoCompleteTextView组件可以和一个字符串数组或List对象绑定,当用户输入一个及以上字符时,系统将在AutoCompleteTextView组件下方列出字符串数组中所有以输入字符开头的字符串(只能提示一次)。
这一点和www.baidu.com、www.google.com的搜索框非常相似,当输入某一个要查找的字符串时,搜索框就会列出以这个字符串开头的最热门的搜索字符串列表。
1.4.多个自动提示文本框MultiAutoCompleteTextView
功能类似AutoCompleteTextView,只不过AutoCompleteTextView只能提示一次,再遇到短信多人发送的情况时,只提示一次的AutoCompleteTextView使用不是很合适,所以就有了MultiAutoCompleteTextView。
调用MultiAutoCompleteTextView.setTokenizer方法为此控件设置一个值与值之间的分隔符即可,其余设置于AutoCompleteTextView类似。