кнопка внутри границы - PullRequest
       28

кнопка внутри границы

3 голосов
/ 27 декабря 2011

У меня проблема с кнопкой внутри рамки.Я хочу, чтобы кнопка заполняла пространство кнопки внутри границы, но кнопка находится над границей, а не под границей.И таким образом он скрывает радиус кордера, сделанный границей.

Вот изображение моей проблемы:

enter image description here

Кто-то знает, как поместить кнопку нижеграница?

Вот мой xaml для моей кнопки:

<Button Name="filterCustomerBtn" 
        Command="{Binding Path=UpdateDepartments}" 
        Style="{StaticResource defaultButtonStyle}" 
        Width="200" 
        Margin="0, 15, 0, 0" 
        HorizontalAlignment="Center">Filter now</Button>

Вот соответствующий код xaml:

<Window.Resources>
    <Style x:Key="defaultButtonStyle" TargetType="Button">
        <Setter Property="Margin" Value="2"></Setter>
    </Style>
</Window.Resources>


<StackPanel Orientation="Vertical" DockPanel.Dock="Top">
    <Border Style="{StaticResource MainBorderStyle}" Margin="2" Background="LightBlue">
        <StackPanel Orientation="Vertical" VerticalAlignment="Center">
            <Button Name="filterCustomerBtn" Command="{Binding Path=UpdateDepartments}" Style="{StaticResource defaultButtonStyle}" Width="200" Margin="0, 15, 0, 0" HorizontalAlignment="Center" Panel.ZIndex="-1">Filter now</Button>
        </StackPanel>
    </Border>
</StackPanel>

Результат Image

enter image description here

Ответы [ 3 ]

4 голосов
/ 27 декабря 2011

Так как у вашей границы есть угловой радиус, вы не можете ничего сделать в контексте стиля кнопки по умолчанию, чтобы закруглить ее углы, чтобы она выглядела без шва с границей. Я столкнулся с этой проблемой с несколькими различными элементами управления, включая кнопки. Решением вашей проблемы является создание ControlTemplate для кнопки. В этом шаблоне вы сможете установить радиус нижних углов вашей кнопки или все 4 угла, если хотите, равный радиусу угла вашей границы. Нажмите здесь для хорошего примера создания шаблона кнопки с закругленными углами. Ниже я попытался упростить код блога, удалив наведенную анимацию. Сконцентрируйтесь на разделе Границы, поскольку они являются основным шаблоном.

<Style x:Key="RoundedButton" TargetType="{x:Type Button}">
    <Setter Property="Background" Value="{TemplateBinding Background}"/>
    <Setter Property="Foreground" Value="{TemplateBinding Foreground}"/>
    <Setter Property="BorderThickness" Value="1"/>
    <Setter Property="HorizontalContentAlignment" Value="Center"/>
    <Setter Property="VerticalContentAlignment" Value="Center"/>
    <Setter Property="Padding" Value="0,0,1,1"/>
    <Setter Property="Template">
    <Setter.Value>
        <ControlTemplate TargetType="{x:Type Button}">                        
            <Border 
                CornerRadius="5,5,5,5" 
                BorderThickness="1,1,1,1" 
                RenderTransformOrigin="0.5,0.5" 
                x:Name="border" 
                BorderBrush="#000000">
                    <Border.RenderTransform>
                        <TransformGroup>
                            <ScaleTransform ScaleX="1" ScaleY="1"/>
                            <SkewTransform AngleX="0" AngleY="0"/>
                            <RotateTransform Angle="0"/>
                            <TranslateTransform X="0" Y="0"/>
                        </TransformGroup>
                    </Border.RenderTransform>
                    <Border 
                        Background="{TemplateBinding Background}" 
                        CornerRadius="5,5,5,5" 
                        x:Name="border1">
                        <Grid>
                            <Grid.RowDefinitions>
                                <RowDefinition Height="0.5*"/>
                                <RowDefinition Height="0.5*"/>
                            </Grid.RowDefinitions>
                            <Border Grid.Row="0" CornerRadius="5,5,0,0">
                                <Border.Background>
                                    <LinearGradientBrush 
                                        EndPoint="0.5,1" 
                                        StartPoint="0.5,0">
                                        <GradientStop 
                                            Color="#00FFFFFF" 
                                            Offset="0"/>
                                        <GradientStop 
                                            Color="#7EFFFFFF" 
                                            Offset="1"/>
                                    </LinearGradientBrush>
                                </Border.Background>
                            </Border>                                
                            <ContentPresenter 
                                VerticalAlignment="Center"  
                                Grid.RowSpan="2" 
                                HorizontalAlignment="Center" 
                                x:Name="contentPresenter"/>
                        </Grid>
                    </Border>
                </Border>
                <ControlTemplate.Triggers>
                    <Trigger Property="IsEnabled" Value="False">
                        <Setter 
                            Property="Opacity" 
                            TargetName="border1"  
                            Value="0.5"/>
                        <Setter 
                            Property="Opacity" 
                            TargetName="border" 
                            Value="1"/>
                        <Setter 
                            Property="Opacity" 
                            TargetName="contentPresenter" 
                            Value="0.5"/>
                    </Trigger>
                    <Trigger 
                        Property="IsPressed" 
                        Value="True">
                        <Setter 
                            Property="RenderTransform" 
                            TargetName="border">
                            <Setter.Value>
                                <TransformGroup>
                                    <ScaleTransform 
                                        ScaleX="0.9" 
                                        ScaleY="0.9"/>
                                    <SkewTransform 
                                        AngleX="0" 
                                        AngleY="0"/>
                                    <RotateTransform 
                                        Angle="0"/>
                                    <TranslateTransform 
                                        X="0" 
                                        Y="0"/>
                                </TransformGroup>
                            </Setter.Value>
                        </Setter>
                    </Trigger>
                </ControlTemplate.Triggers>
            </ControlTemplate>
        </Setter.Value>
    </Setter>
</Style>

Также здесь есть ссылка на страницу MSDN по этой теме.

0 голосов
/ 27 декабря 2011

Вы хотите, чтобы кнопка находилась на ниже границы ... но она имеет значение content внутри границы.Это не сработает ..

Поместите границу в сетку из двух строк и двух столбцов, поместите рамку и ее содержимое в строку, которая охватывает оба столбца, затем нажмите кнопку в первом столбце другой строки,затем margin кнопку до места на границе, где вы хотите.Вот пример:

<Grid>
    <Grid.RowDefinitions>
        <RowDefinition Height="*" />
        <RowDefinition Height="20" />
    </Grid.RowDefinitions>
    <Grid.ColumnDefinitions>
        <ColumnDefinition Width="348*" />
        <ColumnDefinition Width="155*" />
    </Grid.ColumnDefinitions>
    <Border Style="{StaticResource MainBorderStyle}"
        Margin="2"
        Height="100"
        Background="LightBlue"
            Grid.ColumnSpan="2">
        <StackPanel Orientation="Vertical"
                VerticalAlignment="Center">
        <TextBlock Text="Nothing" Width="50"/>
    </StackPanel>
</Border>
<Button Name="filterCustomerBtn"
        Grid.Column="1"
        Grid.Row="1"
        Command="{Binding Path=UpdateDepartments}"
        Width="100"
        Height="24"
        HorizontalAlignment="Right"
        Margin="0,-55,5,0"
        Panel.ZIndex="100">Filter now</Button>
</Grid>
0 голосов
/ 27 декабря 2011

Вы можете использовать свойство ZIndex для перемещения кнопки вниз по границе

Попробуйте это

<Button Name="filterCustomerBtn" 
Command="{Binding Path=UpdateDepartments}" 
Style="{StaticResource defaultButtonStyle}" 
Width="200" 
Margin="0, 15, 0, 0" 
HorizontalAlignment="Center" Panel.ZIndex="-1">Filter now</Button>
...