Android--LinearGradient线性渐变

[html]  
Paint paint = new Paint();  
        LinearGradient gradient = new LinearGradient(0, 0, 100, 100, Color.RED, Color.YELLOW, Shader.TileMode.MIRROR);  
        paint.setShader(gradient);  
        canvas.drawRect(0, 0, 100, 100, paint);  
        canvas.drawText("This is the shader", 100, 100, paint);  
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用 Spannable 实现 TextView 的线性颜色渐变效果,你可以使用 LinearGradient 来创建一个线性渐变的 Shader,并将其设置为 ForegroundColorSpan 的字体颜色。 以下是一个示例代码,演示如何使用 Spannable 实现线性颜色渐变效果: ```java TextView textView = findViewById(R.id.textView); String text = "Hello World!"; Spannable spannable = new SpannableString(text); // 定义渐变起始颜色和结束颜色 int startColor = Color.RED; int endColor = Color.BLUE; // 创建 LinearGradient 对象 LinearGradient gradient = new LinearGradient(0, 0, textView.getPaint().measureText(text), 0, startColor, endColor, Shader.TileMode.CLAMP); // 创建 ForegroundColorSpan,并设置渐变色的 Shader ForegroundColorSpan span = new ForegroundColorSpan(startColor); spannable.setSpan(span, 0, text.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); spannable.setSpan(new ShaderSpan(gradient), 0, text.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); // 将 spannable 设置给 TextView textView.setText(spannable); ``` 在这个示例中,我们首先创建了一个 SpannableString 对象,并将其初始化为需要处理的文本。然后,我们定义了渐变的起始颜色和结束颜色。接下来,我们创建了一个 LinearGradient 对象,指定了渐变的起始点和终止点,并设置了起始颜色和结束颜色。然后,我们创建了一个 ForegroundColorSpan 对象,并将起始颜色设置为它的字体颜色。同时,我们使用 ShaderSpan 来设置 Spannable 的 Shader,将渐变色应用到文本上。 这样,TextView 的文本就会呈现出线性颜色渐变的效果。你可以根据实际需求和喜好,调整起始颜色、结束颜色以及渐变的方向和模式来实现不同的线性颜色渐变效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值