pattern.Invoke()exception:由于对象的当前状态,操作无效

时间:2014-10-08 13:36:04

标签: c# ui-automation

我是c#的新手。 我正在寻找解决方案(可以从http://download.eset.com/special/ESETLogCollector.exe

下载要检查的应用

CODE:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Diagnostics;
using System.Threading;
using System.Windows.Automation;


namespace LogCollector
{
    class Program
    {
        static void Main(string[] args)
        {
            ProcessStartInfo proc = new ProcessStartInfo();
            proc.UseShellExecute = true;
            proc.WorkingDirectory = Environment.CurrentDirectory;
            proc.FileName = "C:\\robot\\ESETLogCollector.exe";
            proc.Verb = "runas";
            Process.Start(proc);
            System.Threading.Thread.Sleep(2000);
            Console.WriteLine("Ahoj");
            AutomationElement desktop = AutomationElement.RootElement;
            Condition cond = new PropertyCondition(AutomationElement.NameProperty, "ESET Log Collector");
            AutomationElement elc = desktop.FindFirst(TreeScope.Children, cond);
            Console.WriteLine(elc.Current.Name);
            String save_path = "";
            Condition cond1 = new PropertyCondition(AutomationElement.AutomationIdProperty, "1005");
            try
            {
                AutomationElement save_as = elc.FindFirst(TreeScope.Subtree, cond1);
                Console.WriteLine(save_as.Current.AutomationId);
                save_path = save_as.Current.Name;
            }
            catch (System.Exception e)
            {
                Console.WriteLine("EX: {0}", e.Message);
            }
            if (System.IO.File.Exists(save_path))
            {
                System.IO.File.Delete(save_path);
                Console.WriteLine(save_path);
            }

            Condition cond2 = new PropertyCondition(AutomationElement.AutomationIdProperty, "1002");
            AutomationElement collect = elc.FindFirst(TreeScope.Children, cond2);
            Console.WriteLine(collect.Current.Name);
            try
            {
                Object outObject;
                collect.TryGetCurrentPattern(InvokePattern.Pattern, out outObject);
                InvokePattern pattern = outObject as InvokePattern;
                pattern.Invoke();
            }
            catch (System.Exception e)
            {
                Console.WriteLine("EX: {0}", e.Message);
            }

            Console.ReadKey();
        }
    }
}

我仍然得到如果我想调用buttonclick是: 由于对象的当前统计数据,操作无效

我真的不知道这里发生了什么。有人可以帮我吗?

1 个答案:

答案 0 :(得分:6)

操作可能失败,因为在使用提升的权限运行ESET日志收集器时,您没有以管理员身份运行自动化应用程序。

UI Automation Security Overview描述了安全模型以及如何与运行在更高权限级别的进程通信(即,您需要一个带有包含特殊属性的清单文件的已签名应用程序)。