【Android开发日记】之基础篇(一)——TextView+SpannableStringBuilder

TextView是控件中最最基础的一个控件,也是最简单的一个控件。但如果仅此,我不会专门为TextView写一篇文章。最近发现了Android中有趣的一个类,那就是标题上写的SpannableStringBuilder。那么它是个什么东西呢?它可以为你的文字加上各种效果,像变色,各种符号,斜体,图片替换,高亮等等。如果想要文字加上一点常见的效果,我们大可不必再自己去写一个自定义的View,使用SpannableStringBuilder就能满足你的需求了。

 

一、TextView

首先是TextView的准备,跟平常的一样,先在布局文件中写好控件,再在代码中通过id获得引用。

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

    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/text_view" />

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/button" />

</LinearLayout>

 

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    
    tv = (TextView)findViewById(R.id.textView1);
    bt = (Button)findViewById(R.id.button1);
    bt.setOnClickListener(this);
    
}

二、SpannableStringBuilder

SpannableStringBuilder其实讲白了就是一个文本编辑器,通过套用不同的模式来改变文本的样子,其主要方法为

    /**
     * Mark the specified range of text with the specified object.
     * The flags determine how the span will behave when text is
     * inserted at the start or end of the span's range.
     */
    public void setSpan(Object what, int start, int end, int flags) {
        setSpan(true, what, start, end, flags);
    }

 

第一个参数是一个实现ParcelableSpan接口的一个类;

第二三个参数就是要改变文本的位置,起始点和终点;

第四个参数是用来对第二个和第三个参数进一步限制和说明的。

 

三、文本的例子

  1. 例子:通过点击按钮来改变文字
  2. 其中关键的点击事件的代码如下
    /*
         * 注意事项: SpannableStringBuilder.setSpan (new
         * ForegroundColorSpan(Color.RED), 1, 3,
         * Spannable.SPAN_EXCLUSIVE_INCLUSIVE); 第一个参数:颜色 第二个参数:开始位置 第三个参数:终止位置
         * 第三个参数:SPAN_EXCLUSIVE_INCLUSIVE.用来对第二个和第三个参数进一步限制和说明
         * 此处表示不包含1,但是包含3.从字面意思也很好理解
         */
        @Override
        public void onClick(View v) {
            String str = "Hello Cpacm! \nA preservation of the memory";
            SpannableStringBuilder builder = new SpannableStringBuilder(str);
            //设置颜色
            builder.setSpan(new ForegroundColorSpan(Color.RED), 0, 5,
            // setSpan时需要指定的 flag,Spanned.SPAN_EXCLUSIVE_EXCLUSIVE(前后都不包括).
                    Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
            //超链接
            builder.setSpan(new URLSpan("https://www.google.com"), 6, 12,
                    Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
            //粗斜体
            builder.setSpan(new StyleSpan(Typeface.BOLD_ITALIC), 12, 15,
                    Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
            //删除线
            builder.setSpan(new StrikethroughSpan(), 16, 29,
                    Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
            //图片替换文字
            Drawable d = getResources().getDrawable(R.drawable.ic_launcher);
            d.setBounds(0, 0, d.getIntrinsicWidth(), d.getIntrinsicHeight());
            // 创建ImageSpan
            ImageSpan span = new ImageSpan(d, ImageSpan.ALIGN_BASELINE);
            // 用ImageSpan替换文本
            builder.setSpan(span, 29, 31, Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
    
            builder.setSpan(new ForegroundColorSpan(Color.RED), 31, 36,
                    Spannable.SPAN_INCLUSIVE_INCLUSIVE);
            //删除文字
            builder.delete(36, 42);
            //添加文字
            builder.append("thing");
            //将文字赋予TextView
            tv.setText(builder);
        }

     

  3. 当然Span的类型不止这么几种,查了一下API,还有很多类型的Span,如下图。

    用法都是一样的
  4. 运行截图
        

 

四、结束语

说来惭愧,好久没有更新这个系列了,也是一直没有机会弄Android界面的原因。今天看到一个文字变化的工具类,所以就想着把TextView做了一下。

 
 

========================================

 

作者:cpacm
出处:(http://www.cnblogs.com/cpacm/p/4099031.html

posted @ 2014-11-15 11:25  cpacm  阅读(2082)  评论(0编辑  收藏  举报