在開發中,遇到了這樣一個情況:顯示一段文字。理所當然地寫出了一個TextBlock,設定了高度自動,並熟練的進行了資料繫結…… 測試的時候發現,由於這段文字太大,TextBlock居然顯示不完整。百度了一下,發現有很多朋友也都遇到了相同的問題,估計微軟是在設計的時候考慮到效能因素,把這個控制項的顯示進行了限制。
這也就算了,更噁心的是,這個TextBlock的外層控制項的高度如果也設定成自動的話,它的高度會隨著文本的長度變化而變化,假設TextBlock外層是一個StackPanel,這個StackPanel中只有這個TextBlock且高度設為自動,TextBlock中的文本很長,文本高度假設是3000px,此時TextBlock只能顯示2000px,而StackPannel又顯示了1000Px的空白……
這個問題怎麼解決,我查到的和能想到大概有這麼幾種方法:
1、用程式把要顯示的文本分段,然後用ListBox顯示多個TextBlock把這些文本段顯示出來。問題是,由於字型大小不同,無法控制每“段”(非自然段)最後一行能否填滿。
2、101 Windows Phone 7 Apps, Volume I-Developing Apps 1-50 一書中第25章提到了PaginatedDocument自訂控制項。這個我還沒仔細看。
3、昨天我還想著用內嵌XNA把文字畫出來…… 後來發現太不實際了,由於要顯示中文,我記得在XNA3.0及之前,XNA是把所有的文字都緩衝成紋理進行顯示的,顯示中文,需要太多的空間。XNA 4.0,是否有新的變化,還沒抽出時間來研究過。
4、用WebBrowser控制項把那段文字以網頁形式顯示出來。
前三種“解決方案”,由於已知技術問題或者個人比較懶的問題,都放棄了……而且第四種解決方案,看起來可行,而且簡單。
(中間的嘗試就不詳細描述了,直接寫解決方案)。
在頁面上放一個WebBrowser控制項,設定名稱為textViewer,如果想在它上面顯示文字,只需要:
textViewer.NavigateToString("Hello world");
測試一下,沒有問題,“hello world”被顯示出來了。大功告成?換個中文試試“世界你好”,呃,你會看到的是亂碼。
查閱資料後發現,WebBrowser顯示的是Unicode,這樣寫能正確顯示中文:
text = "世界你好";
string text_Unicode;
var builder = new StringBuilder();
foreach (char c in text)
{
var b = (int)c;
builder.Append( "&#" + b + ";");
}
text_Unicode = builder.ToString();
textViewer.NavigateToString(text_Unicode);
這次就能正確的顯示中文了。
另外,微軟似乎不推薦在頁面中嵌入WebBrowser,這樣會造成不好的使用者體驗。我建議大家在需要顯示長文本的時候,先用TextBlock顯示摘要,當使用者Tap這段摘要的時候,出現一個全屏的WebBrowser來顯示長文本。
轉載請註明出處~ 錦燕雲
http://www.cnblogs.com/vistach/archive/2012/02/17/Windows_Phone_WP7_TextBlock_long_text_webBrowser_2000px.html