[WPF]用HtmlTextBlock實現消息對話框的內容高亮和跳轉

来源:https://www.cnblogs.com/czwy/p/18273976
-Advertisement-
Play Games

一:背景 1. 講故事 最近在分析dump時,發現有程式的卡死和WeakReference有關,在以前只知道怎麼用,但不清楚底層邏輯走向是什麼樣的,藉著這個dump的契機來簡單研究下。 二:弱引用的玩法 1. 一些基礎概念 用過WeakReference的朋友都知道這裡面又可以分為弱短和弱長兩個概念 ...


動手寫一個簡單的消息對話框一文介紹瞭如何實現滿足常見應用場景的消息對話框。但是內容區域的文字僅僅起到信息展示作用,對於需要部分關鍵字高亮,或者部分內容有交互性的場景(例如下圖提示信息中的“what's the risk?”需要跳轉)則無能為力了。本文將介紹如何在WPF中靈活的實現消息對話框中局部文字內容高亮或者支持跳轉。
image

HtmlTextBlock的使用

在WPF中,可以採用<Run>或者TextEffect實現文字中部分關鍵字高亮,但無法同時滿足部分內容支持鏈接跳轉功能 。如果能直接使用HTML,問題就迎刃而解了,但是在消息對話框的內容區域放一個webbrowser或cef瀏覽器有點太臃腫了。WPF HTML Supported TextBlock分享了一個支持有限HTML標簽的WPF控制項。該控制項可以支持<b>,<u>,<i>,<a>,<br>,<font>標簽,派生自TextBlock控制項,並新增了一個依賴屬性HtmlProperty接收需要展現的html內容,使用時需要把html內容字元串中的<>[]代替。

Content="[font color=red]紅色[/font]文字高亮";

<toolkit:HtmlTextBlock Margin="0,0,0,0" FontSize="18"
					   HorizontalAlignment="Center" VerticalAlignment="Center" 
					   Html="{Binding Content}" />

需要註意的是,用Html綁定的內容中如果包含成對的英文方括弧[]都會被當做標簽處理,無論是否是上述支持的六種標簽,都不會顯示出來。中文方括弧【】或者單個的英文方括弧則會作為內容直接顯示出來。如果用Text綁定內容則全部當成內容顯示出來。

修改消息對話框

動手寫一個簡單的消息對話框中內容區域是使用可選中文本的控制項SelectableTextBlock顯示內容,只需全部替換為HtmlTextBlock,並用依賴屬性HtmlProperty綁定內容即可。調用的時候只需把內容改為帶標簽的內容即可。例如:

 ShowAlertDialog(AlertDialogMode.Normal, AlertDialogType.Info, "打開[a href=https://www.chinadaily.com.cn/]中國日報[/a]網站", yesbuttonText: "確定", nobuttonText: "取消", parent: this);

但在使用<a>標簽實現鏈接跳轉時並沒有用瀏覽器打開指定頁面,調試過程中發現以下關鍵代碼,可以看到HtmlTextBlock是把<a>轉換為Hyperlink控制項,並把href中的url賦值給NavigateUri達到跳轉效果。

private Inline UpdateElement(HtmlTag aTag)
{
  Inline retVal = null;

  switch (aTag.Name)
  {
    case "text" :
      retVal = new Run(aTag["value"]);
      if (currentState.Bold) retVal = new Bold(retVal);
      if (currentState.Italic) retVal = new Italic(retVal);
      if (currentState.Underline) retVal = new Underline(retVal);
      break;
    case "br" :
      retVal = new LineBreak();
      break;
  }

  if (currentState.HyperLink != null && currentState.HyperLink != "")
  {
    Hyperlink link = new Hyperlink(retVal);
    link.NavigateUri = new Uri(currentState.HyperLink);
    retVal = link;
  }
   return retVal;
}

然而,只有 Hyperlink的直接或間接父級為導航宿主時,Hyperlink才能導航到NavigateUri屬性的值,導航宿主包括System.Windows.Navigation.NavigationWindowSystem.Windows.Controls.Frame或任何可承載 XBAP 的瀏覽器(包括 Internet Explorer 7、Microsoft Internet Explorer 6 和 Firefox2.0 以上版本)。因此,需要對這段代碼稍作修改。

if (currentState.HyperLink != null && currentState.HyperLink.Length > 0)
{
	Hyperlink link = new Hyperlink(retVal);
	try
	{
		link.Click += new RoutedEventHandler((s, e) =>
		{
			Process.Start(new ProcessStartInfo((s as Hyperlink).NavigateUri.AbsoluteUri));
			e.Handled = true;
		});
	}
	catch(Exception ex)
	{
		.....
	}
	retVal = link;
}

image


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 簡介: Redis是一款開源的使用ANSI C語言編寫、遵守BSD協議、支持網路、可基於記憶體也可持久化的日誌型、Key-Value高性能資料庫。Redis與其他Key-Value緩存產品相比有以下三個特點: 支持數據持久化,可以將記憶體中的數據保存在磁碟中,重啟可再次載入使用 支持簡單的Key-Val ...
  • 一:背景 1. 講故事 早就聽說過有什麼 網路邊緣計算,這次還真給遇到了,有點意思,問了下 chatgpt 這是幹嘛的 ? 網路邊緣計算是一種計算模型,它將計算能力和數據存儲位置從傳統的集中式數據中心向網路邊緣的用戶設備、感測器和其他物聯網設備移動。這種模型的目的是在接近數據生成源頭的地方提供更快速 ...
  • 之前分享中台 Admin.Core 的模塊代碼生成器,陸續也結合群友們的反饋,完善了一些功能和模板上的優化,而本篇將基於此代碼生成器生成一個通用代碼生成器模塊的基本代碼 後續再在此代碼的基礎上進行完善,製作一個通用的代碼生成器 ...
  • 接了一個小雜毛項目,大概情形是這樣的:ZWT先生開的店是賣拆片機的,Z先生不僅賣機器,還貼心地提供一項服務:可以根據顧客需要修改兩個電機的轉向和轉速(機器廠家有給SDK的,但Z自己不會寫程式)。廠家有配套一個調節器,調整參數時連接到拆片機的串口上,然後旋轉按鈕可以調速,撥碼開關可以設定電機正轉還是反 ...
  • 前言 周六在公司加班,幹完活後越顯無聊,想著下載RabbiitMQ做個小項目玩玩。然而這一下就下載了2個小時,真讓人頭痛。 簡單的講一下如何安裝吧,網上教程和踩坑文章還是很多的,我講我感覺有用的文章放在本文末尾。 安裝地址 erlang 下載 - Erlang/OTP https://www.erl ...
  • 在Windows 11下,使用WinUI2.6以上版本的ListView長這樣: 然而到了Win10上,儘管其他控制項的樣式沒有改變,但ListViewItem變成了預設樣式(初代Fluent) 最重大的問題是,Win10上的HorizontalAlignment未被設置成Stretch,可能造成嚴重 ...
  • 從C#3開始,拓展方法這一特性就得到了廣泛的應用。 此功能允許你能夠使用實例方法的語法調用某個靜態方法,以下是一個獲取/創建文件的靜態方法: public static async Task<StorageFile> GetOrCreateFileAsync(this StorageFolder f ...
  • 最近想把ET打表工具的報錯提示直接調用win系統彈窗,好讓策劃明顯的知道表格哪裡填錯數據,彈窗需要調用System.Windows.Forms庫。操作如下: 需要在 .csproj 文件中添加: <UseWindowsForms>true</UseWindowsForms> 須將目標平臺設置為 Wi ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...