1. 程式人生 > >Android textView文字新增圖片 imageSpan使用

Android textView文字新增圖片 imageSpan使用

如果想為一段文字新增圖片,那麼可以用到imageSpan來很好的實現

程式碼:

tvTest = (TextView) findViewById(R.id.test);  
  
CharSequence text = "效果測試★,效果測試,效果★測試";  
SpannableStringBuilder builder = new SpannableStringBuilder(text);  
String rexgString = "★";  
Pattern pattern = Pattern.compile(rexgString);  
Matcher matcher = pattern.matcher(text);  
  
while (matcher.find()) {  
    builder.setSpan(  
            new ImageSpan(this, R.drawable.ic_launcher), matcher.start(), matcher  
                    .end(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);  
}  
  
<pre name="code" class="java">tvTest<span style="font-family: Arial, Helvetica, sans-serif;">.setText(builder); </span>
效果圖:

如果需要多段文字用圖片進行分辨,可以用StringBuilder新增特殊字元進行區分.

如果知道需要替換圖片的位置,也可以用這種方法:

<span style="white-space:pre">	</span>Bitmap b = BitmapFactory.decodeResource(getResources(), R.drawable.<span style="font-family: Arial, Helvetica, sans-serif;">ic_launcher</span>);  
        ImageSpan imgSpan = new ImageSpan(this, b);  
        SpannableString spanString = new SpannableString("icon");  
        spanString.setSpan(imgSpan, 0, 4, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);  
        textView2.setText(spanString);  
        textView2.append("測試效果測試效果測試效果");
效果圖:

這種是替換某個文字的方法.如果不需要替換,可以在

SpannableString spanString = new SpannableString("icon"); 

直接放入全部文字,然後確定需要放入圖片的位置即可

SpannableString還有很多其他用法,可以設定指定文字大小,顏色,下劃線等效果

    1、BackgroundColorSpan 背景色 
    2、ClickableSpan 文字可點選,有點選事件

    3、ForegroundColorSpan 文字顏色(前景色)
    4、MaskFilterSpan 修飾效果,如模糊(BlurMaskFilter)、浮雕(EmbossMaskFilter)


    5、MetricAffectingSpan 父類,一般不用
6、RasterizerSpan 光柵效果
7、StrikethroughSpan 刪除線(中劃線)
8、SuggestionSpan 相當於佔位符
9、UnderlineSpan 下劃線
10、AbsoluteSizeSpan 絕對大小(文字字型)
11、DynamicDrawableSpan 設定圖片,基於文字基線或底部對齊。
12、ImageSpan 圖片
13、RelativeSizeSpan 相對大小(文字字型)
14、ReplacementSpan 父類,一般不用
15、ScaleXSpan 基於x軸縮放
16、StyleSpan 字型樣式:粗體、斜體等
17、SubscriptSpan 下標(數學公式會用到)
18、SuperscriptSpan 上標(數學公式會用到)
19、TextAppearanceSpan 文字外貌(包括字型、大小、樣式和顏色)
20、TypefaceSpan 文字字型

21、URLSpan 文字超連結

大家需要什麼需求了可以繼續查詢使用方法