1. 程式人生 > >android中SpannableString之富文本顯示效果

android中SpannableString之富文本顯示效果

設置字體 vat rip other 圖片 點擊 oid intent logs

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()方法可以同時使用多個,實現多種效果疊加。


package
com.loaderman.androiddemo; import android.content.Intent; import android.graphics.Color; import android.graphics.Typeface; import android.graphics.drawable.Drawable; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.text.SpannableString; import android.text.Spanned;
import android.text.TextPaint; import android.text.method.LinkMovementMethod; import android.text.style.BackgroundColorSpan; import android.text.style.ClickableSpan; import android.text.style.ForegroundColorSpan; import android.text.style.ImageSpan; import android.text.style.RelativeSizeSpan; import android.text.style.StrikethroughSpan; import android.text.style.StyleSpan; import android.text.style.SubscriptSpan; import android.text.style.SuperscriptSpan; import android.text.style.URLSpan; import android.text.style.UnderlineSpan; import android.view.View; import android.widget.TextView; public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); TextView tv1 = findViewById(R.id.tv1); TextView tv2 = findViewById(R.id.tv2); TextView tv3 = findViewById(R.id.tv3); TextView tv4 = findViewById(R.id.tv4); TextView tv5 = findViewById(R.id.tv5); TextView tv6 = findViewById(R.id.tv6); TextView tv7 = findViewById(R.id.tv7); TextView tv8 = findViewById(R.id.tv8); TextView tv9 = findViewById(R.id.tv9); TextView tv10 = findViewById(R.id.tv10); TextView tv11 = findViewById(R.id.tv11); //設置字體前景色 SpannableString spannableString1 = new SpannableString("設置文字的前景色為淡藍色"); ForegroundColorSpan colorSpan1 = new ForegroundColorSpan(Color.parseColor("#0099EE")); spannableString1.setSpan(colorSpan1, 9, spannableString1.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE); tv1.setText(spannableString1); //設置字體背景色 SpannableString spannableString2 = new SpannableString("設置文字的背景色為淡綠色"); BackgroundColorSpan colorSpan2 = new BackgroundColorSpan(Color.parseColor("#AC00FF30")); spannableString2.setSpan(colorSpan2, 9, spannableString2.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE); tv2.setText(spannableString2); //設置字體大小 SpannableString spannableString3 = 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); spannableString3.setSpan(sizeSpan01, 0, 1, Spanned.SPAN_INCLUSIVE_EXCLUSIVE); spannableString3.setSpan(sizeSpan02, 1, 2, Spanned.SPAN_INCLUSIVE_EXCLUSIVE); spannableString3.setSpan(sizeSpan03, 2, 3, Spanned.SPAN_INCLUSIVE_EXCLUSIVE); spannableString3.setSpan(sizeSpan04, 3, 4, Spanned.SPAN_INCLUSIVE_EXCLUSIVE); spannableString3.setSpan(sizeSpan05, 4, 5, Spanned.SPAN_INCLUSIVE_EXCLUSIVE); spannableString3.setSpan(sizeSpan06, 5, 6, Spanned.SPAN_INCLUSIVE_EXCLUSIVE); spannableString3.setSpan(sizeSpan07, 6, 7, Spanned.SPAN_INCLUSIVE_EXCLUSIVE); tv3.setText(spannableString3); //設置刪除線 SpannableString spannableString4 = new SpannableString("為文字設置刪除線"); StrikethroughSpan strikethroughSpan4 = new StrikethroughSpan(); spannableString4.setSpan(strikethroughSpan4, 5, spannableString4.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE); tv4.setText(spannableString4); //設置下劃線 SpannableString spannableString5 = new SpannableString("為文字設置下劃線"); UnderlineSpan underlineSpan5 = new UnderlineSpan(); spannableString5.setSpan(underlineSpan5, 5, spannableString5.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE); tv5.setText(spannableString5); //設置上標 SpannableString spannableString6 = new SpannableString("為文字設置上標"); SuperscriptSpan superscriptSpan6 = new SuperscriptSpan(); spannableString6.setSpan(superscriptSpan6, 5, spannableString6.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE); tv6.setText(spannableString6); // 設置下標 SpannableString spannableString7 = new SpannableString("為文字設置下標"); SubscriptSpan subscriptSpan7 = new SubscriptSpan(); spannableString7.setSpan(subscriptSpan7, 5, spannableString7.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE); tv7.setText(spannableString7); //設置粗體和斜體 SpannableString spannableString8 = new SpannableString("為文字設置粗體、斜體風格"); StyleSpan styleSpan_B = new StyleSpan(Typeface.BOLD); StyleSpan styleSpan_I = new StyleSpan(Typeface.ITALIC); spannableString8.setSpan(styleSpan_B, 5, 7, Spanned.SPAN_INCLUSIVE_EXCLUSIVE); spannableString8.setSpan(styleSpan_I, 8, 10, Spanned.SPAN_INCLUSIVE_EXCLUSIVE); tv8.setHighlightColor(Color.parseColor("#36969696")); tv8.setText(spannableString8); //設置圖片表情等 SpannableString spannableString9 = new SpannableString("在文本中添加表情(表情)"); Drawable drawable9 = getResources().getDrawable(R.mipmap.a9c); drawable9.setBounds(0, 0, 42, 42); ImageSpan imageSpan9 = new ImageSpan(drawable9); spannableString9.setSpan(imageSpan9, 6, 8, Spanned.SPAN_INCLUSIVE_EXCLUSIVE); tv9.setText(spannableString9); //設置點擊事件 SpannableString spannableString10 = new SpannableString("為文字設置點擊事件"); MyClickableSpan clickableSpan = new MyClickableSpan("https://www.cnblogs.com/loaderman/"); spannableString10.setSpan(clickableSpan, 5, spannableString10.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE); tv10.setMovementMethod(LinkMovementMethod.getInstance()); tv10.setHighlightColor(Color.parseColor("#36969696")); tv10.setText(spannableString10); //設置超鏈接 SpannableString spannableString11 = new SpannableString("為文字設置超鏈接"); URLSpan urlSpan11 = new URLSpan("https://www.cnblogs.com/loaderman/"); spannableString11.setSpan(urlSpan11, 5, spannableString11.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE); tv11.setMovementMethod(LinkMovementMethod.getInstance()); tv11.setHighlightColor(Color.parseColor("#36969696")); tv11.setText(spannableString11); } 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); } } }

效果

技術分享圖片

android中SpannableString之富文本顯示效果