Гость
Форумы / WPF, Silverlight [игнор отключен] [закрыт для гостей] / Silverlight usercontrol на основе панели (грида) / 2 сообщений из 2, страница 1 из 1
17.10.2012, 18:31
    #38003146
Mans7
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Silverlight usercontrol на основе панели (грида)
Доброго времени суток.

Подскажите, пожалуйста, как можно было бы сделать юзерконтрол базированный от грида (в идеале) или от панели таким образом чтобы я мог в XAML'е изменять контент?

То есть, в основном xaml'е будет ну допустим такой код:
Код: xml
1.
2.
3.
<local:TestGrid>
            <Ellipse x:Name="CircleRed" Width="100" Height="100" Fill="Red" Stroke="Black" StrokeThickness="2"/>
        </local:TestGrid>



А отоброжаться это должно как стилизованный грид (скажем так, имитация childwindow у которого есть сверху панелька, крестик и прочее - метод drag&drop я знаю как оформить) с тем контентом который указан в основном xamlе. Я сделал юзерконтрол, сделал его стиль:
Код: xml
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
<UserControl x:Class="DiplomatCONTROLS.TestGrid"
    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"
    mc:Ignorable="d"
    d:DesignHeight="300" x:Name="dd" d:DesignWidth="400">
    <UserControl.Resources>
        <!-- A ContentControl template that defines your background -->
        <ControlTemplate x:Key="BackgroundTemplate" TargetType="ContentControl">
            <Grid>
                <Rectangle Fill="Beige" Stroke="Gray" StrokeThickness="1" Margin="10" RadiusX="15" RadiusY="10"/>
                <Rectangle Fill="White" Stroke="Gray" StrokeThickness="1" Margin="12,30,12,12" RadiusX="15" RadiusY="10"/>
                <Grid.Effect>
                    <DropShadowEffect BlurRadius="10" Direction="0" ShadowDepth="1"/>
                </Grid.Effect>
            </Grid>
        </ControlTemplate>
        <!-- A ContentControl Style that references the background template -->
        <Style x:Key="BackgroundStyle" TargetType="ContentControl">
            <Setter Property="Template" Value="{StaticResource BackgroundTemplate}" />
        </Style>
    </UserControl.Resources>
    <Canvas x:Name="LayoutRoot" Background="White">
        <Grid Width="300" Height="250">
            <ContentControl Style="{StaticResource BackgroundStyle}" />
            <!--<TextBlock Text="Your Cofent" Foreground="Red" FontSize="36" HorizontalAlignment="Center" VerticalAlignment="Center" />-->
        </Grid>
    </Canvas>
</UserControl>


И если просто написать
Код: xml
1.
<local:TestGrid/>


То отображается он как надо. А если как хочу:
Код: xml
1.
2.
3.
<local:TestGrid>
            <Ellipse x:Name="CircleRed" Width="100" Height="100" Fill="Red" Stroke="Black" StrokeThickness="2"/>
        </local:TestGrid>


То вся стилистика пропадает. Как мне сделать правильно?
...
Рейтинг: 0 / 0
18.10.2012, 11:56
    #38003912
AlexeiK
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Silverlight usercontrol на основе панели (грида)
Mans7,

ContentPresenter ?
читал?
почитай
...
Рейтинг: 0 / 0
Форумы / WPF, Silverlight [игнор отключен] [закрыт для гостей] / Silverlight usercontrol на основе панели (грида) / 2 сообщений из 2, страница 1 из 1
Целевая тема:
Создать новую тему:
Автор:
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]