我是一个WPF菜鸟,所以对这个问题中任何固有的愚蠢道歉(!)
我正在尝试使用双击来编辑WPF树视图标签 - 我已经用Google搜索了,看起来这样做的两种方法是使用自定义控件或使用隐藏TextBox/TextBlock之一的样式.
使用样式将标签设置为基于DataTrigger的textBox似乎很容易(例如下面的1),但这意味着无论何时选择行,它都会被"编辑".
我真正想做的是在moused双击事件上启用此功能(转换到文本框),但似乎不能以下面的方式使用EventTriggers,因为它们是瞬态的.(似乎我不能简单地在代码隐藏中使用DoubleClick事件,因为这不会(??)允许我影响显示的控件来显示/隐藏文本框).
使用完整的自定义控件似乎是另一种选择 - 这里有一个AAALMOST工作示例(http://www.codeproject.com/KB/WPF/editabletextblock.aspx),但它不存在HierachicalDataTemplate子句时不起作用(并且它看起来不像解决方案即将到来).
(例如1 - 选中时从文本框切换到文本框)
<Window x:Class="treetest.Window1"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="clr-namespace:treetest"
Title="Window1" Height="300" Width="300">
<Window.Resources>
<Style x:Key="EditableContentControl" TargetType="{x:Type ContentControl}">
<Setter Property="ContentTemplate">
<Setter.Value>
<DataTemplate DataType="{x:Type local:CompositeViewModel}">
<TextBlock Text="{Binding Path=Name}" />
</DataTemplate>
</Setter.Value>
</Setter>
<Style.Triggers>
<DataTrigger Binding="{Binding Path=IsSelected,RelativeSource=RelativeSource AncestorType={x:Type TreeViewItem}}}"
Value="True">
<Setter Property="ContentTemplate">
<Setter.Value>
<DataTemplate DataType="{x:Type local:CompositeViewModel}">
<TextBox Text="{Binding Path=Name,UpdateSourceTrigger=PropertyChanged}" />
</DataTemplate>
</Setter.Value>
</Setter>
</DataTrigger>
</Style.Triggers>
</Style>
</Window.Resources>
<Grid>
<TreeView Margin="12,12,115,12" Name="treeView1"
ItemsSource="{Binding Path=GetRootData}"
>
<TreeView.ItemTemplate>
<HierarchicalDataTemplate DataType="{x:Type local:CompositeViewModel}" ItemsSource="{Binding Path=Children}">
<ContentControl Content="{Binding}" Style="{StaticResource EditableContentControl}"/>
</HierarchicalDataTemplate>
</TreeView.ItemTemplate>
</TreeView>
</Grid>
</Window>
Run Code Online (Sandbox Code Playgroud)
小智 5
有帮助吗:
string name = "some name";
var treeItem = new TreeViewItem()
{
Header = name,
};
var textBox = new TextBox()
{
Text = name,
};
treeItem.MouseDoubleClick += (o, e) =>
{
TreeItem.Header = textBox;
};
textBox.LostFocus += (o, e) =>
{
treeItem.Header = textBox.Text;
name = textBox.Text;
};
Run Code Online (Sandbox Code Playgroud)
它非常简单,而且对我来说效果很好。
| 归档时间: |
|
| 查看次数: |
8819 次 |
| 最近记录: |