[WPF]使用C#代码实现DataTemplate

不得不说DataTemplate是WPF中的一项重要技术组成,可以方便让我们实现各种各样的UI样式,大大丰富了应用程序的界面设计。

通常我们都会在XAML文件中定义出具体的DataTemplate, 我举一个ListView的例子:

ContractedBlock.gif ExpandedBlockStart.gif Code
<ListView IsSynchronizedWithCurrentItem="True" Background="#FFFFFFFF" Foreground="White" ItemsSource="{Binding}" Style="{DynamicResource SuperListViewStyle}" ItemContainerStyleSelector="{StaticResource listViewItemStyleSelector}" x:Name="lvExecutionTable" >
                        
<ListView.View>
                            
<GridView>
                                
<GridViewColumn>
                                    
<GridViewColumn.CellTemplate>
                                        
<DataTemplate>
                                            
<CheckBox HorizontalAlignment="Center" IsChecked="{Binding Path=IsSelected}"/>
                                        
</DataTemplate>
                                    
</GridViewColumn.CellTemplate>
                                    
<GridViewColumnHeader Content="选择" Tag="IsSelected"/>
                                
</GridViewColumn>
                                
<GridViewColumn>
                                    
<GridViewColumn.CellTemplate>
                                        
<DataTemplate>
                                            
<TextBlock Text="{Binding Path=IsComfirmed, Converter={StaticResource IsComfirmedConverter}}" Foreground="{Binding Path=IsComfirmed, Converter={StaticResource IsComfirmedToColorConverter}}"/>
                                        
</DataTemplate>
                                    
</GridViewColumn.CellTemplate>
                                    
<GridViewColumnHeader Content="确认状态" Tag="IsComfirmed"/>
                                
</GridViewColumn>
                                
<GridViewColumn DisplayMemberBinding="{Binding Path=MarketIndicator}">
                                    
<GridViewColumnHeader Content="市场类型" Tag="MarketIndicator"/>
                                
</GridViewColumn>
                                
<GridViewColumn>
                                    
<GridViewColumn.CellTemplate>
                                        
<DataTemplate>
                                            
<TextBlock Text="{Binding Path=TradeType}"/>
                                        
</DataTemplate>
                                    
</GridViewColumn.CellTemplate>
                                    
<GridViewColumnHeader Content="成交方式" Tag="TradeType"/>
                                
</GridViewColumn>
                            
</GridView>
                        
</ListView.View>
                    
</ListView

ContractedBlock.gifCode

例子中对每个Column定义了简单的DataTemplate。

我遇到的问题是如果这个List View需要动态编辑列,或者新加入一些列,就是如何用代码来实现对控件的DataTemplate的操作。

经过查阅MSDN的相关文档,最好找到了解决的办法,如下:

ContractedBlock.gif ExpandedBlockStart.gif Code
            GridViewColumn column = new GridViewColumn();
            GridViewColumnHeader h 
= new GridViewColumnHeader();
            h.Content 
= "??????";
            h.Tag 
= "*******";
            column.Header 
= h;
            DataTemplate dt 
= new DataTemplate();
            FrameworkElementFactory fef 
= new FrameworkElementFactory(typeof(CheckBox));
            Binding binding 
= new Binding();
            binding.Path 
= new PropertyPath("MarketIndicator");
            fef.SetBinding(CheckBox.ContentProperty, binding);
            fef.SetValue(CheckBox.ForegroundProperty, Brushes.White);
            dt.VisualTree 
= fef;
            column.CellTemplate 
= dt;

            (
this.lvExecutionTable.View as GridView).Columns.Add(column);

DataTemplate对象的VisualTree属性的类型是FrameworkElementFactory,用来存放具体的Control。FrameworkElementFactory fef = new FrameworkElementFactory(typeof(CheckBox))语句定义了DataTemplate的顶层元素是一个CheckBox控件,使用fef.SetValue方法可以设置顶层元素的属性,如绑定等等。如果你需要定义的DataTemplate不止一个层次,那么你就要花点时间去设置顶层元素的Content属性。

问题解决,如果大家有更好的办法或者建议请联系我,谢谢!

转载于:https://www.cnblogs.com/chenlhuaf/archive/2009/02/11/1388426.html

C# WPF (Windows Presentation Foundation) 中实现滚动字幕动画,通常会利用`ItemsControl`、`TextBlock`和动画效果来完成。以下是一个简单的步骤概述: 1. 创建`ItemsControl`:设置其`ItemsSource`为包含字幕文本的列表,例如 `ObservableCollection<string>`. ```csharp <ListBox x:Name="ScrollingTextBox" ItemsSource="{Binding MyTextStrings}" /> ``` 2. 数据绑定:将滚动字幕的数据源与视图模型(ViewModel)关联起来。 3. 文本块模板:为`ItemsControl`创建一个数据模板,每个`TextBlock`代表一行滚动的文字。 ```xml <ListBox.ItemTemplate> <DataTemplate> <TextBlock Text="{Binding}" /> </DataTemplate> </ListBox.ItemTemplate> ``` 4. 动画效果:使用`Timeline`和`DoubleAnimation`来控制滚动速度。可以定义一个`Storyboard`,让每个`TextBlock`的位置随着时间变化而改变。 ```csharp Storyboard storyboard = newStoryboard(); DoubleAnimation animation = new DoubleAnimation(0, Height - FontHeight, Duration, EasingFunction.EaseInOutQuint); animation.Completed += AnimationCompleted; Storyboard.SetTargetProperty(animation, "VerticalOffset"); Storyboard.SetTarget(scrollingTextBox); storyboard.Begin(); private void AnimationCompleted(object sender, EventArgs e) { // 更新当前显示的文本并开始下一次滚动 int currentIndex = scrollingTextBox.SelectedIndex; if (currentIndex + 1 >= MyTextStrings.Count) { currentIndex = 0; // 如果已到结尾,从头开始 } scrollingTextBox.SelectedIndex = currentIndex + 1; } ``` 这里假设`Duration`是你想要的滚动时间长度,`FontHeight`是单行文本块的高度,`EasingFunction.EaseInOutQuint`提供了平滑的动画效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值