如何创建一个没有边框的WPF窗口,只能通过夹点调整大小?

Dre*_*kes 87 .net wpf window controltemplate resizegrip

如果您ResizeMode="CanResizeWithGrip"在WPF上设置,Window则右下角会显示调整大小的手柄,如下所示:

如果你设置WindowStyle="None"了标题栏,标题栏会消失,但灰色斜角边缘会保留,直到你设置为止ResizeMode="NoResize".不幸的是,通过设置这种属性组合,调整大小的抓握也会消失.

我通过习惯覆盖了Window's' .我想自己指定窗口的边框,我不需要用户能够从四面调整窗口大小,但我确实需要调整大小.ControlTemplateStyle

有人可以详细说明满足所有这些标准的简单方法吗?

  1. Window除了我指定的那个之外,没有边界ControlTemplate.
  2. 在右下角工作调整大小的抓地力.
  3. 没有标题栏.

Zom*_*eep 173

如果AllowsTransparencyWindow(即使没有设置任何透明度值)上设置属性,边框将消失,您只能通过夹点调整大小.

<Window
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Width="640" Height="480" 
    WindowStyle="None"
    AllowsTransparency="True"
    ResizeMode="CanResizeWithGrip">

    <!-- Content -->

</Window>
Run Code Online (Sandbox Code Playgroud)

结果如下:

  • 尽管如此,AllowTransparency有几个失败,Windows无法再承载子窗口控件,例如WebBrowser,通常强制软件渲染,报告了内存泄漏.请参阅下面的解决方法. (3认同)
  • 哇,我不希望这样,但是它在5分钟内制作你自己的便利贴纸非常方便,谢谢:) (2认同)
  • @Grault thats摆脱了窗口标题,但是窗体周围仍然有一个实心边框。AllowsTransparency摆脱了边界。 (2认同)

小智 69

我试图创建一个无边框窗口 WindowStyle="None"但是当我测试它时,似乎在顶部出现了一个白色条,经过一些研究它似乎是一个"调整边框",这里是一个图像(我用黄色标记):

挑战

经过对互联网的一些研究,以及许多困难的非xaml解决方案,我发现的所有解决方案都是C#代码和许多代码行,我在这里间接找到了解决方案:最大自定义窗口失去阴影效果

<WindowChrome.WindowChrome>
    <WindowChrome 
        CaptionHeight="0"
        ResizeBorderThickness="5" />
</WindowChrome.WindowChrome>
Run Code Online (Sandbox Code Playgroud)

注意 :您需要使用.NET 4.5框架,或者如果您使用的是旧版本,则使用WPFShell,只需引用shell并使用Shell:WindowChrome.WindowChrome.

我使用了WindowChromeWindow 的属性,如果使用它,白色的"resize border"会消失,但是你需要定义一些属性才能正常工作.

CaptionHeight:这是标题区域(标题栏)的高度,允许Aero快照,双击行为作为普通标题栏.将其设置为0(零)以使按钮工作.

ResizeBorderThickness:这是窗口边缘的厚度,您可以在此处调整窗口大小.我把它放到5,因为我喜欢这个数字,因为如果你把零放在一边很难调整窗口的大小.

使用这个短代码后,结果如下:

解决方案

而现在,白色的边框消失了,而无需使用ResizeMode="NoResize"AllowsTransparency="True",也它显示在窗口中的影子.

稍后我将解释如何使用简单和简短的代码轻松地工作按钮(我没有使用按钮的图像),我是新的,我认为我可以发布到codeproject,因为在这里我没有找到这个地方发布教程.

也许还有另一个解决方案(我知道像我这样的新手有困难和困难的解决方案),但这适用于我的个人项目.

这是完整的代码

<Window x:Class="MainWindow"
    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:Concursos"
    mc:Ignorable="d"
    Title="Concuros" Height="350" Width="525"
    WindowStyle="None"
    WindowState="Normal" 
    ResizeMode="CanResize"
    >
<WindowChrome.WindowChrome>
    <WindowChrome 
        CaptionHeight="0"
        ResizeBorderThickness="5" />
</WindowChrome.WindowChrome>

    <Grid>

    <Rectangle Fill="#D53736" HorizontalAlignment="Stretch" Height="35" VerticalAlignment="Top" PreviewMouseDown="Rectangle_PreviewMouseDown" />
    <Button x:Name="Btnclose" Content="r" HorizontalAlignment="Right" VerticalAlignment="Top" Width="35" Height="35" Style="{StaticResource TempBTNclose}"/>
    <Button x:Name="Btnmax" Content="2" HorizontalAlignment="Right" VerticalAlignment="Top" Margin="0,0,35,0" Width="35" Height="35" Style="{StaticResource TempBTNclose}"/>
    <Button x:Name="Btnmin" Content="0" HorizontalAlignment="Right" VerticalAlignment="Top" Margin="0,0,70,0" Width="35" Height="35" Style="{StaticResource TempBTNclose}"/>

</Grid>
Run Code Online (Sandbox Code Playgroud)

谢谢!

  • 嗯,为这个点赞!这是迄今为止该线程最简单/不折衷的答案!应该得到更多的“支持”投票。我不得不承认我对此有点怀疑,尤其是对于幕后发生的事情。我什至检查了 WFP 树,它确实看起来没有添加透明度。即使像“WebBrowser”这样的棘手控件也能正常显示。当应用程序承受很大压力时,我在使用透明度时遇到了渲染冻结问题......好吧,这个解决方案不会发生这种情况。我认为可能是时候停用 @Wobbles 解决方案了! (5认同)

Wob*_*les 38

虽然接受的答案是非常正确的,但只想指出AllowTransparency有一些垮台.它不允许显示子窗口控件,即WebBrowser,它通常会强制软件渲染,这可能会产生负面的性能影响.

但是有一个更好的工作.

如果要创建一个没有可调整大小的边框的窗口,并且能够托管WebBrowser控件或指向URL的框架控件,那么所述控件的内容将显示为空.

我发现了一个解决方法; 在Window中,如果你将WindowStyle设置为None,ResizeMode设置为NoResize(忍受我,你仍然可以在完成后重新调整大小)然后确保你有UNCHECKED AllowTransparency你将有一个没有边框的静态大小的窗口并将显示浏览器控件.

现在,您可能仍希望能够调整大小吗?好吧,我们可以通过互操作来实现:

    [DllImport("user32.dll", CharSet = CharSet.Auto)]
    private static extern IntPtr SendMessage(IntPtr hWnd, uint Msg, IntPtr wParam, IntPtr lParam);

    [DllImportAttribute("user32.dll")]
    public static extern bool ReleaseCapture();

    //Attach this to the MouseDown event of your drag control to move the window in place of the title bar
    private void WindowDrag(object sender, MouseButtonEventArgs e) // MouseDown
    {
        ReleaseCapture();
        SendMessage(new WindowInteropHelper(this).Handle,
            0xA1, (IntPtr)0x2, (IntPtr)0);
    }

    //Attach this to the PreviewMousLeftButtonDown event of the grip control in the lower right corner of the form to resize the window
    private void WindowResize(object sender, MouseButtonEventArgs e) //PreviewMousLeftButtonDown
    {
        HwndSource hwndSource = PresentationSource.FromVisual((Visual)sender) as HwndSource;
        SendMessage(hwndSource.Handle, 0x112, (IntPtr)61448, IntPtr.Zero);
    }
Run Code Online (Sandbox Code Playgroud)

瞧,WPF窗口没有边框,仍然可以移动和调整大小,而不会失去与WebBrowser等控件的兼容性

  • 以下是其他wParam值,只需根据需要将新事件分配给新UI对象`private enum ResizeDirection {Left = 61441,Right = 61442,Top = 61443,TopLeft = 61444,TopRight = 61445,Bottom = 61446,BottomLeft = 61447,BottomRight = 61448,}` (5认同)
  • @CJK是的,但毫无疑问你可以将Windows消息挂钩并处理它. (2认同)

小智 5

样品在这里:

<Style TargetType="Window" x:Key="DialogWindow">
        <Setter Property="AllowsTransparency" Value="True"/>
        <Setter Property="WindowStyle" Value="None"/>
        <Setter Property="ResizeMode" Value="CanResizeWithGrip"/>
        <Setter Property="Template">
            <Setter.Value>
                <ControlTemplate TargetType="{x:Type Window}">
                    <Border BorderBrush="Black" BorderThickness="3" CornerRadius="10" Height="{TemplateBinding Height}"
                            Width="{TemplateBinding Width}" Background="Gray">
                        <DockPanel>
                            <Grid DockPanel.Dock="Top">
                                <Grid.ColumnDefinitions>
                                    <ColumnDefinition></ColumnDefinition>
                                    <ColumnDefinition Width="50"/>
                                </Grid.ColumnDefinitions>
                                <Label Height="35" Grid.ColumnSpan="2"
                                       x:Name="PART_WindowHeader"                                            
                                       HorizontalAlignment="Stretch" 
                                       VerticalAlignment="Stretch"/>
                                <Button Width="15" Height="15" Content="x" Grid.Column="1" x:Name="PART_CloseButton"/>
                            </Grid>
                            <Border HorizontalAlignment="Stretch" VerticalAlignment="Stretch" 
                                        Background="LightBlue" CornerRadius="0,0,10,10" 
                                        Grid.ColumnSpan="2"
                                        Grid.RowSpan="2">
                                <Grid>
                                    <Grid.ColumnDefinitions>
                                        <ColumnDefinition/>
                                        <ColumnDefinition Width="20"/>
                                    </Grid.ColumnDefinitions>
                                    <Grid.RowDefinitions>
                                        <RowDefinition Height="*"/>
                                        <RowDefinition Height="20"></RowDefinition>
                                    </Grid.RowDefinitions>
                                    <ResizeGrip Width="10" Height="10" Grid.Column="1" VerticalAlignment="Bottom" Grid.Row="1"/>
                                </Grid>
                            </Border>
                        </DockPanel>
                    </Border>
                </ControlTemplate>
            </Setter.Value>
        </Setter>
    </Style>
Run Code Online (Sandbox Code Playgroud)

  • 您应该包含代码如何工作的简要说明. (22认同)