如何使用UI自动化检查菜单项?

时间:2013-10-10 13:52:59

标签: c# ui-automation specflow

我正在努力实施必须检查菜单项内容的操作。菜单项包含标题+快捷键(帮助F1)

screen1

但是我遇到了检查菜单中是否有快捷键(F1)的问题。 AutomationElement不包含有关此密钥的任何信息。 AccessKey和AcceleratorKey为空。

enter image description here

如何通过UI自动化访问accessKey?感谢。

1 个答案:

答案 0 :(得分:1)

ToolStrip类菜单的默认实现仅支持助记符。例如,如果您将菜单声明为"&help"而不是"help",则UI自动化应显示此菜单项"Alt+h"作为访问键。此实现不适用于其他类型的快捷方式,如Fx,CTRL等等。

如果您拥有经过检查的应用程序,则可以提供自定义访问密钥字符串。例如,这是一个派生自ToolStripMenuItem的示例类,它返回ShortcutKeyDisplayString中设置的内容(默认情况下,即使定义了ShortcutKeys,它也为空)。

您可以使用它:

MyItem item = new MyItem("Help");
item.ShortcutKeys = Keys.F1;
item.ShortcutKeyDisplayString = "F1";
fileToolStripMenuItem.DropDownItems.Add(item);

以下是示例类:

public class MyItem : ToolStripMenuItem
{
    public MyItem(string text)
        : base(text)
    {
    }

    protected override AccessibleObject CreateAccessibilityInstance()
    {
        return new MyAccessibleItem(this);
    }

    // unfortunately we can't just derive from ToolStripMenuItemAccessibleObject
    // which is stupidly marked as internal...
    private class MyAccessibleItem : ToolStripDropDownItemAccessibleObject
    {
        public MyAccessibleItem(ToolStripMenuItem owner)
            :base(owner)
        {
            Owner = owner;
        }

        public ToolStripMenuItem Owner { get; private set; } 

        public override AccessibleStates State
        {
            get
            {
                if (!Owner.Enabled)
                    return base.State;

                AccessibleStates state = base.State;
                if ((state & AccessibleStates.Pressed) == AccessibleStates.Pressed)
                {
                    state &= ~AccessibleStates.Pressed;
                }

                if (Owner.Checked)
                {
                    state |= AccessibleStates.Checked;
                }
                return state;
            }
        }

        public override string KeyboardShortcut
        {
            get
            {
                return Owner.ShortcutKeyDisplayString;
            }
        }
    }
}