`

Android系列教程之七:EditText使用详解-包含很多教程上看不到的功能演示

阅读更多
写道
标题有点大,说是详解,其实就是对EditText的一些常用功能的介绍,包括密码框,电话框,空白提示文字等等的讲解,尽量的介绍详细一点,也就是所谓的详解了。。呵呵

广告一下我的应用“我团”,最新1.4版可以到“安智市场”、“应用汇”等各大应用商店搜索“我团”下载使用。详情请看 http://flysnow.iteye.com/blog/810503

 

我新建了一个Android的技术交流群,群号为86686524    120059404 ,感兴趣的可以申请加入,大家一块学习。

Android系列教程目录:

  1. Android教程之一:Window下搭建Android开发环境

  2. Android教程之二:Linux下搭建Android开发环境

  3. Android教程之三:第一个Android应用,HelloWorld

  4. Android系列教程之四:Android项目的目录结构

  5. Android系列教程之五:Activity的生命周期

  6. Android系列教程之六:TextView小组件的使用--附带超链接和跑马灯效果

本文版权归飞雪无情 所有,转载请注明出处, 永久链接: http://flysnow.iteye.com/blog/828415

一:新建HelloEditText工程

 

新建一个Hello world详细步骤可以参见

Android教程之三:第一个Android应用,HelloWorld

创建设置如下:

  1. Project name: HelloEditText
  2. Build Target :android 2.2
  3. Application name:HelloEditText
  4. Package name:com.flysnow
  5. create Activity: HelloEditText
  6. min SDK 8

 这时候运行还看不到EditText,因为我们还没有加上,修改main.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"
    >
<EditText
	android:id="@+id/edit_text"  
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:text="这是一个EditText"/>
</LinearLayout>

 这里添加了一个id为"edit_text"的EditText,设置默认显示为本为“这是一个EditText”。。运行效果如下:


二:EditText简介

EditText是一个非常重要的组件,可以说它是用户和Android应用进行数据传输窗户,有了它就等于有了一扇和Android应用传输的门,通过它用户可以把数据传给Android应用,然后得到我们想要的数据。

EditText是TextView的子类,所以TextView的方法和特性同样存在于EditText中,具体的TextView的介绍可以参考上一节Android系列教程之六:TextView小组件的使用--附带超链接和跑马灯效果

 

三:长度和空白提示文字,提示文字颜色,是否可编辑等

EditText有一些属性可以设置EditText的特性,比如最大长度,空白提示文字等。

  1. 有时候我们有一些特属的需要,要求只能在EditText中输入特定个数的字符,比如身份证号、手机号吗等。这时候就可以通过android:maxLength属性来设置最大输入字符个数,比如android:maxLength=“4”就表示最多能输入4个字符,再多了就输入不进去了。
  2. 空白提示文字。有时候我们需要说明你定义的这个EditText是做什么用的,比如让输入“用户名”,或者输入“电话号码”等,但是你又不想在EditText前面加一个TextView来说明这是输入“用户名”的,因为这会使用一个TextView,那么怎么办呢?EditText为我们提供了android:hint来设置当EditText内容为空时显示的文本,这个文本只在EditText为空时显示,你输入字符的时候就消失了,不影响你的EditText的文本。。修改main.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"
        >
    <EditText
    	android:id="@+id/edit_text"  
        android:layout_width="fill_parent" 
        android:layout_height="wrap_content"
        android:maxLength="40"
        android:hint="请输入用户名..."/>
    </LinearLayout>
     运行应用就会看到如下的效果:

     看看吧,简洁明了还不用新增一个TextView说明,也不影响用户操作。
  3. 上面列出了空白时的提示文字,有的人说了,我不想要这个灰色的提示文字,和我的应用整体风格不协调,那也行啊,我们可以换颜色,怎么换呢,就是通过android:textColorHint属性设置你想要的颜色。修改main.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"
        >
    <EditText
    	android:id="@+id/edit_text"  
        android:layout_width="fill_parent" 
        android:layout_height="wrap_content"
        android:maxLength="40"
        android:hint="请输入用户名..."
        android:textColorHint="#238745"/>
    </LinearLayout>
     运行程序效果如下:

     看到了吧,颜色已经变了。。
  4. 还有一个比较实用的功能,就是设置EditText的不可编辑。设置android:enabled="false"可以实现不可编辑,可以获得焦点。这时候我们看到EditText和一个TextView差不多:

     
  5. 实现类似html中Textarea的文本域。在Android中没有专门的文本域组件,但是可以通过设置EditText的高来实现同样的文本域功能。修改main.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"
        >
    <EditText
    	android:id="@+id/edit_text"  
        android:layout_width="fill_parent" 
        android:layout_height="200dip"/>
    </LinearLayout>
     运行程序效果如下:

     

四:输入特殊格式的字符

在我们开发程序的时候不免会输入一些特属个数的字符,比如密码(输入框的字符要加密显示),电话号码(比如数字和-),数字等,这些都算是一些特属格式的字符,强大的EditText同样为我们提供了输入这些特属格式字符的设置。

  1. 密码文本框。密码输入也是Android应用常用的功能,通过配置EditText的android:password="true"就可以实现这一密码输入功能,修改main.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"
        >
    <EditText
    	android:id="@+id/edit_text"  
        android:layout_width="fill_parent" 
        android:layout_height="wrap_content"
        android:password="true"/>
    </LinearLayout>
     运行效果如下:

     可以看到我们输入的字符已经被“.”这样的掩码所代替。
  2. 手机中发短信打电话是必不可少的,所以用于专门输入电话号码的文本框也是大有用途,有了他我们对是否是电话号码的校验就容易的多了(因为字符是正确的,只要校验格式 ).通过设置android:phoneNumber="true"就可以把EditText变成只接受电话号码输入的文本框,连软键盘都已经变成拨号专用软键盘了,所以不用再担心输入其他字符了。修改main.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"
        >
    <EditText
    	android:id="@+id/edit_text"  
        android:layout_width="fill_parent" 
        android:layout_height="wrap_content"
        android:phoneNumber="true"/>
    </LinearLayout>
     运行程序效果如下:

     注意看软键盘,已经变成拨号专用的啦.
  3. 有时候我们只想输入数字,不想输入字母,EditText为我们提供了android:numeric来控制输入的数字类型,一共有三种分别为integer(正整数)、signed(带符号整数)和decimal(浮点数)。这里以signed类型的为例,修改main.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"
        >
    <EditText
    	android:id="@+id/edit_text"  
        android:layout_width="fill_parent" 
        android:layout_height="wrap_content"
        android:numeric="signed"/>
    </LinearLayout>
     运行效果如下:

     注意这里的软键盘变成“数字键盘”的变化.

五:为文本指定特定的软键盘类型

前面我们通过指定为电话号码特定格式,然后键盘类型变成了拨号专用的键盘,这个是自动变的,其实我们也可以通 过android:inputType来设置文本的类型,让输入法选择合适的软键盘的。。android:inputType有很多类型,这里使用date类型来演示,修改main.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"
    >
<EditText
	android:id="@+id/edit_text"  
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content"
    android:inputType="date"/>
</LinearLayout>

  运行效果如下:

六:Enter键图标的设置

软键盘的Enter键默认显示的是“完成”文本,我们知道按Enter建表示前置工作已经准备完毕了,要去什么什么啦。比如,在一个搜索中,我们输入要搜索的文本,然后按Enter表示要去搜索了,但是默认的Enter键显示的是“完成”文本,看着不太合适,不符合搜索的语义,如果能显示“搜索”两个字或者显示一个表示搜索的图标多好。事实证明我们的想法是合理的,Android也为我们提供的这样的功能。通过设置android:imeOptions来改变默认的“完成”文本。这里举几个常用的常量值:

  1. actionUnspecified  未指定,对应常量EditorInfo.IME_ACTION_UNSPECIFIED.效果:
  2. actionNone 没有动作,对应常量EditorInfo.IME_ACTION_NONE 效果:
  3. actionGo 去往,对应常量EditorInfo.IME_ACTION_GO 效果:
  4. actionSearch 搜索,对应常量EditorInfo.IME_ACTION_SEARCH 效果:
  5. actionSend 发送,对应常量EditorInfo.IME_ACTION_SEND 效果:
  6. actionNext 下一个,对应常量EditorInfo.IME_ACTION_NEXT 效果:
  7. actionDone 完成,对应常量EditorInfo.IME_ACTION_DONE 效果:

 下面已搜索为例,演示一个实例,修改main.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"
    >
<EditText
	android:id="@+id/edit_text"  
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content"
    android:imeOptions="actionSearch"/>
</LinearLayout>

  修改HelloEditText如下:

package com.flysnow;

import android.app.Activity;
import android.os.Bundle;
import android.view.KeyEvent;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Toast;
import android.widget.TextView.OnEditorActionListener;

public class HelloEditText extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        EditText editText=(EditText)findViewById(R.id.edit_text);
        editText.setOnEditorActionListener(new OnEditorActionListener() {
			@Override
			public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
				Toast.makeText(HelloEditText.this, String.valueOf(actionId), Toast.LENGTH_SHORT).show();
				return false;
			}
		});
    }
}

 运行程序,点击回车(也就是搜索图标软键盘按钮)会显示该actionId.我们上面的每一个设置都会对应一个常量,这里的actionId就是那个常量值。

七:EditText的取值、全选、部分选择、获取选中文本

       下面通过一个例子来演示EditText的取值、全选、部分选择和获取选中文本.main.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"
    >
<EditText
	android:id="@+id/edit_text"  
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content"
    android:imeOptions="actionSearch"/>
<Button 
	android:id="@+id/btn_get_value"
	android:text="取值"
	android:layout_width="wrap_content"
	android:layout_height="wrap_content"/>
<Button 
	android:id="@+id/btn_all"
	android:text="全选"
	android:layout_width="wrap_content"
	android:layout_height="wrap_content"/>
<Button 
	android:id="@+id/btn_select"
	android:text="从第2个字符开始选择"
	android:layout_width="wrap_content"
	android:layout_height="wrap_content"/>
<Button 
	android:id="@+id/btn_get_select"
	android:text="获取选中文本"
	android:layout_width="wrap_content"
	android:layout_height="wrap_content"/>
</LinearLayout>
 

HelloEditText修改如下:

package com.flysnow;

import android.app.Activity;
import android.os.Bundle;
import android.text.Editable;
import android.text.Selection;
import android.view.KeyEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Toast;
import android.widget.TextView.OnEditorActionListener;
/**
 * EditText演示
 * @author 飞雪无情
 * @since 2010-11-29
 */
public class HelloEditText extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        final EditText editText=(EditText)findViewById(R.id.edit_text);
        //监听回车键
        editText.setOnEditorActionListener(new OnEditorActionListener() {
			@Override
			public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
				Toast.makeText(HelloEditText.this, String.valueOf(actionId), Toast.LENGTH_SHORT).show();
				return false;
			}
		});
        //获取EditText文本
        Button getValue=(Button)findViewById(R.id.btn_get_value);
        getValue.setOnClickListener(new OnClickListener() {
			@Override
			public void onClick(View v) {
				Toast.makeText(HelloEditText.this, editText.getText().toString(), Toast.LENGTH_SHORT).show();
			}
		});
        //让EditText全选
        Button all=(Button)findViewById(R.id.btn_all);
        all.setOnClickListener(new OnClickListener() {
			@Override
			public void onClick(View v) {
				editText.selectAll();
			}
		});
        //从第2个字符开始选择EditText文本
        Button select=(Button)findViewById(R.id.btn_select);
        select.setOnClickListener(new OnClickListener() {
			@Override
			public void onClick(View v) {
				Editable editable=editText.getText();
				Selection.setSelection(editable, 1,editable.length());
			}
		});
      //获取选中的文本
        Button getSelect=(Button)findViewById(R.id.btn_get_select);
        getSelect.setOnClickListener(new OnClickListener() {
			@Override
			public void onClick(View v) {
				int start=editText.getSelectionStart();
				int end=editText.getSelectionEnd();
				CharSequence selectText=editText.getText().subSequence(start, end);
				Toast.makeText(HelloEditText.this, selectText, Toast.LENGTH_SHORT).show();
			}
		});
    }
    /**
     * 交换两个索引
     * @param start 开始索引
     * @param end 结束索引
     */
	protected void switchIndex(int start, int end) {
		int temp=start;
		start=end;
		end=temp;
	}
}
 

 运行效果如下:



 可以通过输入文字和点击下面的按钮测试。

 

八:小结

     这结详细介绍了EditText的大部分特性和常用功能,如常用的密码框,获取值等等。这几天忙的没更新,这次更新个长的。可以够消化一阵子的。

  • 大小: 5.9 KB
  • 大小: 6.4 KB
  • 大小: 6.2 KB
  • 大小: 4.8 KB
  • 大小: 26.9 KB
  • 大小: 4.2 KB
  • 大小: 26.7 KB
  • 大小: 25.1 KB
  • 大小: 25.1 KB
  • 大小: 1.5 KB
  • 大小: 1.7 KB
  • 大小: 1.8 KB
  • 大小: 1.8 KB
  • 大小: 1.5 KB
  • 大小: 1.9 KB
  • 大小: 27.4 KB
  • 大小: 21.5 KB
18
0
分享到:
评论
9 楼 hhb19900618 2013-11-11  
怎么监听 键盘的每次输入啊?
8 楼 hhb19900618 2013-11-11  
讲的还算挺详细

一般Android 开发都使用 LinearLayout布局吗 
7 楼 qianguming 2013-09-29  
http://flysnow.iteye.com/blog/865944
第八篇链接
6 楼 Mr.snail 2013-01-25  
必然得赞~
5 楼 zhengxihong198861 2011-12-21  
给力啊
4 楼 zchening 2011-01-09  
飞雪无情 写道
zchening 写道
你好,请问如果要让EditText每行显示水平线,该怎么写?

请参考Android 自带的demo Notepad,里面有个继承EditText的类,有画线的方法的!

是的,我已经看到了,Thank you all the same.
3 楼 飞雪无情 2011-01-06  
zchening 写道
你好,请问如果要让EditText每行显示水平线,该怎么写?

请参考Android 自带的demo Notepad,里面有个继承EditText的类,有画线的方法的!
2 楼 zchening 2011-01-06  
你好,请问如果要让EditText每行显示水平线,该怎么写?
1 楼 andyfish915 2011-01-04  
楼主给力,佩服

相关推荐

    Android EditText使用详解-包含很多教程上看不到的功能演示

    本文将深入探讨`EditText`的使用,包括一些在常见教程中较少涉及的功能。以下是对`EditText`的详尽解析: 1. 基本使用: `EditText`继承自`TextView`,因此它具有`TextView`的所有属性。在布局XML文件中,可以通过...

    Android软件开发之EditText 详解源码

    通过源码阅读,我们可以发现EditText的实现涉及到Android系统的多个层次,包括视图的绘制、输入事件的处理、输入法服务的交互等。深入理解这些细节,对于优化用户界面、提升用户体验至关重要。同时,掌握EditText的...

    安卓EditText输入框相关-material风格的edittext效果很不错。.rar

    当我们谈论“安卓EditText输入框相关-material风格的edittext效果很不错”,这意味着我们将探讨如何在Android应用中实现遵循Material Design原则的EditText组件。 Material Design风格的EditText通常具有以下特点:...

    android-edittext-validator-master.zip

    "android-edittext-validator-master.zip" 是一个专为Android平台设计的项目,专注于EditText组件的验证功能。这个项目提供了一种方便的方式来验证用户在EditText字段中输入的信息格式。 EditText是Android SDK中的...

    Android学习笔记六:基本视图组件:EditText

    这篇“Android学习笔记六:基本视图组件:EditText”将深入探讨`EditText`的使用、功能以及相关知识点。 首先,`EditText`继承自`TextView`,因此它具备`TextView`的所有属性,如显示文本、字体样式等。但与`...

    Android-Android-Prefix-Input为EditText添加prefix前缀模式

    在Android应用开发中,UI设计和用户体验是至关重要的部分,特别是在涉及到用户交互的文本输入时。`Android-Prefix-Input`项目就是针对这种情况提供的一种解决方案,它允许开发者为`EditText`组件添加前缀(Prefix)...

    Android开发开发技巧之 EditText 属性大全.pdf

    ### Android开发技巧之 EditText 属性大全 在Android应用开发中,`EditText`是用于收集用户输入文本的关键组件之一。为了更好地理解和运用`EditText`的各种属性,本文将详细解析与`EditText`相关的各种属性及其用途...

    最实用的Android教程以及EditText常用功能说明

    - 除了本教程外,提供的Excel文档可能包含更多Android开发的必备资源,包括API参考、设计指南、最佳实践、官方文档链接等,这将为你的Android开发之路提供全面支持。 通过学习和实践上述内容,开发者能够熟练掌握...

    Android应用源码之5.EditText控件学习-IT计算机-毕业设计.zip

    这份“Android应用源码之5.EditText控件学习”的资源旨在帮助开发者深入理解EditText的使用和定制,非常适合正在进行毕业设计或者Android App开发的学习者。 1. EditText基础使用: EditText是Android中的一个...

    安卓EditText输入框相关-Android框架chips-edittext-library.rar

    在`Android框架chips-edittext-library.rar`中,我们可以看到一个专门针对`EditText`的扩展库,它可能包含了一些增强`EditText`功能的实现,比如`ChipsEditText`,这种设计通常是为了提供更丰富的用户体验,例如在...

    android EditText 详解

    在Android开发中,`EditText`是用户界面(UI)组件之一,它允许用户输入文本。这个组件在许多应用场景中都非常重要,例如登录表单、注册页面、搜索栏等。本篇将深入解析`EditText`的各个方面,包括基本用法、属性...

    android-EditText边框颜色

    本教程将详细讲解如何在Android中改变`EditText`的边框颜色,适合初学者学习。 首先,我们要了解`EditText`的基本属性。`EditText`继承自`TextView`,并且添加了一些额外的功能,如文本输入和编辑。它的外观可以...

    Android完美解决listview中多个edittext显示混乱问题

    然而,在ListView中嵌套多个EditText时,常常会遇到一个问题,即用户在EditText中输入内容时,ListView滚动时导致显示混乱,原本输入的位置与EditText不匹配,这被称为“EditText焦点错乱”或“ListView复用机制问题...

    android 自定义带删除按钮的EditText

    在这里,我们通过LayoutInflater将一个包含EditText和删除按钮的布局文件加载到自定义视图中。布局文件`custom_edit_text_with_del.xml`可能如下所示: ```xml &lt;merge xmlns:android=...

    Android代码-android-edittext-validator

    Android Form EditText Android form edit text is an extension of EditText that brings data validation facilities to the edittext. Example App I built an example app that showcase some of the ...

    安卓EditText输入框相关-edittext失去焦点收起键盘.rar

    本资源“安卓EditText输入框相关-edittext失去焦点收起键盘.rar”可能包含了一系列与EditText交互,特别是如何在EditText失去焦点时自动收起软键盘的实践案例。由于无法直接查看压缩包内容,以下将根据常见需求和...

    Android代码-Android-EditText-Validations

    Android EditText Validations Easily Validate EditTexts This library is best used with Kotlin, and is to help reduce boilerplate code when writing validation rules for EditText fields. To install: ...

    Android开发EditText属性

    ### Android开发中的EditText属性详解 #### 一、引言 在Android应用开发中,`EditText`作为用户输入信息的关键组件之一,其丰富的属性为开发者提供了极大的灵活性和定制性。通过合理配置这些属性,可以实现多样化...

Global site tag (gtag.js) - Google Analytics