WPF показывает границу внизу и справа - PullRequest
0 голосов
/ 03 августа 2020

У меня сейчас проблема с тем, что WPF показывает черную линию внизу и справа от моего окна.

В окне только стековая панель с Margin, установленным на 0. Вот моя конфигурация окна:

<Window x:Class="test.Settings"
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"
xmlns:local="clr-namespace:test"
mc:Ignorable="d"
Title="test" 
SizeToContent="WidthAndHeight"
WindowStartupLocation="CenterScreen"
ResizeMode="NoResize"
Background="White"
Margin="0"
Padding="0">

enter image description here

As you can see on the image there is a small black line. Does anyone know how to remove it?

Here is the entire xaml

<Window x:Class="TelefonPopup.Settings"
        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"
        xmlns:local="clr-namespace:TelefonPopup"
        mc:Ignorable="d"
        Title="Telefonpopup Settings"
        SizeToContent="WidthAndHeight"
        WindowStartupLocation="CenterScreen"
        ResizeMode="NoResize">

    <Window.Resources>
        <Style TargetType="Label">
            <Setter Property="VerticalAlignment" Value="Center"/>
            <Setter Property="HorizontalAlignment" Value="Center"/>
            <Setter Property="FontSize" Value="16"/>
        </Style>
        <Style TargetType="RadioButton">
            <Setter Property="VerticalAlignment" Value="Center"/>
            <Setter Property="Margin" Value="10, 0"/>
        </Style>
    </Window.Resources>

    <Grid>
        <Grid.RowDefinitions>
            <RowDefinition/>
            <RowDefinition/>
            <RowDefinition/>
        </Grid.RowDefinitions>
        <Grid.ColumnDefinitions>
            <ColumnDefinition/>
            <ColumnDefinition/>
        </Grid.ColumnDefinitions>

        <Label>Eingeschaltet:</Label>
        <StackPanel Orientation="Horizontal" Grid.Column="1">
            <RadioButton x:Name="rbtnOn">EIN</RadioButton>
            <RadioButton x:Name="rbtnOff">AUS</RadioButton>
        </StackPanel>

        <Label Grid.Row="1">Zeit:</Label>
        <StackPanel Orientation="Horizontal" Grid.Column="1" Grid.Row="1">
            <TextBox x:Name="tbTime" VerticalAlignment="Center" FontSize="16" Margin="15,0,0,0"></TextBox>
            <Label>s</Label>
        </StackPanel>

        <Button x:Name="btnSave" Click="btnSave_Click" Margin="45,10" FontSize="14" Padding="3" Grid.Row="2" Grid.ColumnSpan="2">Speichern</Button>
    </Grid>
</Window>   

1 Ответ

1 голос
/ 03 августа 2020

Я сталкивался с этой проблемой раньше при использовании SizeToContent="WidthAndHeight" и ResizeMode="None". Это проблема с ошибкой рендеринга макета в WPF из-за внутренней математики.

Вы можете легко решить эту проблему, добавив SnapsToDevicePixels="True" к Window.

SnapsToDevicePixels обеспечит отображение элементов на границах пикселей во время рендеринга.

Другой вариант - использовать UseLayoutRounding="True", который выполняет свою работу во время проходов Measure и Arrange.

Я настоятельно рекомендую вам ознакомиться с этими двумя свойствами и решить, что лучше всего подходит для вашего приложения.

...