| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610 | using System;using System.Collections.Generic;using System.Collections.ObjectModel;using System.Data;using System.Diagnostics;using System.Linq;using Aitex.Core.RT.Log;using Aitex.Core.RT.SCCore;using DocumentFormat.OpenXml.Drawing;using ExtendedGrid.Microsoft.Windows.Controls;using MECF.Framework.Common.DataCenter;using MECF.Framework.Common.Equipment;using MECF.Framework.Common.Utilities;using MECF.Framework.UI.Client.CenterViews.DataLogs.ProcessHistory;using MECF.Framework.UI.Client.ClientBase.Tree;using OpenSEMI.ClientBase.ServiceProvider;namespace MECF.Framework.UI.Client.CenterViews.Operations.RealTime{    public class RealtimeProvider : IProvider    {        ObservableCollection<ParameterNode> _rootNode = new ObservableCollection<ParameterNode>();        Dictionary<string, ParameterNode> _indexer = new Dictionary<string, ParameterNode>();        public void Clear()        {            _indexer.Clear();            _rootNode.Clear();        }        /// <summary>        /// 使用字符串队列创建树结构的分支。        /// </summary>        /// <param name="branchString"></param>        /// <param name="node"></param>        private static TreeNode CreateTreeBranch(Queue<string> branchString, TreeNode node)        {            var rootNode = node;            while (true)            {                if (branchString.Count <= 0)                    return rootNode;                var name = branchString.Dequeue();                if (node == null)                {                    // 根节点                    node = new TreeNode(name);                    rootNode = node;                }                else                {                    if (node.Name == name)                        continue;                    // 向ChildNode插入                    var subNode = node.ChildNodes.FirstOrDefault(x => x.Name == name);                    if (subNode == null)                    {                        subNode = new TreeNode(name);                        node.ChildNodes.Add(subNode);                    }                    node = subNode;                }            }        }        public void Create()        {        }        public ObservableCollection<string> GetUserDefineParameters()        {            var typedContents = ((string)QueryDataClient.Instance.Service.GetTypedConfigContent("UserDefine", ""));            ObservableCollection<string> dataList = new ObservableCollection<string>();            if (typedContents != null)            {                var contentList = typedContents.Split(',').ToList();                contentList.ForEach(x =>                {                    if (!string.IsNullOrEmpty(x)) dataList.Add($"{x}");                });            }            return dataList;        }        public Dictionary<string, string> GetSystemDeviceNameDict()        {            return new Dictionary<string, string>()            {                {ModuleName.CarrierRobot.ToString(),ModuleName.Robot.ToString() },                {ModuleName.WaferRobot.ToString(),ModuleName.Robot.ToString() },                {ModuleName.FIMS1.ToString(),ModuleName.FIMS1.ToString() },                {ModuleName.FIMS2.ToString(),ModuleName.FIMS2.ToString() },                {ModuleName.LP1.ToString(),ModuleName.LP1.ToString() },                {ModuleName.LP2.ToString(),ModuleName.LP2.ToString() },                {ModuleName.LP3.ToString(),ModuleName.LP3.ToString() },                {ModuleName.LP4.ToString(),ModuleName.LP4.ToString() },                {ModuleName.Stocker1.ToString(),ModuleName.Stocker1.ToString() },                {ModuleName.Stocker2.ToString(),ModuleName.Stocker2.ToString() },                {ModuleName.Stocker3.ToString(),ModuleName.Stocker3.ToString() },                {ModuleName.Stocker4.ToString(),ModuleName.Stocker4.ToString() },                {ModuleName.Stocker5.ToString(),ModuleName.Stocker5.ToString() },                {ModuleName.Stocker6.ToString(),ModuleName.Stocker6.ToString() },                {ModuleName.Stocker7.ToString(),ModuleName.Stocker7.ToString() },                {ModuleName.Stocker8.ToString(),ModuleName.Stocker8.ToString() },                {ModuleName.Stocker9.ToString(),ModuleName.Stocker9.ToString() },                {ModuleName.Stocker10.ToString(),ModuleName.Stocker10.ToString() },                {ModuleName.Stocker11.ToString(),ModuleName.Stocker11.ToString() },                {ModuleName.Stocker12.ToString(),ModuleName.Stocker12.ToString() },                {ModuleName.Stocker13.ToString(),ModuleName.Stocker13.ToString() },                {ModuleName.Stocker14.ToString(),ModuleName.Stocker14.ToString() },                {ModuleName.Stocker15.ToString(),ModuleName.Stocker15.ToString() },                {ModuleName.Stocker16.ToString(),ModuleName.Stocker16.ToString() },                {ModuleName.Stocker17.ToString(),ModuleName.Stocker17.ToString() },                {ModuleName.Stocker18.ToString(),ModuleName.Stocker18.ToString() },            };        }        /// <summary>        /// 筛选数据库字段        /// </summary>        /// <param name="dataList"></param>        /// <returns></returns>        private Dictionary<string, string> FilterNumericDataList(List<string> dataList, Dictionary<string, string> displayXmlDict)        {            //这里包含了项目中注册到数据库中的所有字段,需要从中筛选出来有效字段并归类            Dictionary<string, string> result = new Dictionary<string, string>();            var effectiveDataList = dataList.Where(a => a.Split('.').Count() > 1);            var pm1DataList = effectiveDataList.Where(a => a.StartsWith(ModuleName.PM1.ToString()) && !displayXmlDict.Keys.Contains(a)).ToDictionary(a => a, a => a);            var systemDataList = effectiveDataList.Where(a => a.StartsWith(ModuleName.System.ToString()) && !displayXmlDict.Keys.Contains(a)).ToDictionary(a => a, a => a);            result.AddRange(pm1DataList);            result.AddRange(systemDataList);            var systemDeviceNameDict = GetSystemDeviceNameDict();            foreach (var item in systemDeviceNameDict)            {                var data = effectiveDataList.Where(a => (a.StartsWith(item.Key))).ToDictionary(a => a, a => $"{item.Value}.{a}");                result.AddRange(data);            }                   return result;        }        /// <summary>        /// 获取指定日期数据库PM/System table 列        /// </summary>        /// <param name="dbTableName"></param>        /// <returns></returns>        public List<string> GetDBCol(string dbTableName)        {            var columnsql = $"select column_name from information_schema.columns where table_name = '{dbTableName}'";            var columnTable = QueryDataClient.Instance.Service.QueryData(columnsql);            return columnTable.Rows.Cast<DataRow>().Select(x => x.ItemArray[0].ToString()).ToList();        }        /// <summary>        /// 获取DataHistory 左侧树字典(既包含配置文件字段,也包含PM/System表字段)        /// </summary>        /// <returns></returns>        public Dictionary<string, string> GetTreeNameDict()        {            Dictionary<string, string> displayDic = QueryDataClient.Instance.Service.GetData("System.Display") as Dictionary<string, string>;            List<string> dataList = (List<string>)QueryDataClient.Instance.Service.GetConfig("System.NumericDataList");            var dataListDict = FilterNumericDataList(dataList, displayDic);            displayDic.AddRange(dataListDict);            return displayDic;        }        /// <summary>        /// 获取ProcessHistory 左侧树结构(不包含PM/System,只根据配置文件字段生成)        /// </summary>        /// <param name="processDetailDisplayDic"></param>        /// <param name="isSelected"></param>        /// <returns></returns>        public ObservableCollection<ParameterNode> GetParameters(out Dictionary<string, string> processDetailDisplayDic, bool isSelected = false)        {            processDetailDisplayDic = new Dictionary<string, string>();            ObservableCollection<ParameterNode> rootNode = new ObservableCollection<ParameterNode>();            try            {                Dictionary<string, string> displayDic = QueryDataClient.Instance.Service.GetData("System.ProcessDetailDisplay") as Dictionary<string, string>;                if (displayDic == null)                    return rootNode;                List<string> dataList = new List<string>();                foreach (var itemDisplay in displayDic)                {                    string[] keyItems = itemDisplay.Key.Split('.');                    string[] valueItems = itemDisplay.Value.Split('.');                    if (keyItems != null)                    {                        if (keyItems.Length == 2)                        {                            var key = $"{valueItems[1]}";                            var keyValue = itemDisplay.Value;                            if (!processDetailDisplayDic.ContainsKey(key))                            {                                processDetailDisplayDic.Add(key, keyValue);                            }                        }                        else if (keyItems.Length == 3)                        {                            var key = $"{valueItems[1]} {valueItems[2]}";                            var keyValue = itemDisplay.Value;                            if (!processDetailDisplayDic.ContainsKey(key))                            {                                processDetailDisplayDic.Add(key, keyValue);                            }                        }                        dataList.Add(itemDisplay.Value);                    }                }                Dictionary<string, ParameterNode> indexer = new Dictionary<string, ParameterNode>();                foreach (string dataName in dataList)                {                    string[] nodeName = dataName.Split('.');                    ParameterNode parentNode = null;                    string pathName = "";                    for (int i = 0; i < nodeName.Length; i++)                    {                        pathName = (i == 0 || i == 1) ? nodeName[i] : (pathName + " " + nodeName[i]);                        if (!indexer.ContainsKey(pathName))                        {                            indexer[pathName] = new ParameterNode() { Name = pathName, ChildNodes = new ObservableCollection<ParameterNode>(), ParentNode = parentNode };                            if (parentNode == null)                            {                                rootNode.Add(indexer[pathName]);                            }                            else                            {                                parentNode.ChildNodes.Add(indexer[pathName]);                            }                        }                        parentNode = indexer[pathName];                    }                }                SortParameterNode(rootNode,                    new Dictionary<string, int>() {                    { "Heater",0},                    { "MFC",1},                    { "APC",2},                    { "Boat",3},                    { "Valve",4} },                    isSelected);            }            catch (Exception ex)            {                LOG.Write(ex);            }            return rootNode;        }        public List<TreeNode> GetTreeNodeParameters()        {            var root = new List<TreeNode>();            try            {                Dictionary<string, string> displayDic = QueryDataClient.Instance.Service.GetData("System.Display") as Dictionary<string, string>;                List<string> dataList = (List<string>)QueryDataClient.Instance.Service.GetConfig("System.NumericDataList");                List<SCConfigItem> setUplist = null;                if (QueryDataClient.Instance.Service.GetConfigItemList().Where(x => x.Path == "System.SetUp") != null)                    setUplist = QueryDataClient.Instance.Service.GetConfigItemList()                        .Where(x => x.Path == "System.SetUp").ToList();                var typedContents = ((string)QueryDataClient.Instance.Service.GetTypedConfigContent("UserDefine", ""));                if (string.IsNullOrEmpty(typedContents))                {                    dataList.Add($"UserDefine");                }                else                {                    var contentList = typedContents.Split(',').ToList();                    contentList.ForEach(x =>                    {                        if (!string.IsNullOrEmpty(x)) dataList.Add($"UserDefine.{x}");                    });                }                dataList.Sort();                foreach (var dataName in dataList)                {                    var nodeName = new Queue<string>(dataName.Split('.'));                    if (nodeName.Count <= 0)                        continue;                    // 开始创建Tree分支                    var rootNode = root.FirstOrDefault(x => x.Name == nodeName.Peek());                    var node = CreateTreeBranch(nodeName, rootNode);                    if (rootNode == null)                    {                        root.Add(node);                    }                }                root.Sort(new NameComparer());                if (displayDic != null)                {                    foreach (TreeNode rootNodes in root)                    {                        foreach (var terminalNode in rootNodes.Flatten(true))                        {                            terminalNode.DisplayName = displayDic.ContainsKey($"{rootNodes.Name}.{terminalNode.FullName}") ? displayDic[$"{rootNodes.Name}.{terminalNode.FullName}"] : terminalNode.FullName;                        }                    }                }                foreach (var rootNodes in root)                {                    var childNode = rootNodes.ChildNodes.ToList();                    childNode.Sort(new NameComparer());                    for (int i = 0; i < childNode.Count; i++)                    {                        rootNodes.ChildNodes.Move(rootNodes.ChildNodes.IndexOf(childNode[i]), i);                    }                }            }            catch (Exception ex)            {                LOG.Write(ex);            }            return root;        }        /// <summary>        /// 获取DataHistory 左侧树结构(既包含配置文件字段,也包含PM/System表字段)        /// </summary>        /// <returns></returns>        public List<TreeNode> GetTreeNodeParameters1()        {            var root = new List<TreeNode>();            try            {                var displayDic = GetTreeNameDict();                              foreach (var dataName in displayDic.Values)                {                    var nodeName = new Queue<string>(dataName.Split('.'));                    if (nodeName.Count <= 0)                        continue;                    // 开始创建Tree分支                    var rootNode = root.FirstOrDefault(x => x.Name == nodeName.Peek());                    var node = CreateTreeBranch(nodeName, rootNode);                    if (rootNode == null)                    {                        root.Add(node);                    }                }                            SortParameterNode(root, "PM1", 0);                SortParameterNode(root, "System", 1);                SortParameterNode(root, "Heater", 2);                SortParameterNode(root, "MFC", 3);                SortParameterNode(root, "APC", 4);                SortParameterNode(root, "Boat", 5);                SortParameterNode(root, "Valve", 6);                           }            catch (Exception ex)            {                LOG.Write(ex);            }            return root;        }        #region Sort 排序              void SortParameterNode(List<TreeNode> rootNode, string Name, int Index)        {            if (Index >= rootNode.Count)            {                return;            }            if (rootNode[Index].Name != Name)            {                for (int i = 0; i < rootNode.Count; i++)                {                    if (rootNode[i].Name == Name)                    {                        TreeNode node = rootNode[i];                        rootNode.RemoveAt(i);                        rootNode.Insert(Index, node);                    }                }            }        }        void SortParameterNode(ObservableCollection<ParameterNode> rootNode, Dictionary<string, int> sortDict, bool isSelectd = false)        {            foreach (var item in sortDict)            {                SortParameterNode(rootNode, item.Key, item.Value, isSelectd);            }        }        void SortParameterNode(ObservableCollection<ParameterNode> rootNode, string Name, int Index, bool isSelectd = false)        {            if (Index >= rootNode.Count)            {                return;            }            if (rootNode[Index].Name != Name)            {                for (int i = 0; i < rootNode.Count; i++)                {                    rootNode[i].Selected = isSelectd;                    if (rootNode[i].Name == Name)                    {                        ParameterNode node = rootNode[i];                        rootNode.RemoveAt(i);                        rootNode.Insert(Index, node);                    }                }            }        }        #endregion        public ObservableCollection<ParameterNode> GetParameterNodeParameters()        {            try            {                List<string> dataList =                    (List<string>)QueryDataClient.Instance.Service.GetConfig("System.NumericDataList");                var typedContents = ((string)QueryDataClient.Instance.Service.GetTypedConfigContent("UserDefine", ""));                for (int i = 0; i < dataList.Count; i++)                {                    if (dataList[i].StartsWith("SMIF"))                        dataList[i] = $"SMIFs.{dataList[i]}";                    if (dataList[i].StartsWith("Stocker"))                        dataList[i] = $"Stockers.{dataList[i]}";                    if (dataList[i].StartsWith("Stage"))                        dataList[i] = $"Stages.{dataList[i]}";                    dataList[i] = dataList[i].Replace("PM1", "Tube");                }                if (string.IsNullOrEmpty(typedContents))                {                    dataList.Add($"UserDefine");                }                else                {                    var contentList = typedContents.Split(',').ToList();                    contentList.ForEach(x =>                    {                        if (!string.IsNullOrEmpty(x)) dataList.Add($"UserDefine.{x}");                    });                }                dataList.Sort();                //List<string> removeList = _indexer.Keys.ToList();                foreach (string dataName in dataList)                {                    string[] nodeName = dataName.Split('.');                    ParameterNode parentNode = null;                    string pathName = "";                    for (int i = 0; i < nodeName.Length; i++)                    {                        pathName = (i == 0) ? nodeName[i] : (pathName + "." + nodeName[i]);                        //removeList.Remove(pathName);                        if (!_indexer.ContainsKey(pathName))                        {                            _indexer[pathName] = new ParameterNode()                            {                                Name = pathName.Replace("UserDefine.", "").Replace("SMIFs.", "").Replace("Stages.", "")                                    .Replace("Stockers.", ""),                                ChildNodes = new ObservableCollection<ParameterNode>(),                                ParentNode = parentNode                            };                            if (parentNode == null)                            {                                _rootNode.Add(_indexer[pathName]);                            }                            else                            {                                parentNode.ChildNodes.Add(_indexer[pathName]);                            }                        }                        parentNode = _indexer[pathName];                        //removeList.Remove(pathName);                    }                }                //foreach (var key in removeList)                //{                //    if (_indexer[key].ParentNode == null)                //        _rootNode.Remove(_indexer[key]);                //    else                //    {                //        _indexer[key].ParentNode.ChildNodes.Remove(_indexer[key]);                //    }                //}                return _rootNode;            }            catch (Exception ex)            {                LOG.Write(ex);            }            #region Test code            ObservableCollection<ParameterNode> result = new ObservableCollection<ParameterNode>();            ParameterNode node1 = new ParameterNode() { Name = "Para Node 1", Selected = false, ChildNodes = new ObservableCollection<ParameterNode>() };            ParameterNode node2 = new ParameterNode() { Name = "Para Node 2", Selected = false, ChildNodes = new ObservableCollection<ParameterNode>() };            ParameterNode node3 = new ParameterNode() { Name = "Para Node 3", Selected = false, ChildNodes = new ObservableCollection<ParameterNode>() };            for (int i = 0; i < 5; i++)            {                ParameterNode node = new ParameterNode() { Name = node1.Name + "_" + i.ToString(), Selected = false, ChildNodes = new ObservableCollection<ParameterNode>() };                node1.ChildNodes.Add(node);            }            for (int i = 0; i < 3; i++)            {                ParameterNode node = new ParameterNode() { Name = node2.Name + "_" + i.ToString(), Selected = false, ChildNodes = new ObservableCollection<ParameterNode>() };                node2.ChildNodes.Add(node);            }            for (int i = 0; i < 4; i++)            {                ParameterNode node = new ParameterNode() { Name = node3.Name + "_" + i.ToString(), Selected = false, ChildNodes = new ObservableCollection<ParameterNode>() };                node3.ChildNodes.Add(node);            }            result.Add(node1);            result.Add(node2);            result.Add(node3);            return result;            #endregion        }    }    public class NameComparer : IComparer<TreeNode>    {        public int Compare(TreeNode x, TreeNode y)        {            if (x == null || y == null)                throw new ArgumentException("Parameters can't be null");            string fileA = x.DisplayName;            string fileB = y.DisplayName;            char[] arr1 = fileA.ToCharArray();            char[] arr2 = fileB.ToCharArray();            int i = 0, j = 0;            while (i < arr1.Length && j < arr2.Length)            {                if (char.IsDigit(arr1[i]) && char.IsDigit(arr2[j]))                {                    string s1 = "", s2 = "";                    while (i < arr1.Length && char.IsDigit(arr1[i]))                    {                        s1 += arr1[i];                        i++;                    }                    while (j < arr2.Length && char.IsDigit(arr2[j]))                    {                        s2 += arr2[j];                        j++;                    }                    if (int.Parse(s1) > int.Parse(s2))                    {                        return 1;                    }                    if (int.Parse(s1) < int.Parse(s2))                    {                        return -1;                    }                }                else                {                    if (arr1[i] > arr2[j])                    {                        return 1;                    }                    if (arr1[i] < arr2[j])                    {                        return -1;                    }                    i++;                    j++;                }            }            if (arr1.Length == arr2.Length)            {                return 0;            }            else            {                return arr1.Length > arr2.Length ? 1 : -1;            }        }    }}
 |