XCEED WPF 属性网格集合选择
本文关键字:集合 选择 网格 属性 WPF XCEED | 更新日期: 2023-09-27 18:33:19
我是WPF的新手,可能是个愚蠢的问题,但是......)具有由XCEED WPF可视化的自定义属性类 属性网格
public class ShopProperties
{
private readonly ObservableCollection<string> _cars = new ObservableCollection<string>();
[Category(@"CarsShop")]
[DisplayName(@"CarsCollection")]
public ObservableCollection<string> CarsCollection { get {return _cars;}}
[Browsable(false)]
private string SelectedCar {get; set;}
}
我需要使用什么最简单和最好的PropertyGrid编辑器(或自定义编辑器)来分配CarsCollection中的SelectedCar元素?
经过一些搜索和阅读 http://wpftoolkit.codeplex.com/wikipage?title=PropertyGrid&referringTitle=Documentation我认为就我而言,它至少有两种方式。
1. 自定义xctk:CollectionControl
和编辑 XAML。
<xctk:PropertyGrid Name="_generalPropertyGrid" DockPanel.Dock="Top"
ShowSearchBox="False" ShowSortOptions="False" ShowTitle="False" NameColumnWidth="120" BorderThickness="0">
<xctk:PropertyGrid.EditorDefinitions>
<xctk:EditorTemplateDefinition TargetProperties="CarsCollection">
<xctk:EditorTemplateDefinition.EditingTemplate>
<DataTemplate>
<xctk:CollectionControl SelectedItem="{Binding Path=SelectedCar}"/>
</DataTemplate>
</xctk:EditorTemplateDefinition.EditingTemplate>
</xctk:EditorTemplateDefinition>
</xctk:PropertyGrid.EditorDefinitions>
</xctk:PropertyGrid>
2. 创建自己的UserControl
来实现ITypeEditor
请参阅 http://wpftoolkit.codeplex.com/wikipage?title=PropertyGrid&referringTitle=Documentation 中的 Datails 按ComboBox
选择。 我选择这种方式。
<UserControl x:Class="proj_namespace.CarSelector"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
mc:Ignorable="d"
x:Name="CarSelector"
d:DesignHeight="25" d:DesignWidth="200">
<Grid>
<ComboBox ItemsSource="{Binding Value, ElementName=CarSelector}" SelectionChanged="Selector_OnSelectionChanged"/>
</Grid>
</UserControl>
和类代码后面:
public partial class CarSelector : ITypeEditor
{
public CarSelector()
{
InitializeComponent();
}
public static readonly DependencyProperty ValueProperty =
DependencyProperty.Register("Value", typeof(ObservableCollection<string>), typeof(CarSelector),
new FrameworkPropertyMetadata(null, FrameworkPropertyMetadataOptions.BindsTwoWayByDefault));
public string Value
{
get { return (string)GetValue(ValueProperty); }
set { SetValue(ValueProperty, value); }
}
public FrameworkElement ResolveEditor(PropertyItem propertyItem)
{
var binding = new Binding("Value");
binding.Source = propertyItem;
binding.Mode = propertyItem.IsReadOnly ? BindingMode.OneWay : BindingMode.TwoWay;
BindingOperations.SetBinding(this, ValueProperty, binding);
return this;
}
private void Selector_OnSelectionChanged(object sender, SelectionChangedEventArgs e)
{
if (sender != null)
MainWindow.Instance._properties.SelectedCar = (sender as ComboBox).SelectedItem as string;
}
}
最后在属性上方添加自定义编辑器行
[Editor(typeof(CarSelector), typeof(CarSelector))]
public ObservableCollection<string> CarsCollection { get { return _securities; } }
我不知道
为什么使用 propertygrid 而不是 datagrid,属性网格用于查看和更改内存中对象的属性(如 WPF 窗口的元素之一),它就像 Visual Studio 中的属性窗口显示所选对象的所有属性。
如果你想显示一个集合,即使你想在之后编辑它,你也应该尝试xceed数据网格,我认为它会更像你的盟友。
但无论如何,你可以将属性网格的 selectedProperty 属性绑定到所选的汽车上,也可以直接使用 propertygrid 的 selectedProperty 属性,检查它是否是汽车。