安卓開(kāi)發(fā)小技巧--TextView 設(shè)置的文字過(guò)長(zhǎng),顯示三個(gè)點(diǎn)或者滾動(dòng)(文字跑馬燈)形式顯示

開(kāi)發(fā)經(jīng)常用textview,有時(shí)候文字過(guò)長(zhǎng)就跑到下一行或者寬度設(shè)為包裹內(nèi)容時(shí)會(huì)擠在一起,這樣看非常不美觀,iOS的文本控件會(huì)自適應(yīng)顯示不下時(shí)后面留三個(gè)點(diǎn),那安卓的可不可以,當(dāng)然可以,效果 如圖:

Screenshot_2017-06-19-15-40-47-625_com.hxzh.uniwi.png

TextView中有個(gè)ellipsize屬性,作用是當(dāng)文字過(guò)長(zhǎng)時(shí),該控件該如何顯示,解釋如下:
1.Android:ellipsize=”start”—–省略號(hào)顯示在開(kāi)頭
2.android:ellipsize=”end”——省略號(hào)顯示在結(jié)尾
3.Android:ellipsize=”middle”—-省略號(hào)顯示在中間
4.android:ellipsize=”marquee”–以跑馬燈的方式顯示(動(dòng)畫(huà)橫向移動(dòng)) 文字左右滾動(dòng)三個(gè)屬性:
android:singleLine=”true”
android:ellipsize=”marquee”
android:marqueeRepeatLimit=”marquee_forever”
Android中我們?yōu)榱藢?shí)現(xiàn)文本的滾動(dòng)可以在ScrollView中嵌入一個(gè)TextView,其實(shí)TextView自己也可以實(shí)現(xiàn)多行滾動(dòng)的,畢竟ScrollView必須只能有一個(gè)直接的子類布局。只要在layout中簡(jiǎn)單設(shè)置幾個(gè)屬性就可以輕松實(shí)現(xiàn)。

<TextView 
android:id="@+id/tvCWJ" 
android:layout_width="fill_parent" 
android:layout_height="wrap_content" 
android:scrollbars="vertical" <!--垂直滾動(dòng)條-->
android:singleLine="false" <!--實(shí)現(xiàn)多行-->
android:maxLines="15" <!--最多不超過(guò)15行-->
android:textColor="#FF0000"
/>
< TextView

android:id = "@+id/app_shortcontent"

android:layout_width = "wrap_content"

android:layout_height = "wrap_content"

android:singleLine = "true"

android:textColor = "#FFFFFFFF"

android:scrollHorizontally = "true"

android:focusable = "true"

android:ellipsize = "marquee"

android:marqueeRepeatLimit ="marquee_forever" />

當(dāng)然我們?yōu)榱俗孴extView動(dòng)起來(lái),還需要用到TextView的setMovementMethod方法設(shè)置一個(gè)滾動(dòng)實(shí)例,代碼如下
TextView tv =(TextView)findViewById(R.id.tvCWJ);
tv.setMovementMethod(ScrollingMovementMethod.getInstance()); //Android開(kāi)發(fā)網(wǎng)提示相關(guān)的可以查看SDK中android.text.method分支了解更多
附: 順便講下 TextView 自動(dòng)滾動(dòng)的實(shí)現(xiàn)方法,下面介紹兩種方法:

一、在代碼中實(shí)現(xiàn):

textView .setEllipsize(TextUtils.TruncateAt.MARQUEE); textView .setSingleLine(true); textView .setMarqueeRepeatLimit(6);

二、在XML中實(shí)現(xiàn):

<TextView 
android:id="@+id/TextView01"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:singleLine="true"
android:text="ddfgdfgdfsgagsgsadfbbbdbgnfgnsgndngdfgfgnffdnfgngfnf"
android:marqueeRepeatLimit="marquee_forever"
android:ellipsize="marquee"
android:scrollHorizontally="true"android:width="150dip">
</TextView>

一切OK,當(dāng) textView 獲取焦點(diǎn)后,就會(huì)自動(dòng)滾動(dòng)。
補(bǔ)充 ==============================
不管是手動(dòng)還是自動(dòng) 你要實(shí)現(xiàn)滾動(dòng)就得加scrollview
到時(shí)候可以通過(guò)handle來(lái)調(diào)用scrollview的scrollTo方法實(shí)現(xiàn)滾動(dòng)
Handler mHandler = new Handler();
private Runnable mScrollToBottom = new Runnable() { public void run() { mScrollView.scrollTo(0, offset); } };

onTouch里面

mHandler.post(mScrollToBottom);
補(bǔ)充 ==================== :
1,把 textview的 Ellipsize 設(shè)置成 marquee(上面有說(shuō))
2,把 Deprecated的 Single line 設(shè)置成 true
3,設(shè)置textview的Marquee repeat limit 屬性(滾動(dòng)回?cái)?shù),默認(rèn)是無(wú)數(shù)回)

附 TextView 屬性大全

android:ems 設(shè)置TextView的寬度為N個(gè)字符的寬度。
android:maxems 設(shè)置TextView的寬度為最長(zhǎng)為N個(gè)字符的寬度。與ems同時(shí)使用時(shí)覆蓋ems選項(xiàng)。
android:minems 設(shè)置TextView的寬度為最短為N個(gè)字符的寬度。與ems同時(shí)使用時(shí)覆蓋ems選項(xiàng)。
android:maxLength 限制輸入字符數(shù)。如設(shè)置為5,那么僅可以輸入5個(gè)漢字/數(shù)字/英文字母。
android:lines 設(shè)置文本的行數(shù),設(shè)置兩行就顯示兩行,即使第二行沒(méi)有數(shù)據(jù)。
android:maxLines 設(shè)置文本的最大顯示行數(shù),與width或者layout_width結(jié)合使用,超出部分自動(dòng)換行,超出行數(shù)將不顯示。
android:minLines 設(shè)置文本的最小行數(shù),與lines類似。
android:lineSpacingExtra 設(shè)置行間距。
android:lineSpacingMultiplier 設(shè)置行間距的倍數(shù)。如”1.2” android:numeric 如果被設(shè)置,該TextView有一個(gè)數(shù)字輸入法。有如下值設(shè)置:integer正整數(shù)、signed帶符號(hào)整數(shù)、decimal帶小數(shù)點(diǎn)浮點(diǎn)數(shù)。
android:password 以小點(diǎn)”.”顯示文本 android:phoneNumber 設(shè)置為電話號(hào)碼的輸入方式。
android:singleLine 設(shè)置單行顯示。如果和layout_width一起使用,當(dāng)文本不能全部顯示時(shí),后面用“…”來(lái)表示。如android:text=”test_ singleLine ” android:singleLine=”true” android:layout_width=”20dp”將只顯示“t…”。如果不設(shè)置singleLine或者設(shè)置為false,文本將自動(dòng)換行
android:textAppearance 設(shè)置文字外觀。如“?android:attr/textAppearanceLargeInverse”這里引用的是系統(tǒng)自帶的一個(gè)外觀,?表示系統(tǒng)是否有這種外觀,否則使用默認(rèn)的外觀??稍O(shè)置的值如下:textAppearanceButton/textAppearanceInverse/textAppearanceLarge/
textAppearanceLargeInverse/textAppearanceMedium/
textAppearanceMediumInverse/textAppearanceSmall/textAppearanceSmallInverse
android:textColor 設(shè)置文本顏色 android:textColorHighlight 被選中文字的底色,默認(rèn)為藍(lán)色
android:textColorHint 設(shè)置提示信息文字的顏色,默認(rèn)為灰色。與hint一起使用。
android:textColorLink 文字鏈接的顏色.
android:textScaleX 設(shè)置文字之間間隔,默認(rèn)為1.0f。參見(jiàn)TextView的截圖。
android:textSize 設(shè)置文字大小,推薦度量單位”sp”,如”15sp” android:textStyle 設(shè)置字形[bold(粗體) 0, italic(斜體) 1, bolditalic(又粗又斜) 2] 可以設(shè)置一個(gè)或多個(gè),用“|”隔開(kāi)
android:typeface 設(shè)置文本字體,必須是以下常量值之一:normal 0, sans 1, serif 2, monospace(等寬字體) 3]
android:height 設(shè)置文本區(qū)域的高度,支持度量單位:px(像素)/dp/sp/in/mm(毫米)
android:maxHeight 設(shè)置文本區(qū)域的最大高度
android:minHeight 設(shè)置文本區(qū)域的最小高度
android:width 設(shè)置文本區(qū)域的寬度,支持度量單位:px(像素)/dp/sp/in/mm(毫米),與layout_width的區(qū)別看這里。
android:maxWidth 設(shè)置文本區(qū)域的最大寬度 android:minWidth 設(shè)置文本區(qū)域的最小寬度

感謝閱讀

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • RelativeLayout 第一類:屬性值為true可false android:layout_centerHr...
    兀兀沙彌閱讀 3,132評(píng)論 0 15
  • 字符串資源里變量替換 Android開(kāi)發(fā)中是拒絕硬編碼的,我們可能會(huì)把一些字符串放在xml中當(dāng)作資源使用,假設(shè)有如...
    醉馬當(dāng)前闖閱讀 13,891評(píng)論 2 44
  • ¥開(kāi)啟¥ 【iAPP實(shí)現(xiàn)進(jìn)入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開(kāi)一個(gè)線程,因...
    小菜c閱讀 7,325評(píng)論 0 17
  • 字符串資源里變量替換 String text = "您已經(jīng)連續(xù)走了5963步";int start = text....
    MDZZ滅頂之災(zāi)12138閱讀 757評(píng)論 0 0
  • Android功能強(qiáng)大,界面華麗,但是眾多的布局屬性就害苦了開(kāi)發(fā)者,下面這篇文章結(jié)合了網(wǎng)上不少資料.第一類:屬性值...
    HangChen閱讀 5,186評(píng)論 0 24

友情鏈接更多精彩內(nèi)容