TextView是控件中最最基础的一个控件,也是最简单的一个控件。但如果仅此,我不会专门为TextView写一篇文章。最近发现了Android中有趣的一个类,那就是标题上写的SpannableStringBuilder。那么它是个什么东西呢?它可以为你的文字加上各种效果,像变色,各种符号,斜体,图片替换,高亮等等。如果想要文字加上一点常见的效果,我们大可不必再自己去写一个自定义的View,使用SpannableStringBuilder就能满足你的需求了。
一、TextView
首先是TextView的准备,跟平常的一样,先在布局文件中写好控件,再在代码中通过id获得引用。
<LinearLayout xmlns:android="http:///apk/res/android"
xmlns:tools="http:///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(.textView1);
bt = (Button)findViewById(.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接口的一个类;
第二三个参数就是要改变文本的位置,起始点和终点;
第四个参数是用来对第二个和第三个参数进一步限制和说明的。
三、文本的例子
- 例子:通过点击按钮来改变文字
- 其中关键的点击事件的代码如下
/*
* 注意事项: 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://"), 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);
}- 当然Span的类型不止这么几种,查了一下API,还有很多类型的Span,如下图。
用法都是一样的 - 运行截图
四、结束语
说来惭愧,好久没有更新这个系列了,也是一直没有机会弄Android界面的原因。今天看到一个文字变化的工具类,所以就想着把TextView做了一下。
作者:cpacm
















