schangxiang@126.com
2025-11-04 f5ed29dc26c7cd952d56ec5721a2efc43cd25992
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
using Newtonsoft.Json.Linq;
using Sodao.FastSocket.Server.Messaging;
using System;
using BiosenSocketService.Exceptions;
using XImaging.Automation.Library.HxDriverLib;
using XImaging.Automation.Service.Interface;
using XImaging.Automation.Service.Instruction;
 
namespace XImaging.Automation.Service
{
 
    /// <summary>
    /// 驱动处理接收到的信息包
    /// </summary>
    class MessageDispatch: IMessageDispatch    
    {
 
        private static MessageDispatch m_Instance = null;
        private HxMessage m_taskMessage;
        private InstructionManager insManager;
 
        private MessageDispatch()
        {
            insManager = new InstructionManager();
        }
 
        public static MessageDispatch GetInstance()
        {
            if (m_Instance == null)
            {
                m_Instance = new MessageDispatch();
            }
            return m_Instance;
        }
 
        public void OnConnect(bool isConnect)
        {
            insManager.OnConnect(isConnect);
        }
        public void Parse(HxMessage message)
        {
            // 任务指令的确认帧反馈
            if (HxMessage.MESSAGE_TYPE_TASK ==message.MessageType|| HxMessage.MESSAGE_TYPE_QUERY == message.MessageType)
            {
                HxTcpHandler.ReplyAckMessage(message);   // 返回确认帧
                LogConstant.logger.Print(string.Format("已收到{0}指令,发送确认帧", message.Method));
            }
 
            // 根据指令类型进行处理
            switch(message.MessageType)
            {
                case HxInstruction.INSTYPE_Task:     // 任务指令类型,有执行时间,需要异步执行
                case HxInstruction.INSTYPE_Query:
                    try
                    {
                        TaskInstruction tIns = new TaskInstruction(message);
                        insManager.Add(tIns);
                    }
                    catch (TaskUncompletedException tuex)
                    {
                        LogConstant.logger.Print(tuex.Message);
                        HxTcpHandler.ReplyFailedMessage(message, ResponseMessagePackage.NullData, tuex.ErrCode, tuex.Message); 
                    }
                    catch (UndefinedInstructionException uiex)
                    {
                        LogConstant.logger.Print(uiex.Message);
                        HxTcpHandler.ReplyFailedMessage(message,ResponseMessagePackage.NullData, uiex.ErrCode, uiex.Message);
                    }
                    catch (Exception ex)
                    {
                        LogConstant.logger.Print(ex.Message);
                        HxTcpHandler.ReplyFailedMessage(message, ResponseMessagePackage.NullData, "EC_UNKOWN", ex.Message);
                    }
 
                    break;
 
                /*case HxInstruction.INSTYPE_Query:     // 查询类指令,立即反馈
                    try
                    {
                        QueryInstruction qIns = new QueryInstruction(message);
                        insManager.Add(qIns);
                    }
                    catch (Exception ex)
                    {
                        LogConstant.logger.Print(ex.Message);
                        HxTcpHandler.ReplyFailedMessage(message, ResponseMessagePackage.NullData, "EC-00-000", ex.Message);
                    }
                    break;*/
 
                case HxInstruction.INSTYPE_Troubleshoot:
                    try
                    {
                        LogConstant.logger.Print(string.Format("收到针对错误{0}的错误处理", message.Method));
                        TroubleshootInstruction tsIns = new TroubleshootInstruction(message);
                        insManager.Add(tsIns);
                    }
                    catch (Exception ex)
                    {
                        LogConstant.logger.Print(ex.Message);
                        HxTcpHandler.ReplyFailedMessage(message, ResponseMessagePackage.NullData, "EC-00-000", ex.Message);
                    }
                    break;
            }
        }
    }
}