Example #1
0
        private void addMatR(invType mat, int amount, int depth, bool start = false)
        {
            if (mat == null)
            {
                return;
            }

            if (mat.isBaseMat())
            {
                baseMats.Add(mat, amount);
            }
            else
            {
                METEData data = null;
                this.meteDatas.TryGetValue(mat, out data);

                bool hadMEData = true;

                if (data == null)
                {
                    data      = this.defaultMETE;
                    hadMEData = false;
                }

                string matStr = "";

                for (int i = 0; i < depth; i++)
                {
                    matStr += "-";
                }

                if (!hadMEData || start)
                {
                    this.QMMatsGrid.Rows.Add(matStr + mat, amount, "", "", "", "", "", "");
                }
                else
                {
                    string[] mesStrs = data.ToStrArray();
                    this.QMMatsGrid.Rows.Add(matStr + mat, amount, mesStrs[0], mesStrs[1], mesStrs[2], mesStrs[3], mesStrs[4], mesStrs[5]);
                }
                var matlist = mat.getMats(amount, data.TotalMEAsMultiplier);

                foreach (KeyValuePair <invType, int> submat in matlist)
                {
                    addMatR(submat.Key, submat.Value, depth + 1);
                }
            }
        }