Я хочу написать ContentControl
для размещения других элементов управления и предоставления им специальной границы.ContentControl со специальной рамкой
Так что я добавил новый UserControl
, сделанный из ContentControl
. У него есть сетка, на внешних сторонах я хочу иметь границу.
Итак, первый вопрос: является ли это хорошим подходом для достижения «пограничного» контроля?
Вот XAML
<ContentControl x:Class="DemoApplication.Controls.ImpressedContentControl"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
Name="ImpressedContent"
d:DesignHeight="300"
d:DesignWidth="300"
mc:Ignorable="d">
<Grid>
<Grid.Resources>
<ImageBrush x:Key="ImpressedLeftBrush"
ImageSource="/DemoApplication;component/Images/Impressed_left.png"
TileMode="FlipY"
Viewport="0,0,100,100"
ViewportUnits="Absolute" />
<ImageBrush x:Key="ImpressedRightBrush"
ImageSource="/DemoApplication;component/Images/Impressed_right.png"
TileMode="FlipY"
Viewport="0,0,100,100"
ViewportUnits="Absolute" />
<ImageBrush x:Key="ImpressedTopBrush"
ImageSource="/DemoApplication;component/Images/Impressed_top.png"
TileMode="FlipY"
Viewport="0,0,100,100"
ViewportUnits="Absolute" />
<ImageBrush x:Key="ImpressedBottomBrush"
ImageSource="/DemoApplication;component/Images/Impressed_bottom.png"
TileMode="FlipY"
Viewport="0,0,100,100"
ViewportUnits="Absolute" />
</Grid.Resources>
<Grid.RowDefinitions>
<RowDefinition Height="4" />
<RowDefinition Height="1*" />
<RowDefinition Height="4" />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="4" />
<ColumnDefinition Width="1*" />
<ColumnDefinition Width="4" />
</Grid.ColumnDefinitions>
<Grid Grid.Row="0"
Grid.Column="1"
Background="{DynamicResource ImpressedTopBrush}" />
<Grid Grid.Row="2"
Grid.Column="1"
Background="{DynamicResource ImpressedBottomBrush}" />
<Grid Grid.Row="1"
Grid.Column="0"
Background="{DynamicResource ImpressedLeftBrush}" />
<Grid Grid.Row="1"
Grid.Column="2"
Background="{DynamicResource ImpressedRightBrush}" />
<ContentControl Grid.Row="1"
Grid.Column="1"
HorizontalAlignment="Stretch"
VerticalAlignment="Stretch"
Content="{Binding ElementName=ImpressedContent,
Path=ControlContent}" />
</Grid>
</ContentControl>
В коде у меня есть DependencyProperty
, чтобы установить содержание.
public partial class ImpressedContentControl : ContentControl
{
public ImpressedContentControl()
{
InitializeComponent();
}
public Control ControlContent
{
get { return (Control)GetValue(ControlContentProperty); }
set { SetValue(ControlContentProperty, value); }
}
public static readonly DependencyProperty ControlContentProperty =
DependencyProperty.Register("ControlContent", typeof(Control), typeof(ImpressedContentControl), new UIPropertyMetadata(""));
}
Я хочу использовать несколько как
<controls:ImpressedContentControl Grid.Column="1">
<ControlContent>
<TextBlock Text="FooBar Text" />
</ControlContent>
</controls:ImpressedContentControl>
Можно ли использовать контент свойство ContentControl каким-то образом?
Есть ли более простой способ достичь этого?
Любые идеи, которые могут быть очень полезными!
это, кажется, только то, что я хочу. Попробуем. –
Подумайте, это все. Большое спасибо! просто нужно что-то сделать с моими изображениями;) –