zoukankan      html  css  js  c++  java
  • 【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! 
      A 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

  • 相关阅读:
    WiFi热点
    计算器
    flask的使用
    Python logging
    串口
    C# 定时器
    C# 控件
    cookie 和 session
    文件
    Linux命令
  • 原文地址:https://www.cnblogs.com/cpacm/p/4099031.html
Copyright © 2011-2022 走看看