您的位置:首页 > 移动开发 > Android开发

Android学习 11 ->控件之TextView和EditText

2015-06-18 16:31 190 查看
文本控件(TextView)是用来显示文本的,是最常用最基本的控件;文本输入控件(EditText)是用户与数据传输进行交互,用户把数据传输给Android应用后得到我们想要的数据。EditText是TextView的子类,所以TextView的方法和特性同样存在于EditText中。

文本控件(TextView):

1、常用属性

android:text=”@string/welcome_android” //文本

android:textColor=”@android:color/holo_red_dark” //字体颜色

android:textSize=”24sp” //字体大小

2.内边距与外边距:内边距padding作用于控件内部,是控件内内容与边框的距离;外边距则是控件之间相隔的距离。如下面所示的内容:

android:padding=”10dp”

android:layout_margin=”10dp”



3、让TextView显示一行,或是文字超过TextView的长度怎么办?

1>.在开头显示省略号

android:singleLine=”true”

android:ellipsize=”start”

2>.在结尾显示省略号

android:singleLine=”true”

android:ellipsize=”end”

3>.在中间显示省略号

android:singleLine=”true”

android:ellipsize=”middle”





4.横向自动滚动(跑马灯效果)





android:singleLine=”true”

android:ellipsize=”marquee”

android:marqueeRepeatLimit=”marquee_forever”

android:focusable=”true”

android:focusableInTouchMode=”true”

以上4个效果都要加上 android:singleLine=”true”,因为TextView默认是š自动换行的android:ellipsize是设置文字过长时,该怎么显示android:marqueeRepeatLimit=”marquee_forever”是设置永远重复,当然à也可以设置具Ó的数字

android:focusable=”true”和android:focusableInTouchMode=”true”一定要加上,不然滚动效果出不来

5.怎么让TextView可以垂直滚动?

在Java代码中加入下面一句话就可以实现垂直滚动textView.setMovementMethod(ScrollingMovementMethod.getInstance());

6.RichTextView(富文本)

怎么实现在同一个TextView中设置不同的字Ó风格呢?

需要ÿ用的类:android.text.Spanned; android.text.SpannableString; android.text.SpannableStringBuilder

SpannableString和SpannableStringBuilder的区别就相当于String和StringBuffer

SpannableString和SpannableStringBuilder可以用来设置不同的Span,这些Span便是用于实现Rich TextView,比如粗Ó,斜Ó,前景色,背景色,字Ó大小,字Ó风格等等,android.text.style.*中定义了很多的Span类型可供ÿ用。

常见的Span见下面的Demo

setSpan(Object what, int start, int end, int flags)中的flags可以设为0或Spanned中定值Spanned.SPAN_EXCLUSIVE_EXCLUSIVE — 不包含两端start和end所在的端点Spanned.SPAN_EXCLUSIVE_INCLUSIVE — 不包含start,Æ包含end

Spanned.SPAN_INCLUSIVE_EXCLUSIVE — 包含start,Æ不包含end

Spanned.SPAN_INCLUSIVE_INCLUSIVE— 包含start和end所在的端点

其中0就相当于Spanned.SPAN_INCLUSIVE_INCLUSIVE

这里的包不包含就好比数学里面的开区间,闭区间

下面有个Demo是Copy的:

<span style="font-size:18px;"><span style="font-size:18px;">package com.tianjf;

import android.app.Activity;
import android.graphics.Color;
import android.graphics.drawable.Drawable;
import android.os.Bundle;
import android.text.SpannableString;
import android.text.Spanned;
import android.text.method.LinkMovementMethod;
import android.text.style.AbsoluteSizeSpan;
import android.text.style.BackgroundColorSpan;
import android.text.style.BulletSpan;
import android.text.style.ForegroundColorSpan;
import android.text.style.ImageSpan;
import android.text.style.RelativeSizeSpan;
import android.text.style.ScaleXSpan;
import android.text.style.StrikethroughSpan;
import android.text.style.StyleSpan;
import android.text.style.SubscriptSpan;
import android.text.style.SuperscriptSpan;
import android.text.style.TypefaceSpan;
import android.text.style.URLSpan;
import android.text.style.UnderlineSpan;
import android.widget.TextView;

public class RichTextViewDemoActivity extends Activity {

TextView mTextView = null;
SpannableString mSpannableString = null;

@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);

mTextView = (TextView) findViewById(R.id.myTextView);

// 创建一个 SpannableString对象
mSpannableString = new SpannableString(
"字体测试字体大小一半两倍前景色背景色正常粗体斜体粗斜体下划线删除线x1x2电话邮件网站短信彩信地图X轴/bot");

// 设置字体(default,default-bold,monospace,serif,sans-serif)
mSpannableString.setSpan(new TypefaceSpan("monospace"), 0, 2,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
mSpannableString.setSpan(new TypefaceSpan("sans-serif"), 2, 4,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

// 设置字体大小(绝对值,单位:像素)
mSpannableString.setSpan(new AbsoluteSizeSpan(20), 4, 8,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

// 设置字体大小(相对值,单位:像素) 参数表示为默认字体宽度的多少倍
mSpannableString.setSpan(new ScaleXSpan(2.0f), 49, 51,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 2.0f表示默认字体宽度的两倍,即X轴方向放大为默认字体的两倍,而高度不变

// 设置字体大小(相对值,单位:像素) 参数表示为默认字体大小的多少倍
mSpannableString.setSpan(new RelativeSizeSpan(0.5f), 8, 10,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 0.5f表示默认字体大小的一半
mSpannableString.setSpan(new RelativeSizeSpan(2.0f), 10, 12,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 2.0f表示默认字体大小的两倍

// 设置字体前景色
mSpannableString.setSpan(new ForegroundColorSpan(Color.MAGENTA), 12,
15, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 设置前景色为洋红色

// 设置字体背景色
mSpannableString.setSpan(new BackgroundColorSpan(Color.CYAN), 15, 18,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 设置背景色为青色

// 设置字体样式正常,粗体,斜体,粗斜体
mSpannableString.setSpan(
new StyleSpan(android.graphics.Typeface.NORMAL), 18, 20,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 正常
mSpannableString.setSpan(new StyleSpan(android.graphics.Typeface.BOLD),
20, 22, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 粗体
mSpannableString.setSpan(
new StyleSpan(android.graphics.Typeface.ITALIC), 22, 24,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 斜体
mSpannableString.setSpan(new StyleSpan(
android.graphics.Typeface.BOLD_ITALIC), 24, 27,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 粗斜体

// 设置下划线
mSpannableString.setSpan(new UnderlineSpan(), 27, 30,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

// 设置删除线
mSpannableString.setSpan(new StrikethroughSpan(), 30, 33,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

// 设置上下标
mSpannableString.setSpan(new SubscriptSpan(), 34, 35,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 下标
mSpannableString.setSpan(new SuperscriptSpan(), 36, 37,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 上标

// 超级链接(需要添加setMovementMethod方法附加响应)
mSpannableString.setSpan(new URLSpan("tel:4155551212"), 37, 39,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 电话
mSpannableString.setSpan(new URLSpan("mailto:webmaster@google.com"),
39, 41, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 邮件
mSpannableString.setSpan(new URLSpan("http://www.baidu.com"), 41, 43,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 网络
mSpannableString.setSpan(new URLSpan("sms:4155551212"), 43, 45,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 短信 使用sms:或者smsto:
mSpannableString.setSpan(new URLSpan("mms:4155551212"), 45, 47,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 彩信 使用mms:或者mmsto:
mSpannableString.setSpan(new URLSpan("geo:38.899533,-77.036476"), 47,
49, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); // 地图

// 设置项目符号
// 第一个参数表示项目符号占用的宽度,第二个参数为项目符号的颜色
mSpannableString.setSpan(new BulletSpan(
android.text.style.BulletSpan.STANDARD_GAP_WIDTH, Color.GREEN),
0, mSpannableString.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

// 设置图片
Drawable drawable = getResources().getDrawable(R.drawable.ic_launcher);
drawable.setBounds(0, 0, drawable.getIntrinsicWidth(),
drawable.getIntrinsicHeight());
mSpannableString.setSpan(new ImageSpan(drawable), 51, 55,
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

mTextView.setText(mSpannableString);
mTextView.setMovementMethod(LinkMovementMethod.getInstance());
}
}
</span></span>


文本输入控件(EditText):

其属性有:android:enabled=" " //false表示文本框不能输入,默认为true可以输入

android:maxlength=" "//限制输入的字符的长度

android:hint=" "//文本输入内容提示,当输入内容时提示会消失

android:textcolor=" "//设置字体的颜色

android:password=" "//ture密文形式输如

android:inputyype=" "//设置软键盘的类型

android:phonenumber=" "//以电话号码输入

android:enabled="false" //使控件不可以被编辑,可以获得焦点

android:textColorHint=" "//设置提示文字的颜色 等

当我们需要说明你定义的这个EditText是做什么用的,比如让输入“用户名”,或者输入“电话号码”等,但是你又不想在EditText前面加一个TextView来说明这是输入“用户名”的,因为这会使用一个TextView,那么怎么办呢?EditText为我们提供了android:hint来设置当EditText内容为空时显示的文本,这个文本只在EditText为空时显示,你输入字符的时候就消失了,不影响你的EditText的文本。其修改的xml如下:

<span style="font-size:18px;"><?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>  </span>


上面列出的空白提示文字,不想是系统的灰色提示文字,这样和应用的整体风格不协调,这样我们也可以改变提示文字的颜色,通过android:textColorHint属性来设置想要的字体颜色。其修改的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>


密码文本框:密码输入应用是常用的功能,通过android:password="true"来实现密码输入的功能。其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>

通过上面的代码,我们输入的密码就会在输入后以“*”代替掉,保证了密码输入的时候不被别人看见。

手机中发短信打电话是必不可少的功能,所以在android中有专门输入电话号码的文本输入框,这样也是的我们对输入的是否是电话号码的校验也容易了很多,通过android:phoneNumber="true" 来讲EditText设置成只接受电话号码输入的文本框,使得输入的软键盘也变成拨号专用的软键盘,这样就不再担心输入的是其他的字符了。其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>


若我们只想输入数字而不想是其他字符的时候,通过android:numeric属性来控制输入的数字类型,一般分为三种类型integer(正整数)、signed(带符号的整数)以及decimal(浮点型)。再此以signed为例,其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属性来设置文本输入的类型,让软键盘选择合适的格式。由于可以选用的类型有很多,再次只以date的类型来演示一下操作,其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>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: