给定来自UISpy和Process Memory Dump的RuntimeId,如何找到隐藏UI元素的原因?

时间:2013-03-18 10:11:41

标签: windbg microsoft-ui-automation

有时,应用程序错误会使用Z-Index生成隐藏的UI控件,这意味着它位于其他UI元素之上。此隐藏窗格显示在屏幕的左上角,阻止用户从任何最大化窗口加载“文件”菜单。如果应用程序关闭,UI元素将消失。

使用UISpy,我能够捕获有关该元素的以下信息:

AutomationElement
  General Accessibility
    AccessKey:     ""
    AcceleratorKey:            ""
    IsKeyboardFocusable:               "True"
    LabeledBy:      "(null)"
    HelpText:        ""

  State
    IsEnabled:       "True"
    HasKeyboardFocus:    "False"

  Identification
    ClassName:    "WindowsForms10.Window.8.app.0.365bd83"
    ControlType:  "ControlType.Pane"
    Culture:            "(null)"
    AutomationId:              ""
    LocalizedControlType:               "pane"
    Name:              ""
    ProcessId:       "10968 (MyApplication)"
    RuntimeId:     "42 21628486"
    IsPassword:    "False"
    IsControlElement:       "True"
    IsContentElement:      "True"

  Visibility
    BoundingRectangle:   "(0, 0, 132, 38)"
    ClickablePoint:              "(null)"
    IsOffscreen:   "False"

ControlPatterns

我还在WinDbg中打开了应用程序的内存转储。如何找到引用RuntimeID "42 21628486"的UI元素的托管对象?或者我可以搜索具有特定宽度的对象?

我希望通过找到托管对象,它会给出隐藏窗口原因的一些线索。

1 个答案:

答案 0 :(得分:0)

还没弄清楚是否可以使用WinDbg但是能够附加Visual Studio的实例并且......

使用Inspect.exe能够找到一个hwnd(可能与RuntimeId相同但不确定):

How found:  Focus [o:0xFFFFFFFC,c:0x0]
    hwnd=0x0006219E 32bit class="WindowsForms10.Window.8.app.0.27e1210" style=0x96010000 ex=0x90088

触发断点并能够在立即窗口中使用以下命令找到控件:

System.Windows.Forms.Control.FromHandle(new IntPtr(401822))