3

StatusBar (定義されたスタイルを持つ) のすべてのボタンが同じスタイル (幅など) を持つ wpf のスタイルを書きたいと思います。

私のスタイルは次のようになります。

<Style TargetType="{x:Type StatusBar}"
               x:Key="DialogBoxStatusBarStyle">
    <Setter Property="Background"
                    Value="LightGray" />
    <Setter Property="Padding"
                    Value="5" />

    ...?

</Style>

要素の xaml:

<StatusBar Style="{StaticResource ResourceKey=DialogBoxStatusBarStyle}" Grid.Row="3"
               FlowDirection="RightToLeft">
        <Button Content="Übernehmen"
                Width="100"
                HorizontalAlignment="Right" />
        <Button Content="Abbrechen"
                Width="100"
                HorizontalAlignment="Right" />

        <Button Content="OK"
                Width="100"
                HorizontalAlignment="Right" />
    </StatusBar>

最終バージョンでは、すべてのボタンの幅を 100 に設定したくありません。これは のスタイルで定義するStatusBarか、 のボタンの子のスタイルで定義する必要がありますStatusBar

4

2 に答える 2

10

ボタンのデフォルトのスタイルを次のに追加できResourcesますDialogBoxStatusBarStyle

<Style TargetType="StatusBar" x:Key="DialogBoxStatusBarStyle">
    <Style.Resources>
        <Style TargetType="Button">
            <Setter Property="Width" Value="100"/>
        </Style>
    </Style.Resources>
    ...
</Style>
于 2013-01-14T13:25:09.190 に答える
2

上記の回答 (@Clemens) を拡張するには、このようなことを行って、ボタン スタイルを個別に再利用し、特定のコンテナーの子にも適用することもできます。

スタイル:

<Style TargetType="{x:Type Button}" x:Key="MyButtonStyle">
    <Setter Property="Width" Value="100" />
    <Setter Property="HorizontalAlignment" Value="Right" />
</Style>

<Style TargetType="{x:Type StatusBar}" x:Key="DialogBoxStatusBarStyle">
    <Setter Property="Background" Value="LightGray" />
    <Setter Property="Padding" Value="5" />

    <Style.Resources>
        <Style TargetType="{x:Type Button}" BasedOn="{StaticResource MyButtonStyle}" />
    </Style.Resources>
    ...
</Style>
于 2016-04-25T23:04:35.643 に答える