[Silverlight]使用点阵字体(如宋体)及相关方面的技巧- 紫色永恒- 博客园

我们知道,Silverlight的默认中文字体是【雅黑】,它是一种矢量字体,有点是可以保证在文字大小变化时也不失真。但是它的效果真的如我们想想中那么好吗?

我们做一个实验,一段简单的XAML

<TextBlock FontSize="14" Text="我是宋体吗ABC?" Margin="30"/>

效果如下图:

看起来还可以,但是做过实际项目开发的各位都清楚,sl中雅黑下的某些字比如:“增”字一类的字变形的比较厉害(虽然sl3有了明显的改善),这很难让我们这些经常和宋体等标准中文字体打交道的人接受。

群里经常有人问:“为啥sl的字体那么模糊啊。sl不能用宋体,真烂!”等等。

其实sl中是{jd1}可以使用点阵字体的,只不过这个技巧大部分人不太清楚而已。

我们设置一下XAML的FontFamily属性

 <TextBlock FontSize="14" FontFamily="SimSun" Text="我是宋体吗ABC?" Margin="30"/>

看效果

怎么样?标准的宋体吧!关键就在于FontFamily的值应该是“SimSun”而不是“宋体”。

不过到了这里,这个解决方案还不是很xx。我们仔细看“ABC”这三个英文,还不如默认的好看呢。这个具体我也不大清楚,不过要解决这个问题我们只需显式的设置英文(比如Arial)字体就可以了。具体设置方法看XAML

<TextBlock FontSize="14" FontFamily="Arial,SimSun" Text="我是宋体吗ABC?" Margin="30"/>

看效果

 

恩,很xx了哦。

注意FontFamily的顺序和设置方法:两种字体见要以半角逗号(,)分割,而且英文字体必须写在中文字体之前。

OK,希望对大家有用。

提前祝大家元旦快乐!


郑重声明:资讯 【[Silverlight]使用点阵字体(如宋体)及相关方面的技巧- 紫色永恒- 博客园】由 发布,版权归原作者及其所在单位,其原创性以及文中陈述文字和内容未经(企业库qiyeku.com)证实,请读者仅作参考,并请自行核实相关内容。若本文有侵犯到您的版权, 请你提供相关证明及申请并与我们联系(qiyeku # qq.com)或【在线投诉】,我们审核后将会尽快处理。
—— 相关资讯 ——