在WinForms中,Form有一个ClientSize属性(继承自Control),它返回其客户区的大小,即标题栏和窗口边框内的区域。
我在WPF中没有看到任何类似内容:没有ClientSize,ClientWidth,ClientHeight,GetClientSize(),或者我可以想到的其他任何猜测名称的内容。
如何获取WPF窗口的客户端大小?
答案 0 :(得分:11)
你可以做到的一种方法是采用最顶层的子元素,将this.Content
强制转换为其类型,并在其上调用.RenderSize
,这将为您提供其大小。
<Window x:Class="XML_Reader.Window1"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="Window1" Height="400" Width="600" WindowStyle="SingleBorderWindow">
<Grid VerticalAlignment="Stretch" HorizontalAlignment="Stretch">
</Grid>
</Window>
((Grid)this.Content).RenderSize.Height
((Grid)this.Content).RenderSize.Width
编辑:
如特伦特所说,ActualWidth
和ActualHeight
也是可行的解决方案。获得上述内容的基本上更容易的方法。
答案 1 :(得分:10)
var h = ((Panel)Application.Current.MainWindow.Content).ActualHeight;
var w = ((Panel)Application.Current.MainWindow.Content).ActualWidth;
答案 2 :(得分:2)
一种方法是使用下面的代码。 XAML:
<Window x:Class="WpfApplication1.Window1"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="clr-namespace:WpfApplication1"
Title="Window1" Height="300" Width="300" Loaded="Window_Loaded">
<Canvas>
</Canvas>
</Window>
C#:
using System.Windows;
using System.IO;
using System.Xml;
using System.Windows.Controls;
namespace WpfApplication1
{
/// <summary>
/// Interaction logic for Window1.xaml
/// </summary>
public partial class Window1 : Window
{
public Window1()
{
InitializeComponent();
}
private void Window_Loaded(object sender, RoutedEventArgs e)
{
double dWidth = -1;
double dHeight = -1;
FrameworkElement pnlClient = this.Content as FrameworkElement;
if (pnlClient != null)
{
dWidth = pnlClient.ActualWidth;
dHeight = pnlClient.ActualHeight;
}
}
}
}
答案 3 :(得分:1)
我将Grid
与VerticalAlignment=Top
一起使用。结果,不幸的是,网格不再填充父窗口(这是它的默认行为,但是VerticalAligment属性破坏了它)。
我通过在网格周围放置一个空的Border
来解决它。该边框填充了窗口的全部内容,它的尺寸与wpf窗口具有的默认边框相同。
要使网格填充主窗口,我使用了绑定:
<Border BorderThickness="0" x:Name=Main>
<Grid VerticalAlignment="Top" Height="{Binding ElementName=Main, Path=ActualHeight}"> ...
</Grid>
</Border>