wpf DataTemplate 和 ControlTemplate 区别,应用举例

在WPF中,模版(ControlTemplate ) ControlTemplate用于定义控件的内部结构和外观,它决定了控件的"长成什么样子",并允许开发者在控件原有的内部逻辑基础上扩展自己的逻辑。DataTemplate则专注于数据内容的展示方式,即数据如何被可视化呈现。

cs 复制代码
示例实现
1. 定义歌曲类
首先,我们定义一个Song类,用于表示歌曲数据。

public class Song  
{  
    public string Title { get; set; }  
    public string Artist { get; set; }  
    // 可以添加更多属性,如专辑、时长等  
}
2. 创建DataTemplate
在XAML中,我们为Song类创建一个DataTemplate,用于定义每首歌曲在播放列表中的显示方式。

<Window.Resources>  
    <DataTemplate x:Key="SongDataTemplate">  
        <StackPanel Orientation="Horizontal" Margin="5">  
            <TextBlock Text="{Binding Title}" FontSize="16" FontWeight="Bold"/>  
            <TextBlock Text=" - " Margin="2,0,0,0"/>  
            <TextBlock Text="{Binding Artist}" FontSize="14"/>  
        </StackPanel>  
    </DataTemplate>  
</Window.Resources>


3. 创建ControlTemplate
接下来,我们为播放列表控件(例如ListBox)创建一个ControlTemplate,以改变其整体外观。这里为了简化,我们只改变背景色和滚动条样式,但你可以根据需要添加更多自定义内容
<Window.Resources>  
    <!-- 之前的DataTemplate定义 -->  
  
    <ControlTemplate x:Key="PlaylistControlTemplate" TargetType="ListBox">  
        <Border Background="LightGray" Padding="10">  
            <ScrollViewer HorizontalScrollBarVisibility="Auto" VerticalScrollBarVisibility="Auto">  
                <ItemsPresenter/>  
            </ScrollViewer>  
        </Border>  
    </ControlTemplate>  
</Window.Resources>

4. 应用Template
现在,我们在XAML布局中应用这两个模版。首先,为ListBox设置ControlTemplate,然后为其ItemTemplate设置之前定义的DataTemplate。
<Grid>  
    <ListBox x:Name="PlaylistListBox"  
             Template="{StaticResource PlaylistControlTemplate}"  
             ItemTemplate="{StaticResource SongDataTemplate}">  
        <!-- 这里通过数据绑定填充歌曲列表 -->  
    </ListBox>  
</Grid>
相关推荐
沉到海底去吧Go5 小时前
【图片识别改名】如何批量将图片按图片上文字重命名?自动批量识别图片文字并命名,基于图片文字内容改名,WPF和京东ocr识别的解决方案
ocr·wpf·图片识别改名·图片识别重命名·图片内容改名
lph19725 小时前
自定义事件wpf
wpf
code bean9 小时前
【WPF】从普通 ItemsControl 到支持筛选的 ItemsControl:深入掌握 CollectionViewSource 用法
wpf
碎碎念的安静20 小时前
WPF可拖拽ListView
c#·wpf
界面开发小八哥1 天前
界面组件DevExpress WPF中文教程:Grid - 如何识别行和卡片?
.net·wpf·界面控件·devexpress·ui开发
TwilightLemon3 天前
WPF 使用CompositionTarget.Rendering实现平滑流畅滚动的ScrollViewer,支持滚轮、触控板、触摸屏和笔
wpf
Vae_Mars4 天前
WPF中自定义消息弹窗
wpf
Magnum Lehar4 天前
GameEngine游戏引擎前端界面wpf页面实现
前端·游戏引擎·wpf
TA远方5 天前
【C#】一个简单的http服务器项目开发过程详解
服务器·http·c#·wpf·web·winform·console
陈奕昆5 天前
2.1HarmonyOS NEXT开发工具链进阶:DevEco Studio深度实践
华为·wpf·harmonyos