android文字流光效果

            <TextView
                android:id="@+id/shimmerTextView"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="流光效果"
                android:textColor="#FFFFFF"
                android:textSize="24sp"
                android:gravity="center"/>

 

    private fun setAnim() {
        val shimmerTextView = binding.shimmerTextView

        // 创建 LinearGradient
        val width = shimmerTextView.paint.measureText(shimmerTextView.text.toString())
        val gradient = LinearGradient(
            0f, 0f, width, 0f,
            intArrayOf(0x22ffffff, 0xffffffff.toInt(), 0x22ffffff),
            floatArrayOf(0f, 0.5f, 1f),
            Shader.TileMode.CLAMP
        )
        shimmerTextView.paint.shader = gradient

        // 创建动画来平移渐变效果
        val animator = ValueAnimator.ofFloat(0f, width)
        animator.addUpdateListener { animation ->
            val value = animation.animatedValue as Float
            val matrix = Matrix()
            matrix.setTranslate(value, 0f)
            gradient.setLocalMatrix(matrix)
            shimmerTextView.invalidate()
        }
        animator.duration = 1500L
        animator.repeatCount = ValueAnimator.INFINITE
        animator.start()
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值