前言
关于TextView
这个控件,大家应该是非常熟悉了,我们平时都会对它的大小,颜色等属性做设置,也只要在布局的xml
里面设置一下size
,color
就好了,但是我相信大家都有第一次遇到被要求单独修改一个TextView
里面的文本的颜色,大小的要求,第一反应是what?how can?。因为TextView
里面的内容在印象之中都是所有内容一起变大变小,变颜色的,那么今天我就介绍两种方案去解决这个问题。
正文
方案一
//两次加大字体,设置字体为红色(big会加大字号,font可以定义颜色)
textView.setText(Html.fromHtml("我后面的字会变化,<font color='#ff0000'><big><big>我会变大而且变红</big></big></font>口罩"));
就像上面的代码的方式,大家可以看到我们采用的是html
的内容方式填入textView
,当然这里的标签还可以使用h1~h6
,html
里面的标题的标签,不过请留意,这标题的标签不止会改变大小,还会换行,详情请了解html
中啥叫块状元素,这里不展开。
方案二
//设置字体大小为58(单位为物理像素),设置字体为红色,字体背景为黄色
textView3.setText("我们期望改变后面内容,改变的内容");
Spannable span = new SpannableString(textView3.getText());
span.setSpan(new AbsoluteSizeSpan(58), 11, 16, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
span.setSpan(new ForegroundColorSpan(Color.RED), 11, 16, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
span.setSpan(new BackgroundColorSpan(Color.YELLOW), 11, 16, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
textView3.setText(span);
这次我们通过Spannable
来实现,可以把“改变的内容”这5个字的大小改为58
,颜色变红,背景变黄。关于Spannable
大家可以去百度有多少种类型,我只演示了三种,还有一个细节,这里范围是左开右闭(就是11,16
)实际改变的内容位置就是12,13,14,15,16不包括11
,这里请大家留意一下。
总结
至此我们可以对TextView
的部分内容的需求玩的很6
了,至于两个方案,个人觉得Spannable
会更灵活一些,哈哈,今天你吃成长快乐了吗??,bye。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。