5 ответов:
вам нужно добавить ссылку внутри тега окна. Что-то вроде:
xmlns:controls="clr-namespace:YourCustomNamespace.Controls;assembly=YourAssemblyName"(при добавлении xmlns: controls= " intellisense должен пнуть, чтобы сделать этот бит проще)
затем вы можете добавить элемент управления:
<controls:CustomControlClassName ..... />
вам, вероятно, нужно добавить пространство имен:
<Window x:Class="UserControlTest.Window1" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:local="clr-namespace:UserControlTest" Title="User Control Test" Height="300" Width="300"> <local:UserControl1 /> </Window>
пару советов: во-первых, убедитесь, что в верхней части есть xmlns, который включает пространство имен, в котором живет ваш элемент управления.
xmlns:myControls="clr-namespace:YourCustomNamespace.Controls;assembly=YourAssemblyName" <myControls:thecontrol/>во-вторых, иногда intellisense глупо.
вот как я заставил его работать:
пользовательский элемент управления WPF
<UserControl x:Class="App.ProcessView" 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" d:DesignHeight="300" d:DesignWidth="300"> <Grid> </Grid> </UserControl>
Пользовательский Элемент Управления C#
namespace App { /// <summary> /// Interaction logic for ProcessView.xaml /// </summary> public partial class ProcessView : UserControl // My custom User Control { public ProcessView() { InitializeComponent(); } } }
MainWindow WPF
<Window x:Name="RootWindow" x:Class="App.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:app="clr-namespace:App" Title="Some Title" Height="350" Width="525" Closing="Window_Closing_1" Icon="bouncer.ico"> <Window.Resources> <app:DateConverter x:Key="dateConverter"/> </Window.Resources> <Grid> <ListView x:Name="listView" > <ListView.ItemTemplate> <DataTemplate> <app:ProcessView /> </DataTemplate> </ListView.ItemTemplate> </ListView> </Grid> </Window>
Comments