使用Kotlin實現文字漸變TextView的代碼
更新時間:2020年04月28日 09:41:08 作者:zhangmeiwen95
這篇文章主要介紹了使用Kotlin實現文字漸變TextView的代碼,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
實現效果:
實現代碼:
import android.content.Context import android.graphics.* import android.support.annotation.ColorInt import android.support.annotation.ColorRes import android.text.TextPaint import android.util.AttributeSet import android.widget.TextView import com.ans.utilactivity.R class GradientTextView @JvmOverloads constructor( context: Context?, attrs: AttributeSet? = null ) : TextView(context, attrs) { private var mPaint: TextPaint? = null private var mLinearGradient: LinearGradient? = null private var mMeasureWidth = 0 private var mTextMatrix: Matrix? = null @ColorInt private var mStartColor: Int = 0xFF333333.toInt() @ColorInt private var mEndColor: Int = 0xFF333333.toInt() init { if (attrs != null) { val attrArray = getContext().obtainStyledAttributes(attrs, R.styleable.GradientTextView) mStartColor = attrArray.getColor(R.styleable.GradientTextView_startColor, mStartColor) mEndColor = attrArray.getColor(R.styleable.GradientTextView_endColor, mEndColor) } } /** * 復寫onSizeChanged方法 * */ override fun onSizeChanged(w: Int, h: Int, oldw: Int, oldh: Int) { super.onSizeChanged(w, h, oldw, oldh) mMeasureWidth = measuredWidth if (mMeasureWidth > 0) { mPaint = paint //(x0,y0):漸變起始點坐標 //(x1,y1):漸變結束點坐標 //color0:漸變開始點顏色,16進制的顏色表示,必須要帶有透明度 //color1:漸變結束顏色 //colors:漸變數組 //positions:位置數組,position的取值范圍[0,1],作用是指定某個位置的顏色值,如果傳null,漸變就線性變化。 //tile:用于指定控件區(qū)域大于指定的漸變區(qū)域時,空白區(qū)域的顏色填充方法。 mLinearGradient = LinearGradient( 0f , 0f , mMeasureWidth.toFloat() , 0f , intArrayOf(mStartColor, mEndColor) , null , Shader.TileMode.CLAMP ) mPaint?.shader = mLinearGradient mTextMatrix = Matrix() } } }
attr.xml 引用
<declare-styleable name="GradientTextView"> <attr name="startColor" format="color"/> <attr name="endColor" format="color"/> </declare-styleable>
引用:
<前綴.GradientTextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Hello World!" app:startColor="@color/colorPrimary" app:endColor="@color/colorAccent" />
到此這篇關于使用Kotlin實現文字漸變TextView的文章就介紹到這了,更多相關Kotlin文字漸變TextView內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Android實現過渡動畫、引導頁 Android判斷是否第一次啟動App
這篇文章主要為大家詳細介紹了Android實現過渡動畫、引導頁,以及Android判斷是否第一次啟動App,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12Android控件系列之Button以及Android監(jiān)聽器使用介紹
Button是各種UI中最常用的控件之一,它同樣也是Android開發(fā)中最受歡迎的控件之一,用戶可以通過觸摸它來觸發(fā)一系列事件,要知道一個沒有點擊事件的Button是沒有任何意義的,因為使用者的固定思維是見到它就想去點2012-11-11