UI控件之显示文本控件TextView(上)

(一)概述
TextView主要是在android中实现文字说明等功能。
(二)常用基本属性
No.1 TextView控件自带属性的使用
UI控件之显示文本控件TextView(上)_第1张图片
运行效果:

实现代码:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" >

    <TextView  android:id="@+id/myTextView" android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="#CDFFFF" android:text="TextView基本属性的使用" android:paddingLeft="100dp" android:gravity="right" android:textColor="#AC0F0D" android:textStyle="italic" android:textSize="20sp"/>

</RelativeLayout>

代码说明:
android:paddingLeft=”100dp”文本内容的左内边距为100dp;
android:gravity=”right”将文本的对齐方式设置为右对齐;
android:textColor=”#AC0F0D”文本颜色设置为红色;
android:textStyle=”italic”文本显示方式设置为斜体;
android:textSize=”20sp”文本大小为20sp

No.2 TextView中HTML标签属性的使用
在TextView中预定了一些类似HTML的标签,通过标签可以使TextView控件显得不懂颜色、大小、字体的文字。

<font>:设置颜色和字体
<big>:设置大小号
<small>:设置小号
<i>\<b>:斜体、粗体
<a>:链接地址
<img>:插入图片

使用这些标签可以用Html.fromHtml方法将这些标签的字符串转换成Charsequenece对象,然后在TextView中进行设置。
如果想在显示的文本中将URL地址、邮箱地址、电话产生超链接的效果可以使用android:autoLink来设置。
该属性如下:

运行效果如下:
UI控件之显示文本控件TextView(上)_第2张图片
实现代码如下:

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" >

    <TextView  android:id="@+id/TextView_1" android:background="#FFF" android:layout_width="match_parent" android:layout_height="wrap_content" />

</LinearLayout>

效果实现代码

package com.example.android_textview;

import java.io.FileDescriptor;
import java.lang.reflect.Field;

import javax.xml.transform.Source;

import android.app.Activity;
import android.graphics.Color;
import android.graphics.drawable.Drawable;
import android.os.Bundle;
import android.text.Html;
import android.text.Html.ImageGetter;
import android.text.method.LinkMovementMethod;
import android.view.View;
import android.widget.TextView;

/** * 实战案例一:如何显示文本(URL、不同大小、字体、颜色的文本) * @author Administrator * */
public class TextViewTest_1 extends Activity {



    @Override
    protected void onCreate(Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        super.onCreate(savedInstanceState);
        setContentView(R.layout.text_view_test_1);
        TextView TextView_1 = (TextView) findViewById(R.id.TextView_1);
        TextView_1.setTextColor(Color.GREEN);//设置TextView的文本颜色;
        TextView_1.setBackgroundColor(Color.BLACK);//设置TextView的文本颜色;
        TextView_1.setTextSize(20);//设置TextView的文本大小;
        /** * * 在TextView中预定了一些类似HTML的标签,通过标签可以使TextView控件显得不懂颜色、大小、字体的文字。 * <font>:设置颜色和字体 * <big>:设置大小号 * <small>:设置小号 * <i>\<b>:斜体、粗体 * <a>:链接地址 * <img>:插入图片 */
        String html = "图像1<img src='image1'/>图像2<img src='image2'/>图像3<img src='image3'/><p>";
        html += "图像4<a href='http://www.baidu.com'><img src='image4'></a>图像5<img src='image5'/>";

        /** * CharSequence 是 char 值的一个可读序列。 * CharSequence对html标签进行序列化 * */
        CharSequence charSequence = Html.fromHtml(html, new ImageGetter() {


            @Override
            public Drawable getDrawable(String source) {
                // TODO Auto-generated method stub
                //获取系统资源的信息,比如图片信息
                Drawable drawable = getResources().getDrawable(getResourceId(source));
                //第三个图片文件按照50%的比例进行压缩
                //getIntrinsicWidth()获取固有宽度,getIntrinsicHeight()获取固有高度;

                if (source.equals("image3")) {
                    drawable.setBounds(0 , 0 ,drawable.getIntrinsicWidth()/2 , 
                            drawable.getIntrinsicHeight()/2);
                }else{
                    drawable.setBounds(0 , 0 ,drawable.getIntrinsicWidth() ,
                            drawable.getIntrinsicHeight());
                }
                return drawable;
            }
        }, null);

        TextView_1.setText(charSequence);
        TextView_1.setMovementMethod(LinkMovementMethod.getInstance());
    }

    protected int getResourceId(String name) {
        // TODO Auto-generated method stub

        try {
            //根据资源的ID的变量名获得Field的对象,使用反射机制来实现
            Field  field = R.drawable.class.getField(name);
            //取得并返回资源的ID的字段(静态变量)的值,使用反射机制
            return Integer.parseInt(field.get(null).toString());
        } catch (Exception e) {

        }

        return 0;
    }
}

代码解析:
定义了String型的html将“图像2<img src='image2'/>“中的文本与图片集合在一起,使用<a href='http://www.baidu.com'>定义了一个点击图片进入百度的连接;用Html.fromHtml方法将这些标签的字符串转换成Charsequenece对象(即进行序列化),然后TextView_1调用它的setText()进行了设置,调用 setMovementMethod()来允许被TextView使用handle的key,即该TextView可以使用handle的机制来更新UI;主要是实现了点击“图片3”的View后会发生跳转的功能,剩下的是使getResourceId()方法来获取资源Id,将其传给getDrawable()方法进行图片绘制,其中,图片2是按照宽高各一半来进行绘制的;

No.3 TextView中autoLink属性识别链接类型
当文字中出现了URL,E-Mail,电话号码,地图的时候,我们可以通过设置autoLink属性;当我们点击文字中对应部分的链接,即可跳转至某默认app,比如一串号码,点击后跳转至拨号界面;
UI控件之显示文本控件TextView(上)_第3张图片

运行效果:

UI控件之显示文本控件TextView(上)_第4张图片

UI控件之显示文本控件TextView(上)_第5张图片

完毕~~~下节我们进入实战应用。

你可能感兴趣的:(android,textview,属性,应用,autoLink)