1.html方式:html
String str = "<font color='red'>中軟</font>" + "<font color= 'green'>國際</font>"; TextView tvTitle = (TextView) findViewById(R.id.tvTitle); tvTitle.setText(Html.fromHtml(str));
2. style方式:java
SpannableString styledText = new SpannableString("親愛的小寶,你好"); styledText.setSpan(new TextAppearanceSpan(this, R.style.textColorBlack6), 0, 3, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); styledText.setSpan(new TextAppearanceSpan(this, R.style.textColorGreen), 3, 5, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); TextView tvCom = (TextView) findViewById(R.id.tvCom); tvCom.setText(styledText,TextView.BufferType.SPANNABLE);
<style name="textColorBlack6"> <item name="android:textColor">@color/black6</item> <item name="android:textStyle">italic</item> </style> <style name="textColorGreen"> <item name="android:textColor">@color/green</item> </style> <style name="textColorBlack"> <item name="android:textColor">@color/black</item> </style> <style name="textColorRed"> <item name="android:textColor">@color/buyRed</item> </style>
特殊處理:android
//建立一個 SpannableString對象 SpannableString msp = new SpannableString("字體測試字體大小一半兩倍前景色背景色正常粗體斜體粗斜體下劃線刪除線x1x2電話郵件網站短信彩信地圖X軸綜合"); //設置字體(default,default-bold,monospace,serif,sans-serif) msp.setSpan(new TypefaceSpan("monospace"), 0, 2, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); msp.setSpan(new TypefaceSpan("serif"), 2, 4, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //設置字體大小(絕對值,單位:像素) msp.setSpan(new AbsoluteSizeSpan(20), 4, 6, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); msp.setSpan(new AbsoluteSizeSpan(20,true), 6, 8, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //第二個參數boolean dip,若是爲true,表示前面的字體大小單位爲dip,不然爲像素,同上。 //設置字體大小(相對值,單位:像素) 參數表示爲默認字體大小的多少倍 msp.setSpan(new RelativeSizeSpan(0.5f), 8, 10, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //0.5f表示默認字體大小的一半 msp.setSpan(new RelativeSizeSpan(2.0f), 10, 12, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //2.0f表示默認字體大小的兩倍 //設置字體前景色 msp.setSpan(new ForegroundColorSpan(Color.MAGENTA), 12, 15, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //設置前景色爲洋紅色 //設置字體背景色 msp.setSpan(new BackgroundColorSpan(Color.CYAN), 15, 18, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //設置背景色爲青色 //設置字體樣式正常,粗體,斜體,粗斜體 msp.setSpan(new StyleSpan(android.graphics.Typeface.NORMAL), 18, 20, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //正常 msp.setSpan(new StyleSpan(android.graphics.Typeface.BOLD), 20, 22, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //粗體 msp.setSpan(new StyleSpan(android.graphics.Typeface.ITALIC), 22, 24, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //斜體 msp.setSpan(new StyleSpan(android.graphics.Typeface.BOLD_ITALIC), 24, 27, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //粗斜體 //設置下劃線 msp.setSpan(new UnderlineSpan(), 27, 30, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //設置刪除線 msp.setSpan(new StrikethroughSpan(), 30, 33, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //設置上下標 msp.setSpan(new SubscriptSpan(), 34, 35, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //下標 msp.setSpan(new SuperscriptSpan(), 36, 37, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //上標 //超級連接(須要添加setMovementMethod方法附加響應) msp.setSpan(new URLSpan("tel:4155551212"), 37, 39, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //電話 msp.setSpan(new URLSpan("mailto:webmaster@google.com"), 39, 41, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //郵件 msp.setSpan(new URLSpan("http://www.baidu.com"), 41, 43, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //網絡 msp.setSpan(new URLSpan("sms:4155551212"), 43, 45, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //短信 使用sms:或者smsto: msp.setSpan(new URLSpan("mms:4155551212"), 45, 47, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //彩信 使用mms:或者mmsto: msp.setSpan(new URLSpan("geo:38.899533,-77.036476"), 47, 49, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //地圖 //設置字體大小(相對值,單位:像素) 參數表示爲默認字體寬度的多少倍 msp.setSpan(new ScaleXSpan(2.0f), 49, 51, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //2.0f表示默認字體寬度的兩倍,即X軸方向放大爲默認字體的兩倍,而高度不變 //SpannableString對象設置給TextView myTextView.setText(msp); //設置TextView可點擊 myTextView.setMovementMethod(LinkMovementMethod.getInstance());
在使用SpannableString對象時要注意:web
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE等的做用:網絡
用來標識在 Span 範圍內的文本先後輸入新的字符時是否把它們也應用這個效果。分別有函數
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE(先後都不包括)、佈局
Spanned.SPAN_INCLUSIVE_EXCLUSIVE(前面包括,後面不包括)、測試
Spanned.SPAN_EXCLUSIVE_INCLUSIVE(前面不包括,後面包括)、字體
Spanned.SPAN_INCLUSIVE_INCLUSIVE(先後都包括)。網站
TextView添加以下屬性:
android:singleLine="true" android:focusable="true" android:ellipsize="marquee" android:marqueeRepeatLimit="-1" android:focusableInTouchMode="true"
Activity中設置TextView添加屬性:
textView.setSelected(true);
Android 代碼中設置控件背景顏色,以TextView爲例
如下是配置button中的文字效果:
drawable/button_font.xml
<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:state_selected="true" android:color="#FFF" /> <item android:state_focused="true" android:color="#FFF" /> <item android:state_pressed="true" android:color="#FFF" /> <item android:color="#000" /> </selector>
Button還能夠實現更復雜的效果,例如漸變
drawable/button_color.xml
<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:state_pressed="true">//定義當button 處於pressed 狀態時的形態。 <shape> <gradient android:startColor="#8600ff" /> <stroke android:width="2dp" android:color="#000000" /> <corners android:radius="5dp" /> <padding android:left="10dp" android:top="10dp" android:bottom="10dp" android:right="10dp"/> </shape> </item> <item android:state_focused="true">//定義當button得到 focus時的形態 <shape> <gradient android:startColor="#eac100"/> <stroke android:width="2dp" android:color="#333333" color="#ffffff"/> <corners android:radius="8dp" /> <padding android:left="10dp" android:top="10dp" android:bottom="10dp" android:right="10dp"/> </shape> </item> </selector>
最後,須要在包含 button的xml文件裏添加兩項。假如是 main.xml 文件,
咱們須要在<Button />里加兩項。
android:focusable="true" android:backgroud="@drawable/button_color"
這樣當你使用Button的時候就能夠甩掉系統自帶的那黃顏色的背景了,實現個性化的背景,配合應用的總體佈局很是之有用啊。
1.建立一個boolean值isCollect用來保存當前狀態,TextView.setSelected(isCollect);
2.設置Selector中Item state_selected="true"時的圖片:
<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android" > <item android:state_pressed="true" android:drawable="@drawable/icon_play_active"/> <item android:state_selected="true" android:drawable="@drawable/icon_play_active"/> <item android:state_enabled="true" android:drawable="@drawable/icon_play_inactive"/> </selector>
3.TextView設置背景爲Selector,就能夠實現了。
方法:
public void setCompoundDrawables (Drawable left, Drawable top, Drawable right, Drawable bottom);
至關於xml中設置:
android:drawableLeft="@drawable/icon"
Drawable drawable= getResources().getDrawable(R.drawable.drawable); /// 這一步必需要作,不然不會顯示. drawable.setBounds(0, 0, drawable.getMinimumWidth(), drawable.getMinimumHeight()); myTextview.setCompoundDrawables(drawable,null,null,null);
也或參考另外一個函數:
public void setCompoundDrawablesWithIntrinsicBounds (Drawable left, Drawable top, Drawable right, Drawable bottom)
設置drawablePadding:
textView.setCompoundDrawablePadding(int) ;