Привязка к свойству зависимостей пользовательского элемента управления WPF/XAML
Мое приложение выглядит следующим образом:
SectionHeader
SectionHeader
Содержание
SectionHeader
Содержание
SectionHeader
- это пользовательский элемент управления с двумя свойствами зависимостей = Title и Apps.
Заголовок не изменяется, но приложения должны быть привязаны к свойству приложения "Свойства окна главного окна". Свойство Apps требуется только для двух из трех заголовков разделов.
<c:SectionHeader DockPanel.Dock="Top" x:Name="SectionResources" Title="RESOURCES"
Apps="{Binding Path=Apps}" />
Так оно и есть на данный момент. Проблема в том, что приложения не отображаются.
В SectionHeader
DataContext устанавливается в себя следующим образом, что позволяет отображать Title.
DataContext="{Binding RelativeSource={RelativeSource Self}}"
Приложения - это ItemSource для ItemsControl
в UserControl:
<ItemsControl
ItemsSource="{Binding Apps}">
Итак, мои вопросы:
- Как привязать данные к UserControl DP?
- Это более простой способ сделать этот макет без UserControls?
EDIT:
Забыл упомянуть, что Apps - это ObservableCollection of AppsItems.
Вот как выглядит мой DP:
public static readonly DependencyProperty AppsProperty = DependencyProperty.Register("Apps",
typeof (ObservableCollection<AppsItem>), typeof (SectionHeader),
new PropertyMetadata(null, OnAppsPropertyChanged));
private static void OnAppsPropertyChanged(DependencyObject d, DependencyPropertyChangedEventArgs e)
{
Console.WriteLine("Hello!!!");
var sectionHeader = d as SectionHeader;
var value = e.NewValue as ObservableCollection<AppsItem>;
sectionHeader.Apps = value;
}
Ответы
Ответ 1
Дайте имя вашему usecontrol и попробуйте привязать его как
ItemsSource="{Binding Apps,ElementName=root}"
и root - это имя, которое дает вашему usercontrol
<UserControl x:Class="WpfApplication1.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Height="350" Width="525"
x:Name="root">
это привязка элемента к пользовательскому элементу управления, у которого есть свойство Apps
Ответ 2
Попробовав воспроизвести это из вашего описания и столкнувшись с подобной проблемой, я обнаружил, что единственный способ заставить его работать - не устанавливать DataContext для UserControl и вместо этого использовать ElementBinding:
<UserControl x:Class="WpfApplication2.UserControl1"
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="thisUC"
d:DesignHeight="300" d:DesignWidth="300">
<Grid>
<Border Background="Red" Padding="10">
<ListBox x:Name="ucList" ItemsSource="{Binding ElementName=thisUC, Path=UCApps}"/>
</Border>
</Grid>
</UserControl>
Реализация этого UC тривиально проста:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using System.Collections.ObjectModel;
using System.Collections;
namespace WpfApplication2
{
/// <summary>
/// Interaction logic for UserControl1.xaml
/// </summary>
public partial class UserControl1 : UserControl
{
public IEnumerable UCApps
{
get { return (IEnumerable)GetValue(UCAppsProperty); }
set { SetValue(UCAppsProperty, value); }
}
// Using a DependencyProperty as the backing store for Apps. This enables animation, styling, binding, etc...
public static readonly DependencyProperty UCAppsProperty =
DependencyProperty.Register("UCApps", typeof(IEnumerable), typeof(UserControl1), new UIPropertyMetadata(null));
public UserControl1()
{
InitializeComponent();
}
}
}
как и XAML, который его вызывает:
<Grid >
<my:UserControl1 x:Name="ucName" UCApps="{Binding Path=Apps}"/>
</Grid>
(Я изменил имя Apps
в вашем Usercontrol на UCApps
, чтобы я мог видеть, что происходит - слишком много свойств с тем же именем запутались!)
Ответ 3
Apps="{Binding Path=Apps}"
Привязывает приложения к себе.
Попробуйте выполнить
1) Ваша ViewModel должна быть элементом управления DataContext, тогда вы можете использовать следующие
Apps="{Binding DataContext.Apps}"
Также вы можете использовать утилиту Snoop, чтобы найти проблемы с привязкой в режиме реального времени
Ответ 4
Вы пробовали
Apps="{Binding Apps}"
вместо
Apps="{Binding Path=Apps}"
в вашем верхнем уровне управления?
Также вы получаете какие-либо ошибки привязки в окне вывода VS при запуске приложения?