LabelParam.cs
6.3 KB
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
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
using CodeLibrary;
using OnlineStore;
using OnlineStore.Common;
using OnlineStore.LoadCSVLibrary;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Runtime.Serialization.Formatters.Binary;
using System.Text;
using System.Threading.Tasks;
namespace DeviceLibrary
{
[Serializable]
public class ReelParam
{
/// <summary>
/// 创建新出入库信息
/// </summary>
/// <param name="wareNo">二维码内容</param>
/// <param name="platew">宽度</param>
/// <param name="plateh">高度</param>
/// <param name="IsNg">是否是入库NG料</param>
/// <param name="ngMsg">NG消息</param>
public ReelParam(string wareNo = "", int platew = 0, int plateh = 0, bool _IsNg = false, string ngMsg = "")
{
UID = databaseProc.Current.GetID();
ReeID = WareCode;
WareCode = wareNo;
PlateW = platew;
PlateH = plateh;
PlateRawH = plateh;
IsNg = _IsNg;
NgMsg = ngMsg;
PN = "PN";
}
public long UID = 0;
string _WareCode;
/// <summary>
/// 物品二维码信息
/// </summary>
public string WareCode
{
get => _WareCode;
set
{
_WareCode = value;
}
}
public string bitmapfilename = "";
public string ReeID { get; set; }
public string PN { get; set; }
public string Algo { get; set; }
/// <summary>
/// 点料数量
/// </summary>
public int QTY { get; set; } = 0;
public int OrgQTY { get; set; } = 0;
public int CurrentStringNum = 0;
public List<CodeInfo> codeInfos { get; set; }
/// <summary>
/// 料盘高度
/// </summary>
public int PlateH { get; set; }
public int PlateRawH { get; set; }
/// <summary>
/// 料盘宽度
/// </summary>
public int PlateW { get; set; }
/// <summary>
/// 是否是入料NG料
/// </summary>
public bool IsNg
{
get;set;
}
/// <summary>
/// 入料NG消息
/// </summary>
public string NgMsg = "";
/// <summary>
/// 贴标状态
/// </summary>
public string LabelState = "None";
public ReelParam clone()
{
ReelParam dstobject;
using (MemoryStream mStream = new MemoryStream())
{
BinaryFormatter bf = new BinaryFormatter();
bf.Serialize(mStream, this);
mStream.Seek(0, SeekOrigin.Begin);//指定当前流的位置为流的开头。
dstobject = (ReelParam)bf.Deserialize(mStream);
mStream.Close();
}
return dstobject;
}
public string ToStr()
{
//var ngStr = IsNg ? "[NG]" : $"[{ReelDest}]";
var countStr = QTY > 0 ? $"[{QTY}]" : "";
return $"[{PlateW}x{PlateH}]{countStr}[{ReeID}]";
}
public string ToDetailStr()
{
return $"{DateTime.Now:HH:mm:ss},{ReeID},{PN},{PlateW}x{PlateH},{CurrentStringNum},{NgMsg},{QTY},{WareCode}";
}
public string ToSortStr()
{
return $"{PN},{PlateW}inch,{NgMsg},{QTY}";
}
bool islog = false;
public void logresult(string xrayfile = "", string resultfile = "")
{
if (!islog)
{
islog = true;
var datetime = DateTime.Now;
string countfile = $"\\LogData\\{datetime:yyyyMMdd_HHmmss}_{QTY}.csv";
Directory.CreateDirectory("\\LogData\\");
if (!File.Exists(countfile))
{
StreamWriter sw1 = new StreamWriter(countfile, true, Encoding.GetEncoding("GB2312"));
sw1.WriteLine($"ReelId,Quantity,DateCode,XFile,Operator");
sw1.Close();
sw1.Dispose();
}
var sw = new StreamWriter(countfile, true, Encoding.GetEncoding("GB2312"));
//var sw = File.Open(countfile, FileMode.Append, FileAccess.Write);
// string s = $"\r\n{ReeID},{PN},{PlateW}x{PlateH},{ReelDest},{NgMsg},{QTY},{WareCode}";
//var b = Encoding.GetEncoding("gb2312").GetBytes(s);
//sw.Write(b, 0, b.Length);
sw.WriteLine($"{ReeID},{QTY},{datetime:yyyy/MM/dd HH:mm:ss},{xrayfile},");
sw.Close();
sw.Dispose();
}
databaseProc.Current.InsertOrUpdateRI(UID, PN, ReeID, IsNg, NgMsg, QTY, LabelState, Algo, WareCode, xrayfile, resultfile);
}
/*
public void logresult(string xrayfile="",string resultfile="")
{
if (!islog)
{
islog = true;
string countfile = $"\\XrayLogs\\CountResult-{DateTime.Now:yyyy-MM-dd}.csv";
Directory.CreateDirectory("\\XrayLogs\\");
if (!File.Exists(countfile))
{
StreamWriter sw1 = new StreamWriter(countfile, true, Encoding.GetEncoding("GB2312"));
sw1.WriteLine($"Date,ReeID,PN,NgMsg,QTY,Algo,XrayFile,ResultFile");
sw1.Close();
sw1.Dispose();
}
var sw = new StreamWriter(countfile, true, Encoding.GetEncoding("GB2312"));
//var sw = File.Open(countfile, FileMode.Append, FileAccess.Write);
// string s = $"\r\n{ReeID},{PN},{PlateW}x{PlateH},{ReelDest},{NgMsg},{QTY},{WareCode}";
//var b = Encoding.GetEncoding("gb2312").GetBytes(s);
//sw.Write(b, 0, b.Length);
sw.WriteLine($"{DateTime.Now:yyyy-mm-dd HH:mm:ss},{ReeID},{PN},{NgMsg},{QTY},{Algo},{xrayfile},{resultfile}");
sw.Close();
sw.Dispose();
}
databaseProc.Current.InsertOrUpdateRI(UID, PN, ReeID, IsNg, NgMsg, QTY, LabelState, Algo, WareCode,xrayfile,resultfile);
}*/
public string GetImgName()
{
string timeName = "-" + DateTime.Now.ToString("yyyyMMddHHmmss") + ".png";
return PN + "-" + ReeID + "-" + timeName;
}
}
}