莆田做網站公司營銷推廣渠道有哪些
先上效果圖
分析問題
網上有很多關于這個的代碼,實現都過于復雜了,github上甚至還看到一篇文章600多行代碼,結果一跑起來全是bug。還是自己寫吧!!!
如果我們需要換行的"查看全文"、"收起全文"
效果那沒什么號說的,因為可以直接用兩個TextView然后通過判斷超過行數還是沒有超過行數來判斷顯示還是隱藏即可。這沒有什么難度,這里我們需要實現同一TextView實現。
要在 TextView 的部分文字上添加顏色和點擊事件,您可以使用 SpannableString
和 ClickableSpan
來實現。
為了避免重復代碼,那我們肯定是自定義View實現,新建一個ScalingTextView,繼承AppCompatTextView
class ScalingTextView(context: Context, attrs: AttributeSet?) :AppCompatTextView(context, attrs) {}
然后我們需要幾個參數
<!--一段測試文字-->
<string name="scaling_str">這是一段ScalingTextView的折疊測試文字,測試多行顯示的時候是否可以”查看全文“、”收起全文“這個功能是否正常呢,但是這個問題必須要超過兩行才行,因此我現在每打的一個字都是在湊字數,你懂了吧!!!</string>
SpannableString
和 ClickableSpan
對象
private var spannableString: SpannableString? = null// 創(chuàng)建 ClickableSpan 對象val clickableSpan = object : ClickableSpan() {override fun onClick(widget: View) {// 在這里處理點擊事件toggleText()}override fun updateDrawState(ds: TextPaint) {// 設置點擊文字的顏色ds.color = Color.BLUE// 如果不希望點擊文字有下劃線,可以注釋下面這行代碼ds.isUnderlineText = true}}
fun toggleText() {if (isCollapsed) {// 展開文本maxLines = Integer.MAX_VALUEisCollapsed = false} else {// 折疊文本maxLines = maxLinesCollapsedisCollapsed = true}}
當然還有些其他便于設置的參數,例如:
private var maxLinesCollapsed: Int = 2//默認折疊行數private var isCollapsed: Boolean = falseprivate var mOriginText: String //文本內容private @ColorInt var mOriginTextColor: Int//折疊文字顏色private val DEFAULT_OPEN_SUFFIX = "查看全文"private val DEFAULT_CLOSE_SUFFIX = "收起全文"private val ellipsis = "..."
當然這些參數我們需要通過xml里直接配置,不用每次都set一堆方法對吧,所以添加自定義屬性
<declare-styleable name="scaling_text_view"><attr name="content_text" format="string"></attr><attr name="content_text_color" format="color"></attr></declare-styleable>
然后獲取這幾個自定義參數,大家可以自行增加,這里只為演示內容
init {val typedValue = context.obtainStyledAttributes(attrs, R.styleable.scaling_text_view)mOriginText = typedValue.getString(R.styleable.scaling_text_view_content_text).toString()mOriginTextColor = typedValue.getColor(R.styleable.scaling_text_view_content_text_color,ContextCompat.getColor(context,R.color.themeColor)).toInt()}
最后我們如何實現功能呢?我們可以從幾個方向去分析:
- 在文字結尾追加上
“...”
省略號和"查看全文"
、"收起全文"
,這個不難 - 當超出最大限制行數的時候我們需要截取掉多余內容,并且為
“...”
省略號和"查看全文"
、"收起全文"
空出位置 - 為
"查看全文"
、"收起全文"
添加顏色 - 最后為
"查看全文"
、"收起全文"
添加點擊事件 - 最后的最后刷新文本內容
那么我們可以重寫onMeasure
這里我們用到一個方法getLineEnd
val lineEndIndex = layout.getLineEnd(maxLinesCollapsed - 1)val newText = text.subSequence(0, lineEndIndex - ellipsis.length + 1 - DEFAULT_OPEN_SUFFIX.length + 1).toString().trim { it <= ' ' } + ellipsis + DEFAULT_OPEN_SUFFIX
創(chuàng)建SpannableString對象
spannableString = SpannableString(newText);
//設置點擊事件spannableString?.setSpan(clickableSpan,newText.lastIndexOf(DEFAULT_OPEN_SUFFIX),newText.lastIndexOf(DEFAULT_OPEN_SUFFIX) + DEFAULT_OPEN_SUFFIX.length,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE)//設置文本顏色spannableString?.setSpan(ForegroundColorSpan(mOriginTextColor),newText.lastIndexOf(DEFAULT_OPEN_SUFFIX),newText.lastIndexOf(DEFAULT_OPEN_SUFFIX) + DEFAULT_OPEN_SUFFIX.length,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE)
最后設置刷新文本
text = spannableStringmovementMethod = LinkMovementMethod.getInstance()super.onMeasure(widthMeasureSpec, heightMeasureSpec)
好了,我們搞定了,完整代碼
class ScalingTextView(context: Context, attrs: AttributeSet?) :AppCompatTextView(context, attrs) {private var maxLinesCollapsed: Int = 2private var isCollapsed: Boolean = falseprivate val TAG: String = ScalingTextView::class.java.simpleNameprivate var mOriginText: Stringprivate @ColorInt var mOriginTextColor: Intprivate val DEFAULT_OPEN_SUFFIX = "查看全文"private val DEFAULT_CLOSE_SUFFIX = "收起全文"private val ellipsis = "..."private var spannableString: SpannableString? = nullinit {val typedValue = context.obtainStyledAttributes(attrs, R.styleable.scaling_text_view)mOriginText = typedValue.getString(R.styleable.scaling_text_view_content_text).toString()mOriginTextColor = typedValue.getColor(R.styleable.scaling_text_view_content_text_color,ContextCompat.getColor(context,R.color.themeColor)).toInt()text = mOriginText}// 創(chuàng)建 ClickableSpan 對象val clickableSpan = object : ClickableSpan() {override fun onClick(widget: View) {// 在這里處理點擊事件toggleText()}override fun updateDrawState(ds: TextPaint) {// 設置點擊文字的顏色ds.color = Color.BLUE// 如果不希望點擊文字有下劃線,可以注釋下面這行代碼ds.isUnderlineText = true}}fun toggleText() {if (isCollapsed) {// 展開文本maxLines = Integer.MAX_VALUEisCollapsed = false} else {// 折疊文本maxLines = maxLinesCollapsedisCollapsed = true}}override fun onMeasure(widthMeasureSpec: Int, heightMeasureSpec: Int) {super.onMeasure(widthMeasureSpec, heightMeasureSpec)if (layout.lineCount <= maxLinesCollapsed && spannableString == null) {//原文本等于或者小于默認折疊行數的時候不追加點擊事件等return}if (layout != null && layout.lineCount > maxLinesCollapsed && isCollapsed) {val lineEndIndex = layout.getLineEnd(maxLinesCollapsed - 1)val newText = text.subSequence(0, lineEndIndex - ellipsis.length + 1 - DEFAULT_OPEN_SUFFIX.length + 1).toString().trim { it <= ' ' } + ellipsis + DEFAULT_OPEN_SUFFIXspannableString = SpannableString(newText);//設置點擊事件spannableString?.setSpan(clickableSpan,newText.lastIndexOf(DEFAULT_OPEN_SUFFIX),newText.lastIndexOf(DEFAULT_OPEN_SUFFIX) + DEFAULT_OPEN_SUFFIX.length,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE)//設置文本顏色spannableString?.setSpan(ForegroundColorSpan(mOriginTextColor),newText.lastIndexOf(DEFAULT_OPEN_SUFFIX),newText.lastIndexOf(DEFAULT_OPEN_SUFFIX) + DEFAULT_OPEN_SUFFIX.length,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE)text = spannableStringmovementMethod = LinkMovementMethod.getInstance()super.onMeasure(widthMeasureSpec, heightMeasureSpec)}else if (layout != null && !isCollapsed) {val newText = mOriginText + DEFAULT_CLOSE_SUFFIXspannableString = SpannableString(newText);//設置點擊事件spannableString?.setSpan(clickableSpan,newText.lastIndexOf(DEFAULT_CLOSE_SUFFIX),newText.lastIndexOf(DEFAULT_CLOSE_SUFFIX) + DEFAULT_CLOSE_SUFFIX.length,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE)//設置文本顏色spannableString?.setSpan(ForegroundColorSpan(mOriginTextColor),newText.lastIndexOf(DEFAULT_CLOSE_SUFFIX),newText.lastIndexOf(DEFAULT_CLOSE_SUFFIX) + DEFAULT_CLOSE_SUFFIX.length,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE)text = spannableStringmovementMethod = LinkMovementMethod.getInstance()super.onMeasure(widthMeasureSpec, heightMeasureSpec)}}}
xml里使用,這里默認是展開的,你們默認隱藏的話自己實現
<com.github.demo.wight.ScalingTextViewandroid:id="@+id/scalingTextView"android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_marginTop="12dp"app:content_text="@string/scaling_str"app:content_text_color="@color/themeColor"" />