FrameworkElement.Height 属性

定义

获取或设置 FrameworkElement 的建议高度。

public:
 property double Height { double get(); void set(double value); };
double Height();

void Height(double value);
public double Height { get; set; }
var double = frameworkElement.height;
frameworkElement.height = double;
Public Property Height As Double
<frameworkElement Height="double"/>
-or-
<frameworkElement Height="Auto"/>
 

属性值

Double

double

对象的高度(以像素为单位)。 默认值为 NaN。 除特殊的 NaN 值外,此值必须等于或大于 0。

示例

此示例演示在运行时创建的 UI 元素的简单属性集,需要初始化其内容以及基本显示属性(如 Height、 WidthBackground)。 (Background 实际上是 一个 Control 属性,不是由 FrameworkElement.)

Button button2 = new Button();
button2.Height = 50;
button2.Width = 100;
button2.Background = new SolidColorBrush(Colors.Blue);
button2.Content = "Click Me";
Dim button2 As Button = New Button
button2.Height = 50
button2.Width = 100
button2.Background = New SolidColorBrush(Colors.Blue)
button2.Content = "Click Me"

注解

Height 是 FrameworkElement 上指定高度信息的三个可写属性之一。 另外两个是 MinHeightMaxHeight。 如果这些值之间存在冲突,则实际高度确定的应用顺序是,必须遵循第一个 MinHeight ,然后 是 MaxHeight,最后,如果它位于边界内,则为 Height。

一些 FrameworkElement 派生类型也派生自 Shape。 并非所有 Shape 类都使用 Height 或 Width 来指定其外观,而是使用可能定义一组点的特定属性。 在这种情况下,计算高度或 宽度 ,但通常不直接设置。

自定义类可能有类似的注意事项,其中类可能具有比 Height 或 Width 更有意义的属性来指定维度。 高度或 宽度 仍可用作成员,并且是可设置的。

设置 Height 或 Width 属性的对象几乎始终是另一个父级的子集合中的子对象,将 Height 或 Width 设置为值只是布局过程的建议值。 布局系统以及父类的特定布局逻辑将在布局过程中使用 值作为非绑定输入,并且可能必须剪裁、调整对象大小、调整容器大小,或这些行为的某些组合,这些行为跨越布局中的多个参与对象。 边距和填充也会影响可用大小。 有关详细信息,请参阅对齐、边距和填充

此属性的返回值始终与设置为它的任何值相同。 相比之下, ActualHeight 属性的值可能会有所不同。 由于布局拒绝了建议的大小,因此差异可能会静态发生,也可以是暂时发生的。 布局系统本身相对于属性系统的 Height 集异步工作,布局系统可能尚未处理大小调整属性更改。

不允许使用 Height 的负值。

此外,请勿将 Height 设置为明显大于任何可能视觉显示的最大大小的值。

“Auto”和 NaN

Height 和 Width 的默认值为“Auto”,由 NaN 表示。 在 XAML 标记中,可以使用字符串“Auto”将值设置为 NaN。

注意

在 C# 中,可以从 Double.NaN 获取 NaN

在 C++ 中,可以使用 宏或 std::numeric_limits<double>::quiet_NaN()获取 NaNNAN

请勿使用 == 运算符来测试 NaN。

在 C# 中,使用 Double.IsNaN () 测试 NaN。

在 C++ 中,使用 isnan () 测试 NaN。

布局系统将“Auto”值解释为通常意味着对象的大小应调整为布局中的可用大小,而不是特定的像素值。

适用于

另请参阅