日韩欧美人妻无码精品白浆,www.大香蕉久久网,狠狠的日狠狠的操,日本好好热在线观看

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

【C#】WinForm到WPF轉(zhuǎn)型:TextBlock的應(yīng)用

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

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


WinForm與WPF之比較

WinForm中的文本顯示控件

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

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

WPF中的文本顯示控件

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

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

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


TextBlock的基礎(chǔ)應(yīng)用

在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顯示靜態(tài)文本 -->
        <TextBlock Text="這是一個簡單的TextBlock,用于顯示文本,類似于WinForm的Label"
                   FontSize="16"
                   FontWeight="Bold"
                   Foreground="Blue"/>

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

核心要點

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

TextBlock的高級用法

混合使用Run標簽

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

<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手動換行 -->
            第一行內(nèi)容<LineBreak/>
            第二行內(nèi)容<LineBreak/>
            第三行內(nèi)容
        </TextBlock>
    </Grid>
</Window>

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

數(shù)據(jù)綁定示例

在WPF的MVVM模式下,TextBlock可以通過Binding來與ViewModel中的屬性關(guān)聯(lián),從而實現(xiàn)數(shù)據(jù)驅(qū)動的視圖更新。下面是一個簡單的示例。

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()
        
{
            // 構(gòu)造函數(shù)中初始化數(shù)據(jù)
            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
只讀文本顯示
文本格式化
基本字體設(shè)置
靈活支持Run等標簽
支持數(shù)據(jù)綁定
需手動處理(或使用第三方框架)
原生支持數(shù)據(jù)綁定
自動換行
使用AutoSize或設(shè)置大小
TextWrapping
更靈活
性能及渲染
一般,GDI+渲染
優(yōu)秀,使用DirectX渲染
設(shè)計器支持
WinForm拖拽設(shè)計器
Visual Studio / Blend 設(shè)計器



結(jié)束語

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

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

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


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

caoporn进入亚洲| 91精品久久久久无码人妻| 抽插无码区| 日韩偶美成人网址| 久久无码精品久久无码免费| 女生又紧又黄又黄视频网站| aV影院在线小说| 久久精品欧美日本| 免费草b视频在线| 少妇高潮28p| 国自产偷拍精品| 免费黄色av网站大全| 欧亚洲无码在线观看| 婷婷手机在线视频| caoporn超碰97免费| 亚洲无码欧美国产日韩| 一区二区五码免费| 亚洲不卡中文字幕高清在线| 在线免费伦理日韩AV| 中日韩欧美一级黄色网络| 天天干夜夜一区| 日本老熟妇aⅤ视频| 午夜一区不卡视频| 好吊扭视频这里都是精品| 骚少妇| 999久久久毛片网| 欧美人妻第一区第五页| www.av男人天堂.con| 日韩夫妻Av大片| 天堂资源一区二区| 国产一区无码国语| 天天曰天天干天天操| 强伦女教师一区二区三区免费观看 | 亚洲www一区2区| A∨在线一区| 欧美xxxAV一区| 蜜臀AVwww| 精品秘 无码一区二区三区| 五房播播激情网站| 亚洲视频一区二区三区香蕉| 日本一级大片一区二区|