Android UI设计系列之HTML标签实现TextView设置中文字体加粗效果(6)

Android UI设计系列之HTML标签实现TextView设置中文字体加粗效果(6),第1张

概述搞软件开发的都知道项目中各种需求都有,而有时候各种奇葩的需求真是让人大跌眼镜,为了实现这些奇葩的需求我们往往苦逼的废寝忘食,我现在的项目中就有一个应该算得上奇葩的需求吧,需求是这样的:在一段文字中实现

搞软件开发的都知道项目中各种需求都有,而有时候各种奇葩的需求真是让人大跌眼镜,为了实现这些奇葩的需求我们往往苦逼的废寝忘食,我现在的项目中就有一个应该算得上奇葩的需求吧,需求是这样的:在一段文字中实现对部分文字加粗
这个看上去也不难并且有点小儿科,因为TextVIEw中有个属性是AndroID:textStyle,它其中一个值是bold,也就是说是对将要显示的文字进行加粗,于是我就在TextVIEw控件中添加了此属性,代码如下:

<TextVIEw  androID:layout_wIDth="fill_parent"  androID:layout_height="wrap_content"  androID:layout_margin="5dip"  androID:gravity="center"  androID:text="中文加粗了么?Chiness is bolded ?"  androID:textcolor="#000000"  androID:textStyle="bold"  androID:textSize="18sp" /> 

运行程序测试了一下效果,很遗憾的是对英文和数字是可以加粗的,但是对中文就没有效果了。然后又想到到使用AndroID中自带的HTML.fromHTML方法(我之前是搞J2EE开发的,对Web还是比较熟悉的,呵呵),因为在web开发中利用strong标签或者是b标签可以实现对文字的加粗效果,然后我就在TextVIEw的setText()方法中使用HTML.fromHTML方法,运行之后发现并没有出现加粗效果,又尝试了重新安装APK测试一下依然没有实现我想要的中文加粗效果,随后就上网询问百度,因为我比较喜欢询问度娘,呵呵
在网上查看了其他的对中文加粗的实现,除了使用androID:textStyle方法外就是通过TextVIEw的TextPaint对象,调用TextPaint对象的setFakeBoldText(true),可以实现对文字加粗的效果,我就尝试了一下,代码如下:

Title = (TextVIEw) findVIEwByID(R.ID.Title); Title.getPaint().setFakeBoldText(true); 

这样就可以实现对中文和英文的同时加粗,实现了需求上说的对文字加粗的效果,但是问题来了,我需要实现的对文字加粗是在一段话中对部分文字而不是全部文字都需要加粗,这样问题就来了,虽然可以通过上述方法实现中文的加粗但是把所有的文字都加粗了,为了实现部分文字加粗,我幸苦的把需要加粗的文字使用单独的TextVIEw实现,不需要加粗的就使用另外一个TextVIEw,这样基本上实现了需求所要的效果。
虽然实现了效果,可是这个问题还是在我心里留着,后来在无意中看一个控件源码时发现了它的注释里有个加粗的效果使用的是<tt>标签,我立马来了兴趣就在心里想可能这个标签可以实现对文字的部分加粗,于是就赶紧测试一下,代码如下:

Title = (TextVIEw) findVIEwByID(R.ID.Title); Title.setText(HTML.fromHTML("<b>China中国<tt>中国</tt></b>China真伟大!")); 

运行了一下程序,果然有效果,并且是实现的在一个TextVIEw中对部分文字实现了加粗,呵呵,心里高兴坏了,于是赶紧记录下来,给今后有需要的童鞋留个方便吧
总结一下加粗方式:

详细代码请见:https://www.oudahe.com/p/17338/

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。

总结

以上是内存溢出为你收集整理的Android UI设计系列之HTML标签实现TextView设置中文字体加粗效果(6)全部内容,希望文章能够帮你解决Android UI设计系列之HTML标签实现TextView设置中文字体加粗效果(6)所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1149187.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存