android spannable 设置字体颜色,使用Android SpannableString设置TextView局部文字颜色

样式文件:

android:id="@+id/textView"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="欢迎来到枫林的小窝!"/>

代码文件:

private void initTextView() {

TextView textView = findViewById(R.id.textView);

SpannableString spannableString = new SpannableString(textView.getText());

setTextColor(spannableString, "枫林的小窝", Color.BLUE);

textView.setText(spannableString);

}

/**

* 设置SpannableString指定文字的颜色

*

* @param spannableString

* @param text

* @param color

*/

private void setTextColor(SpannableString spannableString, String text, int color) {

int start = spannableString.toString().indexOf(text);

int end = start + text.length();

spannableString.setSpan(new ForegroundColorSpan(color), start, end, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

}

参考链接:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值