手记

Android中几个常用控件

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
   
   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类似。

7人推荐
随时随地看视频
慕课网APP