(8)监控微信进程运行状态-微信UI自动化(.Net+C#)

整理 | 小耕家的喵大仙

出品 | CSDN(ID:lichao19897314)

Q Q | 978124155

往期知识回顾: 

​​​​​​​​​​​​​​(1)C#开启探索微信自动化之路-微信UI自动化

(2)C#创建微信窗体自动化实例-微信UI自动化

(3)C#针对系统热键管理-微信UI自动化

(4)C#采集微信通讯录和联系人-微信UI自动化

(5)C#实现针对微信窗体鼠标静默点击-微信UI自动化

(6)C#搜索微信通讯录联系人-微信UI自动化

(7)C#实现微信消息群发-微信UI自动化

(8)C#监控微信进程运行状态-微信UI自动化

(9)C#监控微信网络连接状态-微信UI自动化

(11)C#实现微信窗体尺寸跟随调整-微信UI自动化

(12)C#采集微信聊天记录及历史消息-微信UI自动化

(13)C#实现自动回复微信消息-微信UI自动化

(14)C#针对微信界面元素截图操作-微信UI自动化

(15)C#实现对微信窗体的行为管控-微信UI自动化

(16)C#实现微信多开-微信UI自动化

(17)C#实现微信聊天文件接收及下载-微信UI自动化

👆 以上文章是以往对使用自动化技术操作微信的一些文章及案例!!!!

微信定时发送消息

(1)自动化程序在运行过程中应为依赖的主程序是微信,所以要对微信进程运行状态进行监控,如果发现微信处于运行状态的情况则自动化程序可以执行对应操作,微信应为人为或者意外导致关闭的情况则需要自动化程序马上响应做出对应的处理。

(2)实现思路,开启一个线程定时监控微信的窗体是否存在则可以实现

实现过程

首先定义一个WIN32 API的调用类,用来查找窗体。


   /// <summary>
    /// 发现窗口
    /// </summary>
    public class Win32_Find_Window
    {
        [DllImport("user32.dll", EntryPoint = "FindWindow")]
        private extern static IntPtr FindWindow(string lpClassName, string lpWindowName);
        public static IntPtr Do(string className, string windowName)
        {
            return FindWindow(className, windowName);
        }
    }

定义好一个查找微信窗体的调用类


    public class WXWin32
    {
        private static IntPtr currentWeixin = IntPtr.Zero;
        public static IntPtr GetWeiXin()
        {
          // if (currentWeixin == IntPtr.Zero)
                currentWeixin = Win32_Find_Window.Do("WeChatMainWndForPC", "微信");
            return currentWeixin;
        }
    }

定义一个监控的基类,因为后续很多监控都需要


 public class BaseMonitor : IMonitor
    {
        public BaseMonitor() {
            MonitorStatus = MonitorStatus.Stop;
        }
        public MonitorStatus MonitorStatus { get; protected set; }

        public event EventHandler<EventArgs> MonitorStop;

        public virtual void Break()
        {
            MonitorStatus = MonitorStatus.Stoping;
        }

        public virtual void Monitor()
        {

        }

        protected void ExecuteMonitorStop()
        {
            MonitorStatus = MonitorStatus.Stop;
            if (MonitorStop != null)
            {
                MonitorStop(this, EventArgs.Empty);
            }
        }
    }

    public enum MonitorStatus
    {
        Monitoring = 0,
        Stoping = 1,
        Stop = 2
    }

定义监控类



namespace WpfApp1.UIAuto.Monitor
{
    public class UI_WX_Process_Monitor : BaseMonitor
    {
        public event EventHandler<ProcessEventArgs> ProcessEvent;

        public ProcessStatus Status { get; private set; } = ProcessStatus.UnKnow;

        public override void Monitor()
        {
            if (MonitorStatus == MonitorStatus.Monitoring)
                return;
            SystemLog.Info("启动微信是否打开监听");

            MonitorStatus = MonitorStatus.Monitoring;

            Thread th = new Thread(new ThreadStart(() =>
            {
                while (MonitorStatus == MonitorStatus.Monitoring)
                {
                    if (WXWin32.GetWeiXin() != IntPtr.Zero)
                    {
                        DoProcess(ProcessStatus.Run);
                    }
                    else 
                    {
                        DoProcess(ProcessStatus.Close);
                    }
                    Thread.Sleep(1000);
                }
                ExecuteMonitorStop();
            }));
            th.Start();
        }

        private void DoProcess(ProcessStatus status)
        {
            if (Status == status)
                return;
            Status = status;

            if (ProcessEvent != null)
            {
                ProcessEvent(this, new ProcessEventArgs { Status = status });
            }
        }

        public override void Break()
        {
            base.Break();
            SystemLog.Info("关闭微信是否打开监听");
        }
    }

    public class ProcessEventArgs : EventArgs
    {
        public ProcessStatus Status { get; set; }
    }

    public enum ProcessStatus
    {
        UnKnow = 0,
        Run = 1,
        Close= 2
    }
}

调用


   public MainWindow()
        {
           

             UI_WX_Process_Monitor process = new UI_WX_Process_Monitor();
            process.ProcessEvent += Process_ProcessEvent;
 process.Monitor();
        } 
 private void Process_ProcessEvent(object sender, ProcessEventArgs e)
        {
            if (e.Status == ProcessStatus.Close)
            {
               //你的具体业务代码
            }

        }

上一篇(7)微信UI自动化-自动发送消息给指定联系人(C#)(.Net)

下一篇(9)微信UI自动化-监控微信网络状态(C#)

因为文章所表达的意思可能无法满足每一位阅读需求,需要源码或者支持请联系作者QQ 978124155

好的,我可以给你一些指导。 首先,你需要使用ASP.NETC#来创建一个Web应用程序。你可以使用Visual Studio来完成这个任务。在创建项目时,选择ASP.NET Web应用程序模板。 接下来,你需要安装QrCode.Net和ZXing.Net NuGet包。这些包将帮助你生成和解析二维码。 在你的页面中,你可以使用QrCode.Net来生成二维码。你可以使用以下代码: ```csharp using QrCodeNet.Encoding; using QrCodeNet.Encoding.Windows.Render; using System.Drawing; // Generate QR code var encoder = new QrEncoder(ErrorCorrectionLevel.M); var code = encoder.Encode("Hello World!"); var renderer = new GraphicsRenderer(new FixedModuleSize(5, QuietZoneModules.Two), Brushes.Black, Brushes.White); var stream = new MemoryStream(); renderer.WriteToStream(code.Matrix, ImageFormat.Png, stream); stream.Position = 0; // Display QR code on page var img = new System.Web.UI.WebControls.Image(); img.ImageUrl = "data:image/png;base64," + Convert.ToBase64String(stream.ToArray()); ``` 在这个例子中,我们使用了QrCode.Net来生成一个包含“Hello World!”文本的二维码,并将其显示在一个ASP.NET页面上。 接下来,你需要使用ZXing.Net来解析二维码。你可以使用以下代码: ```csharp using ZXing; // Decode QR code var reader = new BarcodeReader(); var result = reader.Decode(new Bitmap(qrCodeImage)); // Display result on page if (result != null) { Response.Write("QR code text: " + result.Text); } else { Response.Write("Failed to decode QR code."); } ``` 在这个例子中,我们使用ZXing.Net来解析一个二维码图像,并在页面上显示结果。 最后,你需要将这些代码整合到一个页面中,并使用ASP.NET的事件模型来处理二维码扫描的结果。 希望这些指导可以帮助你完成这个项目!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小耕家的喵大仙

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值