使用WPF的PopUp类实现父子窗口关联

一、POPUP窗口可以显示在屏幕任何地方,它们一般没有父窗口,但是如果明确调用SetParent,这类窗口也可以有父窗口。

        [DllImport("user32.dll", EntryPoint = "SetParent")]
        public static extern int SetParent(IntPtr hWndChild, IntPtr hWndNewParent);

这样设置之后,popup窗口会做为子窗口嵌入进父窗口内。从效果上来看,几乎不再有Popup的特性(如:触及屏幕边界时,也不会保持在屏幕中显示的状态)。

二、POPUP窗口也可以设置所有者窗口(owner),这时的POPUP窗口会保持其特有的属性。同是也会跟随其所有者窗口的Z序显示。

[DllImport("user32.dll", SetLastError = true)]
static extern int SetWindowLong(IntPtr hWnd, int nIndex, IntPtr dwNewLong);

WindowInteropHelper helper = new WindowInteropHelper(this.hostWindow);
SetWindowLong(nowHwnd, -8, helper.Handle.ToInt32());

因为POPUP的默认属性是Topmost的,如果因为需要将其设置为非Topmost的状态,则很容易出现popup窗口被其它窗口遮挡的问题。原因就是因为popup窗口并没有所有者窗口,这时,其Z序很容易被其它窗口压到底下。如果在设置非Topmost 属性的同时,设置其所有者窗口,则可以解决这样的问题。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
WPF中的Popup是一种特殊的控件,它可以显示在其他控件上方,并且可以在需要时弹出和隐藏。Popup的样式可以通过重写来自定义。 首先,在WPF中定义Popup的样式需要使用XAML语言。可以在Window或者Page的资源中定义样式,也可以在单独的资源文件中定义。 我们可以通过为Popup定义一个控制模板来重写其样式。控制模板是一种描述控件外观和行为的XAML标记。 以下是一个简单的示例,展示了如何重写Popup的样式: ```xaml <Style TargetType="Popup"> <Setter Property="Template"> <Setter.Value> <ControlTemplate TargetType="Popup"> <Grid Background="Transparent"> <!-- 在此处定义你想要的Popup的样式 --> <Border Background="White" BorderBrush="Gray" BorderThickness="1" CornerRadius="5"> <ContentPresenter /> </Border> </Grid> </ControlTemplate> </Setter.Value> </Setter> </Style> ``` 在这个示例中,我们重写了Popup的样式,使其在显示时以圆角灰色边框包裹内容。可以根据需要自定义Border的属性,如背景色、边框颜色、边框粗细等。 当我们使用自定义样式的Popup控件时,只需要将该样式应用到需要的控件上即可: ```xaml <Button Content="点击弹出Popup"> <Button.Resources> <Style TargetType="Popup" BasedOn="{StaticResource {x:Type Popup}}"> <!-- 在这里进一步修改样式,如果有需要 --> </Style> </Button.Resources> <Button.Triggers> <EventTrigger RoutedEvent="Button.Click"> <BeginStoryboard> <Storyboard> <BooleanAnimationUsingKeyFrames Storyboard.TargetProperty="IsOpen"> <DiscreteBooleanKeyFrame KeyTime="0" Value="True" /> </BooleanAnimationUsingKeyFrames> </Storyboard> </BeginStoryboard> </EventTrigger> </Button.Triggers> <Button.ContentTemplate> <DataTemplate> <Popup PlacementTarget="{Binding RelativeSource={RelativeSource FindAncestor, AncestorType=Button}}" Placement="Bottom"> <!-- 在这里放置Popup的内容 --> <TextBlock Text="这是一个Popup" Margin="5" /> </Popup> </DataTemplate> </Button.ContentTemplate> </Button> ``` 通过上述方式,我们可以重写WPF中的Popup样式,实现更加个性化的外观效果。同时,通过定义控制模板,我们还可以进一步自定义Popup的布局和动画效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值