如何知道WPF用户控件已被选中并处于显示状态

本文关键字:于显示 显示 状态 用户 WPF 何知道 控件 | 更新日期: 2023-09-27 18:06:44

我有一个用户控件在选项卡控件下显示为多个实例

<TabControl x:Name="tabControl"  HorizontalAlignment="Left" Height="616" Margin="0,20,0,20" VerticalAlignment="Top" Width="1282" Grid.ColumnSpan="2">
                <TabItem Header=" OPHistorianCutter " Padding="0">
                        <OP:Historian x:Name="OPHistorianCutter1" />
                </TabItem>
                <TabItem Header=" OPHistorianCutter " Padding="0">
                        <OP:Historian x:Name="OPHistorianCutter2" />
                </TabItem>
                <TabItem Header=" OPHistorianCutter " Padding="0">
                        <OP:Historian x:Name="OPHistorianCutter3" />
                </TabItem>
            </TabControl>

我的问题:

  1. 是否有任何事件我可以在' ophistory '用户控件中使用,当用户控件被选项卡显示时执行?

  2. 是否有任何属性告诉我用户控件当前正在显示(在选项卡控件下被选中)。我试过"ophistoran1"。isFocused',但似乎总是假的

如何知道WPF用户控件已被选中并处于显示状态

1。你可以使用tabControl的SelectionChanged事件来知道哪个tabItem(和UserControl)被显示。

你可以使用UserControl的Loaded事件来知道它何时被激活。读这。

1。您可以使用tabControl的SelectionChanged事件来知道显示的是哪个tabItem。

   SelectionChanged="TabControl_OnSelectionChanged"
   private void TabControl_OnSelectionChanged(object sender, SelectionChangedEventArgs e)
   {
       throw new NotImplementedException();
   }

2。您可以使用SelectedIndex来获得选中的选项卡:

tabControl.SelectedIndex

或与tabItem

tabItem.IsSelected

您可以通过从父控件获取属性来在UserControl上报告这些属性:

    public bool IsSelected
    {
        get
        {
            var tabitem = Parent as TabItem;
            return tabitem != null && tabitem.IsSelected;
        }
    }

编辑

你可以使用isVisible属性和相关的事件:

 <TabControl>
        <TabItem Header="1">
        </TabItem>
        <TabItem Header="2">
            <local:UserControl1 IsVisibleChanged="UIElement_OnIsVisibleChanged"></local:UserControl1>
        </TabItem>
        <TabItem></TabItem>
    </TabControl>

   private void UIElement_OnIsVisibleChanged(object sender, DependencyPropertyChangedEventArgs e)
   {
       var uc = sender as UserControl1;
   }

谢谢你的回复,但我已经找到了一个解决方案。必须使用visualtreehelper来查找父容器,并查看它是否在可视范围内。

public bool IsUserVisible
        {
            get
            {
                UIElement element = (UIElement)this;
                if (!element.IsVisible)
                    return false;
                var container = VisualTreeHelper.GetParent(element) as FrameworkElement;
                if (container == null) throw new ArgumentNullException("container");
                Rect bounds = element.TransformToAncestor(container).TransformBounds(new Rect(0.0, 0.0, element.RenderSize.Width, element.RenderSize.Height));
                Rect rect = new Rect(0.0, 0.0, container.ActualWidth, container.ActualHeight);
                return rect.IntersectsWith(bounds);
            }
        }