OxyPlot.SkiaSharp中文顯示亂碼的問題

oxyplot 圖表控制項功能強大,使用很廣泛。最近考慮到性能使用OxyPlot.SkiaSharp替代OxyPlot.WPF,曲線圖表初步測試,性能提升近10倍左右。基於SkiaSharp圖形引擎的一些控制項常遇見中文亂碼的問題,所以改用OxyPlot.SkiaSharp時也有心裡準備。默認情況下中文顯示真成了亂碼。如下圖所示。

顯示亂碼

於是翻了遍OxyPlot.SkiaSharp源碼,看到PlotModel中的DefaultFont屬性默認值是「Segoe UI」,西文無襯線體。試著改為「微軟雅黑」,中文顯示正常了。如下圖所示。

顯示正常

OxyPlot.WPF中為什麼顯示沒問題,將WPF中TextBlock字體改為ALGERIAN後,只有英文應用了該字體,而中文則是以另外一種字體顯示的。如下圖所示。

中英文分別映射

我們知道WPF的默認字體也是「Segoe UI」,為什麼顯示不會有問題呢,這就要提到WPF應用字體的機制了。

WPF應用程式使用屬性FontFamily、FontStyle、FontWeight、FontStretch和FontSize來指定它想要的字體。 在運行時,WPF會決定在應用程式運行的目標系統上使用準確的字體。這個決定是基於將前四個屬性(暫時忽略FontSize)與該系統上安裝的物理字體文件進行匹配。

WPF首先將提供的FontFamily與系統中找到的字體名稱進行匹配。 然後,它試圖找到一個與所請求的FontStretch、FontStyle和FontWeight屬性值最接近的字體。 匹配FontStretch是最高優先順序,其次是FontStyle,然後是FontWeight。

如果WPF找不到匹配的字體,它就會「退回」到與WPF一起安裝的默認字體,即

C:\Windows\Fonts\GlobalUserInterface.CompositeFont

這是一種複合字體,它試圖將單個字元映射到系統上可能存在的字體。也就是說中文和英文是分開映射到不同的字體上。

Tags: