7

WPFセパレーターにヘッダーを追加したいと思います(GroupBoxの一番上の行のように見えます)。これの目的はビューを異なるセクションに分割することであり、私たちのビジネスのガイドラインではそのためにセパレータを使用する必要があると述べているため、GroupBoxを使用できません...誰かがそれを行う方法を知っていますか?

編集:

他のコントロール(境界線やテキストボックスなど)を使用してこのソリューションを実現できることは知っていますが、HeaderプロパティをSeparatorオブジェクトに追加できるかどうかを知りたいです。

4

2 に答える 2

13

あなたはあなた自身のカスタムコントロールを書くことができます

public class HeaderedSeparator : Control
{
    public static DependencyProperty HeaderProperty =
        DependencyProperty.Register(
        "Header",
        typeof(string),
        typeof(HeaderedSeparator));

    public string Header
    {
        get { return (string)GetValue(HeaderProperty); }
        set { SetValue(HeaderProperty, value); }
    }
}

そしてスタイル:

<Style TargetType="{x:Type local:HeaderedSeparator}">
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="{x:Type local:HeaderedSeparator}">
                <Grid Height="{TemplateBinding Height}">
                    <Grid.ColumnDefinitions>
                        <ColumnDefinition Width="15"/>
                        <ColumnDefinition Width="Auto"/>
                        <ColumnDefinition />
                    </Grid.ColumnDefinitions>
                    <Separator Grid.Column="0"/>
                    <TextBlock Grid.Column="1" 
                        VerticalAlignment="Center" Margin="5 0" 
                        Text="{TemplateBinding Header}"/>
                    <Separator Grid.Column="2" />
                </Grid>
            </ControlTemplate>
        </Setter.Value>
    </Setter>
</Style>

そしてそれを使用します:

<local:HeaderedSeparator Header="Header1"/>
<local:HeaderedSeparator Header="Header2"/>
于 2011-07-04T16:23:51.020 に答える
2

次のようなものを試してください。

  <Grid Height="20">
     <Grid.ColumnDefinitions>
        <ColumnDefinition Width="Auto"/>
        <ColumnDefinition Width="Auto"/>
        <ColumnDefinition Width="*"/>
     </Grid.ColumnDefinitions>
     <Separator
        Width="20"
        VerticalAlignment="Center"/>
     <TextBlock
        Grid.Column="1"
        HorizontalAlignment="Center"
        Margin="4, 0"
        Text="My Header"/>
     <Separator
        Grid.Column="2"
        VerticalAlignment="Center"/>
  </Grid>
于 2011-07-04T16:23:38.103 に答える