Как полностью убрать границу кнопки в wpf? - PullRequest
124 голосов
/ 15 июня 2009

Я пытаюсь создать кнопку с изображением и без рамки - так же, как кнопки панели инструментов Firefox, прежде чем навести на них курсор и увидеть полную кнопку.

Я попытался установить BorderBrush на Transparent, BorderThickness на 0, а также попытался BorderBrush="{x:Null}", но вы все равно можете увидеть контур кнопки.

Ответы [ 8 ]

245 голосов
/ 02 июня 2010

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

<Button BorderThickness="0"  
    Style="{StaticResource {x:Static ToolBar.ButtonStyleKey}}" >...
46 голосов
/ 17 июля 2012

Возможно, вам придется изменить шаблон кнопки, это даст вам кнопку без рамки, но также без какого-либо нажатия или отключенного эффекта:

    <Style x:Key="TransparentStyle" TargetType="{x:Type Button}">
        <Setter Property="Template">
            <Setter.Value>
                <ControlTemplate TargetType="Button">
                    <Border Background="Transparent">
                        <ContentPresenter/>
                    </Border>
                </ControlTemplate>
            </Setter.Value>
        </Setter>
    </Style>

и кнопка:

<Button Style="{StaticResource TransparentStyle}"/>
23 голосов
/ 25 июля 2010

Что вам нужно сделать, это примерно так:

<Button Name="MyFlatImageButton"
        Background="Transparent"
        BorderBrush="Transparent"
        BorderThickness="0" 
        Padding="-4">
   <Image Source="MyImage.png"/>
</Button>

Надеюсь, это то, что вы искали.

Редактировать: Извините, забыл упомянуть, что если вы хотите видеть границу кнопки при наведении на изображение, все, что вам нужно сделать, это пропустить Padding = "- 4" .

20 голосов
/ 27 декабря 2010

Я не знаю, почему другие не указали, что этот вопрос дублируется с на этот вопрос с принятым ответом .

Я приведу здесь решение: вам нужно переопределить ControlTemplate из Button:

<Button Content="save" Name="btnSaveEditedText" 
                Background="Transparent" 
                Foreground="White" 
                FontFamily="Tw Cen MT Condensed" 
                FontSize="30" 
                Margin="-280,0,0,10"
                Width="60"
                BorderBrush="Transparent"
                BorderThickness="0">
    <Button.Template>
        <ControlTemplate TargetType="Button">
             <ContentPresenter Content="{TemplateBinding Content}"/>
        </ControlTemplate>
    </Button.Template>  
</Button>
3 голосов
/ 25 ноября 2010

Вы можете использовать гиперссылку вместо кнопки, например:

        <TextBlock>
            <Hyperlink TextDecorations="{x:Null}">
            <Image Width="16"
                   Height="16"
                   Margin="3"
                   Source="/YourProjectName;component/Images/close-small.png" />
            </Hyperlink>
        </TextBlock>
2 голосов
/ 15 июня 2009

Возможно, вы уже знаете, что размещение вашей кнопки внутри панели инструментов дает вам такое поведение, но если вы хотите что-то, что будет работать во ВСЕХ текущих темах с любой предсказуемостью, вам нужно будет создать новый ControlTemplate. *

Решение Прашанта не работает с кнопкой, не находящейся на панели инструментов, когда кнопка имеет фокус. Он также не работает на 100% с темой по умолчанию в XP - вы все равно можете видеть слабые серые границы, когда ваш контейнер Background имеет белый цвет.

1 голос
/ 24 июля 2017

Программно вы можете сделать это:

btn.BorderBrush = new SolidColorBrush(Colors.Transparent);
0 голосов
/ 18 декабря 2015

Почему бы вам не установить оба значения Background & BorderBrush одинаковыми brush

 <Style TargetType="{x:Type Button}" >
        <Setter Property="Background" Value="{StaticResource marginBackGround}"></Setter>
        <Setter Property="BorderBrush" Value="{StaticResource marginBackGround}"></Setter>            
 </Style>

<LinearGradientBrush  x:Key="marginBackGround" EndPoint=".5,1" StartPoint="0.5,0">
    <GradientStop Color="#EE82EE" Offset="0"/>
    <GradientStop Color="#7B30B6" Offset="0.5"/>
    <GradientStop Color="#510088" Offset="0.5"/>
    <GradientStop Color="#76209B" Offset="0.9"/>
    <GradientStop Color="#C750B9" Offset="1"/>
</LinearGradientBrush>
...