Android 文本增強使用:SpannableString

SpannableString其實和String一樣,都是一種字符串類型,SpannableString可以直接作爲TextView的顯示文本,不同的是SpannableString可以通過使用其方法setSpan方法實現字符串各種形式風格的顯示,重要的是可以指定設置的區間,也就是爲字符串指定下標區間內的子字符串設置格式。

setSpan(Object what, int start, int end, int flags)方法需要用戶輸入四個參數,what表示設置的格式是什麼,可以是前景色、背景色也可以是可點擊的文本等等,start表示需要設置格式的子字符串的起始下標,同理end表示終了下標,flags屬性就有意思了,共有四種屬性:

Spanned.SPAN_INCLUSIVE_EXCLUSIVE 從起始下標到終了下標,包括起始下標
Spanned.SPAN_INCLUSIVE_INCLUSIVE 從起始下標到終了下標,同時包括起始下標和終了下標
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE 從起始下標到終了下標,但都不包括起始下標和終了下標
Spanned.SPAN_EXCLUSIVE_INCLUSIVE 從起始下標到終了下標,包括終了下標

SpannableString的setSpan()方法可以同時使用多個,實現多種效果疊加。

下面我們一一解讀幾種Span常用的格式:

  • ForegroundColorSpan

 

 

ForegroundColorSpan,爲文本設置前景色,效果和TextView的setTextColor()類似,實現方法如下:

SpannableString spannableString = new SpannableString("設置文字的前景色爲淡藍色");
ForegroundColorSpan colorSpan = new ForegroundColorSpan(Color.parseColor("#0099EE"));
spannableString.setSpan(colorSpan, 9, spannableString.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE); 
textView.setText(spannableString);

設置的區間是9到字符串的最後,也就是圖中“淡藍色”三字。

  • BackgroundColorSpan

 

 

BackgroundColorSpan,爲文本設置背景色,效果和TextView的setBackground()類,實現方法如下:

SpannableString spannableString = new SpannableString("設置文字的背景色爲淡綠色");
BackgroundColorSpan colorSpan = new BackgroundColorSpan(Color.parseColor("#AC00FF30"));
spannableString.setSpan(colorSpan, 9, spannableString.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
textView.setText(spannableString);
  • RelativeSizeSpan

 

 

RelativeSizeSpan,設置文字相對大小,在TextView原有的文字大小的基礎上,相對設置文字大小,實現方法如下:

SpannableString spannableString = new SpannableString("萬丈高樓平地起");

RelativeSizeSpan sizeSpan01 = new RelativeSizeSpan(1.2f);
RelativeSizeSpan sizeSpan02 = new RelativeSizeSpan(1.4f);
RelativeSizeSpan sizeSpan03 = new RelativeSizeSpan(1.6f);
RelativeSizeSpan sizeSpan04 = new RelativeSizeSpan(1.8f);
RelativeSizeSpan sizeSpan05 = new RelativeSizeSpan(1.6f);
RelativeSizeSpan sizeSpan06 = new RelativeSizeSpan(1.4f);
RelativeSizeSpan sizeSpan07 = new RelativeSizeSpan(1.2f);

spannableString.setSpan(sizeSpan01, 0, 1, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
spannableString.setSpan(sizeSpan02, 1, 2, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
spannableString.setSpan(sizeSpan03, 2, 3, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
spannableString.setSpan(sizeSpan04, 3, 4, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
spannableString.setSpan(sizeSpan05, 4, 5, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
spannableString.setSpan(sizeSpan06, 5, 6, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
spannableString.setSpan(sizeSpan07, 6, 7, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
textView.setText(spannableString);
  • StrikethroughSpan

 

 

StrikethroughSpan,爲文本設置中劃線,也就是常說的刪除線,實現方法如下:

SpannableString spannableString = new SpannableString("爲文字設置刪除線");
StrikethroughSpan strikethroughSpan = new StrikethroughSpan();
spannableString.setSpan(strikethroughSpan, 5, spannableString.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
textView.setText(spannableString);

看到這有沒有小激動,分分鐘實現天貓打折優惠效果,有木有?

  • UnderlineSpan

 

 

UnderlineSpan,爲文本設置下劃線,具體實現方法如下:

SpannableString spannableString = new SpannableString("爲文字設置下劃線");
UnderlineSpan underlineSpan = new UnderlineSpan();
spannableString.setSpan(underlineSpan, 5, spannableString.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
textView.setText(spannableString);
  • SuperscriptSpan

 

 

SuperscriptSpan,設置上標,具體實現方法如下:

SpannableString spannableString = new SpannableString("爲文字設置上標");
SuperscriptSpan superscriptSpan = new SuperscriptSpan();
spannableString.setSpan(superscriptSpan, 5, spannableString.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
textView.setText(spannableString);

從效果圖可以看出,被設置爲上標的文字大小和下面的文本文字大小一樣,只要我們稍加修飾,結合RelativeSizeSpan設置小字體文本作爲上標,分分鐘實現指數公式有木有,再也不用2^2+3^2=13這樣缺乏審美的數學公式了,是不是超實用?

  • SubscriptSpan

 

 

SubscriptSpan,設置下標,功能與設置上標類似,不做過多描述,具體實現方法如下:

SpannableString spannableString = new SpannableString("爲文字設置下標");
SubscriptSpan subscriptSpan = new SubscriptSpan();
spannableString.setSpan(subscriptSpan, 5, spannableString.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
textView.setText(spannableString);
  • StyleSpan

 

 

StyleSpan,爲文字設置風格(粗體、斜體),和TextView屬性textStyle類似,實現方法如下:

SpannableString spannableString = new SpannableString("爲文字設置粗體、斜體風格");
StyleSpan styleSpan_B  = new StyleSpan(Typeface.BOLD);
StyleSpan styleSpan_I  = new StyleSpan(Typeface.ITALIC);
spannableString.setSpan(styleSpan_B, 5, 7, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
spannableString.setSpan(styleSpan_I, 8, 10, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
textView.setHighlightColor(Color.parseColor("#36969696"));
textView.setText(spannableString);
  • ImageSpan

 

 

ImageSpan,設置文本圖片,實現方法如下:

SpannableString spannableString = new SpannableString("在文本中添加表情(表情)");
Drawable drawable = getResources().getDrawable(R.mipmap.a9c);
drawable.setBounds(0, 0, 42, 42);
ImageSpan imageSpan = new ImageSpan(drawable);
spannableString.setSpan(imageSpan, 6, 8, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
textView.setText(spannableString);

這一個是不是很炫酷?再加一個解析算法,將文本中特定的文本轉換成特定的表情圖片,分分鐘實現聊天表情顯示效果有木有啊朋友們!

  • ClickableSpan

 

 

ClickableSpan,設置可點擊的文本,設置這個屬性的文本可以相應用戶點擊事件,至於點擊事件用戶可以自定義,就像效果圖顯示一樣,用戶可以實現點擊跳轉頁面的效果,具體實現方法如下:

SpannableString spannableString = new SpannableString("爲文字設置點擊事件");
MyClickableSpan clickableSpan = new MyClickableSpan("http://www.jianshu.com/users/dbae9ac95c78");
spannableString.setSpan(clickableSpan, 5, spannableString.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
textView.setMovementMethod(LinkMovementMethod.getInstance());
textView.setHighlightColor(Color.parseColor("#36969696")); 
textView.setText(spannableString);

/***************************************************************/

class MyClickableSpan extends ClickableSpan {

    private String content;

    public MyClickableSpan(String content) {
        this.content = content;
    }

    @Override
    public void updateDrawState(TextPaint ds) {
        ds.setUnderlineText(false);
    }

    @Override
    public void onClick(View widget) {
        Intent intent = new Intent(MainActivity.this, OtherActivity.class);
        Bundle bundle = new Bundle();
        bundle.putString("content", content);
        intent.putExtra("bundle", bundle);
        startActivity(intent);
    }
}

代碼中我們自定義MyClickableSpan類,繼承至ClickableSpan,並重寫其中一些方法。ds.setUnderlineText()控制是否讓可點擊文本顯示下劃線,很明顯,在上面代碼中我選擇了false,不顯示下滑寫。onClick點擊事件的具體實現方法寫在其中。如上代碼,我們重寫ClickableSpan的onClick方法實現Activity的跳轉效果,並傳遞跳轉數據。

注意:使用ClickableSpan的文本如果想真正實現點擊作用,必須爲TextView設置setMovementMethod方法,否則沒有點擊相應,至於setHighlightColor方法則是控制點擊是的背景色。

  • URLSpan

 

 

URLSpan,設置超鏈接文本,其實聰明的小夥幫在講到ClickableSpan的時候就能實現超鏈接文本的效果了,重寫onClick點擊事件就行,也確實看了URLSpan的源碼,URLSpan就是繼承自ClickableSpan,也和想象中一樣,就是重寫了父類的onClick事件,用系統自帶瀏覽器打開鏈接,具體實現方法如下:

SpannableString spannableString = new SpannableString("爲文字設置超鏈接");
URLSpan urlSpan = new URLSpan("http://www.jianshu.com/users/dbae9ac95c78");
spannableString.setSpan(urlSpan, 5, spannableString.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
textView.setMovementMethod(LinkMovementMethod.getInstance());
textView.setHighlightColor(Color.parseColor("#36969696"));
textView.setText(spannableString);

URLSpanonClick事件的源碼如下:

@Override
public void onClick(View widget) {
    Uri uri = Uri.parse(getURL());
    Context context = widget.getContext();
    Intent intent = new Intent(Intent.ACTION_VIEW, uri);
    intent.putExtra(Browser.EXTRA_APPLICATION_ID, context.getPackageName());
    try {
        context.startActivity(intent);
    } catch (ActivityNotFoundException e) {
        Log.w("URLSpan", "Actvity was not found for intent, " + intent.toString());
    }
}

除此之外,還有MaskFilterSpan可以實現模糊和浮雕效果,RasterizerSpan可以實現光柵效果,因爲以上兩個使用頻率不高,而且效果也不是很明顯,就不做詳細說明,有興趣的小夥伴不妨去試一試。

SpannableStringBuilder

應該有不少開發的小夥伴知道StringBuilder,可以使用append()方法實現字符串拼接,非常方便。同樣,SpannableString中也有SpannableStringBuilder,顧名思義,就是實現對,SpannableString的一個拼接效果,同樣是append()方法,可以實現各種風格效果的SpannableString拼接,非常實用。

 

原文鏈接:https://www.cnblogs.com/qynprime/p/8026672.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章