你的分享就是我们的动力 ---﹥

Silverlight中使用点阵字体(如宋体)的技巧

时间:2012-07-13 12:46来源:www.chengxuyuans.com 点击:

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

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

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

效果如下图:

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

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

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

我们设置一下XAML的FontFamily属性

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

看效果

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

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

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

看效果

 

恩,很完美了哦。

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

OK,希望对大家有用。

出处:http://024hi.cnblogs.com/

转载注明地址:http://www.chengxuyuans.com/slverlight/41918.html