LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

【C#】WinForm到WPF轉型:TextBlock的應用

admin
2025年5月16日 9:0 本文熱度 60

在Windows Forms(WinForm)開發中,常用Label控件來顯示只讀文本;當我們轉向WPF進行開發時,用于顯示文本的常用控件則是TextBlock。TextBlock是WPF中非常輕量且靈活的文本呈現控件,相比Label而言,TextBlock有更豐富的格式化功能和更好的性能表現。本文將從WinForm到WPF的轉型角度,為您介紹TextBlock在WPF中的應用場景和典型用法。


WinForm與WPF之比較

WinForm中的文本顯示控件

在WinForm中,如果要在界面上展示文本內容,通常使用以下控件:

  1. Label
    :用于顯示只讀文本,幾乎無格式化選項,可更改字體、顏色等基本屬性
  2. TextBox
    :可編輯的文本控件,允許用戶輸入

WPF中的文本顯示控件

WPF中可以使用以下控件來顯示文本:

  1. TextBlock
    :輕量級文本顯示控件,支持豐富的文本格式化(如RunSpan等)
  2. Label
    :WPF中也提供了Label控件,但更多是兼容WinForm的用法;Label通常會包含一個ContentPresenter來顯示內容

在實際WPF開發中,推薦使用TextBlock實現只讀文本的顯示,因為它具有更好的可擴展性和渲染性能。


TextBlock的基礎應用

在WPF中,使用TextBlock最簡單的方式就是直接將要顯示的文本通過Text屬性綁定到控件上。下面是一個演示示例,包括在XAML中的用法和后端C#代碼。

基本示例

<Window x:Class="AppTextBlock.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:AppTextBlock"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <StackPanel Margin="20">
        <!-- 使用TextBlock顯示靜態文本 -->
        <TextBlock Text="這是一個簡單的TextBlock,用于顯示文本,類似于WinForm的Label"
                   FontSize="16"
                   FontWeight="Bold"
                   Foreground="Blue"/>

        <!-- 多行文本示例 -->
        <TextBlock TextWrapping="Wrap"
                   Margin="0,10,0,0">
            這是一段較長的文本,開啟TextWrapping后,TextBlock會根據控件或者其容器的寬度自動換行,非常方便。與WinForm中的Label相比較,WPF中的TextBlock可以更靈活地進行文本渲染。
        </TextBlock>
    </StackPanel>
</Window>

核心要點

  • TextBlock
    是一個輕量級控件,渲染性能好
  • TextWrapping="Wrap"
    可以讓文本根據控件寬度自動換行

TextBlock的高級用法

混合使用Run標簽

和WinForm中的Label只能在一個文本元素中展示單一格式不同,WPF中TextBlock可以結合Run標簽來實現多段文字的不同格式。

<Window x:Class="AppTextBlock.Window1"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:AppTextBlock"
        mc:Ignorable="d"
        Title="Window1" Height="450" Width="800">

    <StackPanel>
        <TextBlock>
            <!-- 普通文本 -->
            <Run Text="這是一段普通文本。" />

            <!-- 加粗文本 -->
            <Run Text="這段文字加粗顯示。" FontWeight="Bold" />

            <!-- 彩色文本 -->
            <Run Text="這段文字為紅色。" Foreground="Red" />
        </TextBlock>
    </StackPanel>
</Window>

文本換行與行高

<Window x:Class="AppTextBlock.Window2"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:AppTextBlock"
        mc:Ignorable="d"
        Title="Window2" Height="450" Width="800">

    <Grid>
        <TextBlock TextWrapping="Wrap"
           LineHeight="30"
           LineStackingStrategy="BlockLineHeight">

            <!-- 使用LineBreak手動換行 -->
            第一行內容<LineBreak/>
            第二行內容<LineBreak/>
            第三行內容
        </TextBlock>
    </Grid>
</Window>

  • TextWrapping="Wrap"
    :自動換行
  • LineHeight="30"
    :行高設置為30
  • LineStackingStrategy="BlockLineHeight"
    :以行高為基準進行堆疊

數據綁定示例

在WPF的MVVM模式下,TextBlock可以通過Binding來與ViewModel中的屬性關聯,從而實現數據驅動的視圖更新。下面是一個簡單的示例。

ViewModel代碼

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace AppTextBlock
{
    publicclass MainViewModel : INotifyPropertyChanged
    {
        privatestring _displayText;
        publicstring DisplayText
        {
            get => _displayText;
            set
            {
                _displayText = value;
                OnPropertyChanged(nameof(DisplayText));
            }
        }

        public MainViewModel()
        
{
            // 構造函數中初始化數據
            DisplayText = "Hello,WPF的TextBlock!";
        }

        public event PropertyChangedEventHandler PropertyChanged;
        protected virtual void OnPropertyChanged(string propertyName)
        
{
            PropertyChanged?.Invoke(thisnew PropertyChangedEventArgs(propertyName));
        }
    }
}

綁定到TextBlock

<Window x:Class="AppTextBlock.Window3"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:AppTextBlock"
        mc:Ignorable="d"
        Title="Window3" Height="450" Width="800">

    <Window.DataContext>
         <local:MainViewModel/>
    </Window.DataContext>
    <Grid>

        <StackPanel VerticalAlignment="Center" HorizontalAlignment="Center">
            <TextBlock Text="{Binding DisplayText}" 
                   FontSize="18"
                   FontWeight="Bold"
                   Foreground="Purple"/>

        </StackPanel>
    </Grid>
</Window>

這樣在程序運行時,如果MainViewModelDisplayText屬性更新,UI上TextBlock顯示的文本將會自動刷新。


TextBlock vs. WinForm的Label

特性/屬性
WinForm中的Label
WPF中的TextBlock
只讀文本顯示
文本格式化
基本字體設置
靈活支持Run等標簽
支持數據綁定
需手動處理(或使用第三方框架)
原生支持數據綁定
自動換行
使用AutoSize或設置大小
TextWrapping
更靈活
性能及渲染
一般,GDI+渲染
優秀,使用DirectX渲染
設計器支持
WinForm拖拽設計器
Visual Studio / Blend 設計器



結束語

從WinForm轉型到WPF中,TextBlock是顯示只讀文本的理想選擇。與WinForm中常用的Label控件相比,TextBlock不僅性能更好,而且支持更豐富的格式化選擇。同時WPF本身的MVVM數據綁定模式也讓界面邏輯與數據邏輯更好地分離,實現真正的組件化與模塊化開發。

在實際項目中,如果需要顯示的文本內容很復雜,或者需要結合Run、Span等子元素實現多樣式展示,TextBlock都是很好的選擇。希望本文能幫助您快速上手WPF的TextBlock控件!

閱讀原文:https://mp.weixin.qq.com/s/2gTGSp_9rONfoubaB5klpQ


該文章在 2025/5/16 9:04:59 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

黄频国产免费高清视频,久久不卡精品中文字幕一区,激情五月天AV电影在线观看,欧美国产韩国日本一区二区
五月天综合网在线欧美 | 亚洲特级视频在线观看 | 最新久久偷拍视频 | 中文美女乱婬试看视频 | 一级夜理论片久久 | 亚洲一区二区三区精品视频 |