一厂MES,含注塑,喷涂,冲孔
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

1199 lines
42 KiB

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Configuration;
using System.Data;
using System.Diagnostics.Eventing.Reader;
using System.Drawing;
using System.IO;
using System.Linq;
using System.Net;
using System.Net.NetworkInformation;
using System.Reflection;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using System.Windows.Forms;
using MESClassLibrary.BLL.BasicInfo;
using MESClassLibrary.BLL.Injection;
using MESClassLibrary.BLL.Inspection;
using MESClassLibrary.BLL.Log;
using MESClassLibrary.BLL.TruckBox;
using MESClassLibrary.DAL;
using MESClassLibrary.EFModel;
using MESClassLibrary.Model;
namespace InjectionPC
{
public partial class FrmQuality : Form
{
private static string position = "", reason = "";
private bool _isScanBarCode = true;
int count = 0; //缺陷图选择个数
private InjectionBoxBLL _injectionBoxBLL = new InjectionBoxBLL();
private BadInjectionBLL badBLL = new BadInjectionBLL();
private BadInjectionModel badmd = new BadInjectionModel();
private BarCodeBLL barbll = new BarCodeBLL();
private WmsBLL _wmsBll = new WmsBLL();
private string stationId = "";
private DataTable _boxDetailTable = null;
private List<string> _boxDelList = new List<string>();
internal event Action<List<string>> QualityViewClosed = null;
public FrmQuality(bool isSingle = false)
{
InitializeComponent();
this.Size = new Size(1280, 1024);
if(isSingle == true)
{
txtBoxCode.Enabled = false;
txtBoxCode.KeyDown -= textBox1_KeyDown;
}
}
private void label9_Click(object sender, EventArgs e)
{
this.Close();
//OnVisibleChanged()
}
protected override void OnVisibleChanged(EventArgs e)
{
base.OnVisibleChanged(e);
if (!IsHandleCreated)
{
this.Close();
}
}
private void FrmQuality_Load(object sender, EventArgs e)
{
Control.CheckForIllegalCrossThreadCalls = false;
string LineID = "";
label6.Text = Program.station;
label8.Text = Program.OperatorName;
comboBox1.Text = Program.Shift;
txtScanBarCode.TabIndex = 0;
txtScanBarCode.Focus();
txtBoxCode.Enabled = false;
GetClass();
comboBox1.Enabled = false;
txtBoxCode.Text = "";
textBox2.Text = "";
Thread t = new Thread(new ThreadStart(TimeGo));
t.Start();
timer2.Interval = Convert.ToInt32(ConfigurationManager.AppSettings["InterVal2"]);
timer2.Enabled = false;
StationBLL bll=new StationBLL();
DataTable dt = bll.SearchInfoByNo(Program.station);
if (dt != null && dt.Rows.Count > 0)
{
stationId = dt.Rows[0]["StationID"].ToString();
}
#region 测试
//获取服务器上图片
//Ping p1 = new Ping();
//bool status = false;
//PingReply reply = p1.Send(Program.IP); //发送主机名或Ip地址
//StringBuilder sbuilder;
//if (reply.Status == IPStatus.Success)
//{
// status = Upload.DoConnComputer(Program.IP, "aa", "Administrator", "Wff775168+");
// if (status == true)
// {
// //共享文件夹的目录
// DirectoryInfo theFolder = new DirectoryInfo(@"\\" + Program.IP + "\\aa\\");
// string filename = theFolder.ToString();
// //执行方法
// TransportRemoteToLocal(@"D:\车间.png", filename, "车间.png"); //实现将远程服务器文件写入到本地
// }
//}
//FileStream fs = new FileStream("D:\\2.jpg", FileMode.Open,
// FileAccess.Read);//获取图片文件流
//Image img = Image.FromStream(fs); // 文件流转换成Image格式
//pictureBox2.Image = img; //给 图片框设置要显示的图片
//fs.Close(); // 关闭流,释放图片资源
//Label[] lb = new Label[5];
//string[] str = { "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O" };
//for (int i = 0; i < 5; i++)
//{
// for (int j = 0; j < 3; j++)
// {
// lb[i] = new Label();
// lb[i].Text = str[i].ToString();
// lb[i].Font = new Font(lb[i].Font.FontFamily, 32, FontStyle.Bold);
// lb[i].Size = new Size(pictureBox2.Width / 5, pictureBox2.Height / 3);
// lb[i].Location = new Point(0 + i * lb[i].Size.Width, 0 + j * lb[i].Size.Height);
// lb[i].BorderStyle = BorderStyle.FixedSingle;
// lb[i].BackColor = Color.Transparent;
// lb[i].TextAlign = ContentAlignment.MiddleCenter;
// pictureBox2.Controls.Add(lb[i]);
// lb[i].Click += new EventHandler(lblRoom_Click);
// }
//}
//StationBLL sbll = new StationBLL();
//DataTable sdt = sbll.SearchInfoByNo(Program.station);
//if (sdt != null && sdt.Rows.Count > 0)
//{
// LineID = sdt.Rows[0]["LineID"].ToString();
//}
//sdt.Dispose();
//int row = 0, col = 6;
//DefectBLL dbll = new DefectBLL();
//DataTable dt3 = dbll.SearchInfo(LineID);
//if (dt3 != null && dt3.Rows.Count > 0)
//{
// row = Convert.ToInt32(Math.Ceiling((double)dt3.Rows.Count / 6));
// Label[] dLb = new Label[7];
// string[] dstr = new string[dt3.Rows.Count];
// for (int i = 0; i < dt3.Rows.Count; i++)
// {
// dstr[i] = dt3.Rows[i]["DefectName"].ToString();
// }
// for (int i = 0; i < 6; i++) //列
// {
// for (int j = 0; j < row;j++) //行
// {
// dLb[i] = new Label();
// if ((i + 6 * j) < dstr.Length)
// {
// dLb[i].Text = dstr[i + 6 * j].ToString();
// dLb[i].Font = new Font(dLb[i].Font.FontFamily, 24, FontStyle.Bold);
// dLb[i].Size = new Size(150, 50);
// dLb[i].Location = new Point(20 + i * (dLb[i].Size.Width+25), 5 + j * (dLb[i].Size.Height+20));
// dLb[i].BorderStyle = BorderStyle.FixedSingle;
// dLb[i].BackColor = Color.Transparent;
// dLb[i].TextAlign = ContentAlignment.MiddleCenter;
// panel2.Controls.Add(dLb[i]);
// }
// }
// }
//}
#endregion
txtScanBarCode.Text = Program.strBarCode;
lbBoxCode.Text = Program.strBoxCode;
txtScanBarCode.SelectAll();
if (ConfigurationManager.AppSettings["IsLast"] == "1")
{
label9.Visible = true;
}
else if (ConfigurationManager.AppSettings["IsLast"] == "0")
{
label9.Visible = false;
}
GetBadCount();
if (!string.IsNullOrEmpty(txtScanBarCode.Text))
{
textBox3_KeyDown(null, new KeyEventArgs( Keys.Enter));
}
}
private void TimeGo()
{
System.Timers.Timer timer = new System.Timers.Timer();
timer.Interval = 1000;
timer.Enabled = true;
timer.Elapsed += new System.Timers.ElapsedEventHandler(timer_Tick);
}
private void timer_Tick(object sender, EventArgs e)
{
try
{
label2.Text = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
Thread.Sleep(500);
}
catch
{
}
}
/// <summary>
/// 从远程服务器下载文件到本地
/// </summary>
/// <param name="src">下载到本地后的文件路径,包含文件的扩展名</param>
/// <param name="dst">远程服务器路径(共享文件夹路径)</param>
/// <param name="fileName">远程服务器(共享文件夹)中的文件名称,包含扩展名</param>
public static void TransportRemoteToLocal(string src, string dst, string fileName) //src:下载到本地后的文件路径 dst:远程服务器路径 fileName:远程服务器dst路径下的文件名
{
try
{
FileStream inFileStream = new FileStream(src, FileMode.Open); //远程服务器文件 此处假定远程服务器共享文件夹下确实包含本文件,否则程序报错
if (!Directory.Exists(dst))
{
Directory.CreateDirectory(dst);
}
dst = dst + fileName;
FileStream outFileStream = new FileStream(dst, FileMode.OpenOrCreate); //从远程服务器下载到本地的文件
byte[] buf = new byte[inFileStream.Length];
int byteCount;
while ((byteCount = inFileStream.Read(buf, 0, buf.Length)) > 0)
{
outFileStream.Write(buf, 0, byteCount);
}
inFileStream.Flush();
inFileStream.Close();
outFileStream.Flush();
outFileStream.Close();
}
catch (Exception ex)
{
LogErrBLL.AddInfo(ex.ToString(), MethodBase.GetCurrentMethod());
}
}
void lblRoom_Click(object sender, EventArgs e)
{
Label a = (Label) sender;
//foreach (Control c in pictureBox2.Controls)
//{
// c.BackColor = Color.Transparent;
//}
if (a.BackColor == Color.Transparent)
{
a.BackColor = Color.FromArgb(150, System.Drawing.Color.Chartreuse);
count++;
}
else
{
a.BackColor = Color.Transparent;
count--;
}
//position +=a.Text+",";
}
void dLbRoom_Click(object sender, EventArgs e)
{
Label a = (Label)sender;
string aa = a.Text;
if (a.BackColor == Color.Transparent)
{
a.BackColor = Color.FromArgb(150, Color.Chartreuse);
reason += a.Text+";";
}
else
{
reason = reason.Replace(a.Text+";","");
a.BackColor = Color.Transparent;
}
}
/// <summary>
/// 保存缺陷 1.tb_Bad_Injection 增加记录 2.tb_Injection_BoxRecord表减一条数据 3. tb_BarCode1表 IsBad=1 4.[tb_Injectionn_Interface]表增加一条QaRst=1的数据
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void button1_Click(object sender, EventArgs e)
{
//string stockNo = "",batchNo="",partNo="",isbox="";
foreach (Control c in pictureBox2.Controls)
{
Label lab = c as Label;
if (lab.BackColor != Color.Transparent)
{
position += lab.Text + ";";
}
}
if (position == "")
{
MessageBox.Show("请选择缺陷位置!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
return;
}
if (reason == "")
{
MessageBox.Show("请选择缺陷原因!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
return;
}
InjectionBoxBLL ibll=new InjectionBoxBLL();
InspectionBLL bll = new InspectionBLL();
tb_Inspection_tx md = new tb_Inspection_tx();
if (txtBoxCode.Text != "" && txtScanBarCode.Text != "")
{
MessageBox.Show("箱单和条码只能输入一个!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
return;
}
if (txtBoxCode.Text == "" && txtScanBarCode.Text == "")
{
MessageBox.Show("请扫描条码", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
return;
}
#region 大件报废
if (txtBoxCode.Text == "" && txtScanBarCode.Text != "")
{
SingleBadSave();
}
#endregion
#region 小件报废,直接修改产量,如果是开机报废减产量,否则产量不变增加报废数
if (txtBoxCode.Text != "" && txtScanBarCode.Text == "")
{
FullBoxBadSave(_boxDetailTable);
if (!_boxDelList.Contains(txtBoxCode.Text?.Trim()))
{
_boxDelList.Add(txtBoxCode.Text?.Trim());
}
}
#endregion
#region 插入质检总表
md.BarCode = badmd.OneBarCode;
md.IsOK = 0;
md.Station = 2;
bll.AddInfo(md);
#endregion
reason = "";
txtScanBarCode.Text = "";
txtScanBarCode.TabIndex = 0;
txtScanBarCode.SelectAll();
txtScanBarCode.Focus();
textBox4.Text = "";
pictureBox2.Image = null;
txtBoxCode.Text = "";
pictureBox2.Controls.Clear();
panel2.Controls.Clear();
position = "";
reason = "";
}
/// <summary>
/// 单个报废
/// </summary>
private void SingleBadSave()
{
string isbox = "";
#region 判断是否已做过报废
DataTable baddt = badBLL.SearchByCode(txtScanBarCode.Text.Trim()); //bad 表
if (baddt != null && baddt.Rows.Count > 0)
{
MessageBox.Show("请产品已做过报废处理!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
reason = "";
txtScanBarCode.Text = "";
txtScanBarCode.TabIndex = 0;
txtScanBarCode.Focus();
textBox4.Text = "";
pictureBox2.Image = null;
pictureBox2.Controls.Clear();
panel2.Controls.Clear();
return;
}
#endregion
#region 保存报废详细信息和是否装过箱,装过箱子的不允许报废
badmd.ID = Guid.NewGuid().ToString();
badmd.StationID = stationId;
badmd.BadPosition = position;
badmd.BadReason = reason.Trim();
badmd.code = _scanPartNo;
badmd.Desc = textBox4.Text?.Trim();
//直供件条码
if (txtScanBarCode.Text.Trim().Contains("#"))
{
badmd.BarCode = txtScanBarCode.Text.Trim();
//tb_barCode找到记录
DataTable dt1 = barbll.SeachInfoByOne(txtScanBarCode.Text.Trim(), Program.tableName, 2);
if (dt1 != null && dt1.Rows.Count > 0)
{
badmd.OneBarCode = dt1.Rows[0]["OneBarCode"].ToString();
isbox = dt1.Rows[0]["BoxNo"].ToString();
//扣减装箱表boxRecord中箱码对应的数量
//if (SubtrBoxCount(isbox) == false)
// return;
if (SaveBad(badmd,isbox) == false)
{
return;
}
}
else
{
MessageBox.Show("条码不存在!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
return;
}
}
else
{
//普通条码
if (txtScanBarCode.Text.Trim().Contains('.'))
{
badmd.BarCode = txtScanBarCode.Text.Trim();
//tb_barCode找到记录
DataTable dt = barbll.SeachInfoByOne(txtScanBarCode.Text.Trim(), Program.tableName, 2);
if (dt != null && dt.Rows.Count > 0)
{
badmd.OneBarCode = dt.Rows[0]["OneBarCode"].ToString();
isbox = dt.Rows[0]["BoxNo"].ToString();
if (SaveBad(badmd, isbox) == false)
{
return;
}
}
else
{
MessageBox.Show("条码不存在!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
return;
}
}
//20位注塑码
else
{
badmd.OneBarCode = txtScanBarCode.Text.Trim();
DataTable dt1 = barbll.SeachInfoByOne(txtScanBarCode.Text.Trim(), Program.tableName, 1);
if (dt1 != null && dt1.Rows.Count > 0)
{
badmd.BarCode = dt1.Rows[0]["BarCode"].ToString();
isbox = dt1.Rows[0]["BoxNo"].ToString();
if (SaveBad(badmd, isbox) == false)
{
return;
}
}
else
{
MessageBox.Show("条码不存在!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
return;
}
}
}
//badBLL.Add_Info(badmd);
#endregion
#region 更新BarCode表标志位
//barbll.UpdateIsBad(Program.tableName, badmd.OneBarCode, badmd.BarCode);
#endregion
GetBadCount();
}
bool SaveBad(BadInjectionModel badmd ,string boxCode)
{
if (!string.IsNullOrEmpty(boxCode))
{
DataTable boxTable = _injectionBoxBLL.SearchBox(boxCode);
if (boxTable.Rows.Count > 0)
{
if (boxTable.Rows[0]["IsPrint"].ToString() == "1")
{
MessageBox.Show("请产品已做装箱,不能做报废!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
reason = "";
txtScanBarCode.Text = "";
txtScanBarCode.TabIndex = 0;
txtScanBarCode.Focus();
textBox4.Text = "";
pictureBox2.Image = null;
pictureBox2.Controls.Clear();
panel2.Controls.Clear();
return false;
}
else
{
bool exsitInWms = _wmsBll.IsReadBarCodeInWms(badmd.BarCode);
if(exsitInWms == true)
{
MessageBox.Show($"条码[{badmd.BarCode}]在WMS已处理,无法在MES进行报废操作.");
return false;
}
string msg = badBLL.SaveBad(badmd,boxCode, Program.tableName, Program.station);
if (!string.IsNullOrEmpty(msg))
{
MessageBox.Show("报废操作失败,失败原因:" + msg);
return false;
}
else
{
MessageBox.Show(badmd.OneBarCode +"报废操作成功");
}
}
}
}
else
{
bool exsitInWms = _wmsBll.IsReadBarCodeInWms(badmd.BarCode);
if (exsitInWms == true)
{
MessageBox.Show($"条码[{badmd.BarCode}]在WMS已处理,无法在MES进行报废操作.");
return false;
}
string msg = badBLL.SaveBad(badmd, boxCode, Program.tableName, Program.station);
if (!string.IsNullOrEmpty(msg))
{
MessageBox.Show("报废操作失败,失败原因:" + msg);
return false;
}
else
{
MessageBox.Show(badmd.OneBarCode + "报废操作成功");
}
}
return true;
}
bool SaveBadByBatch(DataTable boxDetailTable, string boxCode)
{
if (!string.IsNullOrEmpty(boxCode))
{
badmd.Desc = textBox4.Text?.Trim();
string msg = badBLL.SaveBadByBatch(boxDetailTable, stationId, position, reason, boxCode, Program.tableName, textBox4.Text?.Trim(), Program.station);
if (!string.IsNullOrEmpty(msg))
{
MessageBox.Show($"整箱报废失败:" + msg);
return false;
}
}
return true;
}
/// <summary>
/// 按箱码报废
/// </summary>
private void FullBoxBadSave(DataTable boxDetailTable)
{
if(boxDetailTable == null || boxDetailTable.Rows.Count ==0)
{
MessageBox.Show($"箱码[{txtBoxCode.Text}]所含详细记录为0,请重新操作.");
return;
}
if (MessageBox.Show($"确认对箱码[{txtBoxCode.Text}]所含[{boxDetailTable.Rows.Count}]条数据做报废处理?", "", MessageBoxButtons.OKCancel) == DialogResult.Cancel)
return;
string boxCode = boxDetailTable.Rows[0]["BoxNo"].ToString();
if (string.IsNullOrEmpty(boxCode))
return;
#region 扣减箱码数量
bool isRead = _wmsBll.IsReadBoxInWms(boxCode);
if (isRead == true)
{
MessageBox.Show($"箱码[{boxCode}]已报工,不能做报废!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
reason = "";
txtScanBarCode.Text = "";
txtScanBarCode.TabIndex = 0;
txtScanBarCode.Focus();
textBox4.Text = "";
pictureBox2.Image = null;
pictureBox2.Controls.Clear();
panel2.Controls.Clear();
return;
}
else
{
SaveBadByBatch(boxDetailTable, boxCode);
}
#endregion
GetBadCount();
}
/// <summary>
/// 扣减箱码数量
/// </summary>
/// <param name="boxCode"></param>
/// <returns></returns>
bool SubtrBoxCount(string boxCode)
{
if (!string.IsNullOrEmpty(boxCode))
{
DataTable boxTable = _injectionBoxBLL.SearchBox(boxCode);
if (boxTable.Rows.Count > 0)
{
if (boxTable.Rows[0]["IsPrint"].ToString() == "1")
{
MessageBox.Show("请产品已做装箱,不能做报废!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
reason = "";
txtScanBarCode.Text = "";
txtScanBarCode.TabIndex = 0;
txtScanBarCode.Focus();
textBox4.Text = "";
pictureBox2.Image = null;
pictureBox2.Controls.Clear();
panel2.Controls.Clear();
return false;
}
else
{
_injectionBoxBLL.UpdateBoxCount(boxCode, -1);
}
}
}
return true;
}
/// <summary>
/// 扣减箱码数量为0,同时撤回WMS报工数据, 如果wms已读取,返回false
/// </summary>
/// <param name="boxCode"></param>
/// <returns></returns>
bool ClearBoxCount(string boxCode)
{
if (!string.IsNullOrEmpty(boxCode))
{
bool isRead = _wmsBll.IsReadBoxInWms(boxCode);
if (isRead == true)
{
MessageBox.Show($"箱码[{boxCode}]已报工,不能做报废!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
reason = "";
txtScanBarCode.Text = "";
txtScanBarCode.TabIndex = 0;
txtScanBarCode.Focus();
textBox4.Text = "";
pictureBox2.Image = null;
pictureBox2.Controls.Clear();
panel2.Controls.Clear();
return false;
}
else
{
bool isDel = _wmsBll.DelRecordByBox(boxCode);
if(isDel)
{
_injectionBoxBLL.UpdateBoxCount(boxCode, 100, true);
}
else
{
MessageBox.Show($"整箱报废失败,可能箱码[{boxCode}]在操作时已被wms接收");
return false;
}
}
}
return true;
}
private static bool IsNumeric(string str)
{
System.Text.RegularExpressions.Regex reg1 = new System.Text.RegularExpressions.Regex(@"^[0-9]\d*$");
return reg1.IsMatch(str);
}
private void textBox3_KeyDown(object sender, KeyEventArgs e)
{
if (e.KeyCode == Keys.Enter)
{
textBox2.Text = "1";
_boxDetailTable = null;
BarCodeScan(txtScanBarCode.Text.Trim());
}
}
private string _scanPartNo = string.Empty;
/// <summary>
/// 扫描标签质检
/// </summary>
/// <param name="scanBarCode"></param>
void BarCodeScan(string scanBarCode)
{
_isScanBarCode = true;
string code = "";
string[] barcode = new string[3];
int row = 0, col = 0;
string picture = "";
string LineID = "";
ProductBLL bll = new ProductBLL();
BarCodeBLL barbll = new BarCodeBLL();
if (scanBarCode.Contains('.') == false && scanBarCode.Contains('#') == false)
{
DataTable xdt = barbll.SeachInfoByOne(scanBarCode.Trim(), Program.tableName, 1);
if (xdt != null && xdt.Rows.Count > 0)
{
code = xdt.Rows[0]["BarCode"].ToString();
_scanPartNo = xdt.Rows[0]["PartNo"].ToString();
}
else
{
MessageBox.Show("条码有误!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
return;
}
barcode = code.Split('.');
DataTable dt = bll.SearchInfoByPartNo(barcode[0]);
if (dt != null && dt.Rows.Count > 0)
{
textBox4.Text = dt.Rows[0]["ProductName"].ToString();
row = Convert.ToInt32(dt.Rows[0]["Rows"].ToString());
col = Convert.ToInt32(dt.Rows[0]["Cols"].ToString());
picture = dt.Rows[0]["PicturePath"].ToString();
}
}
else
{
DataTable xdt = barbll.SeachInfoByOne(scanBarCode.Trim(), Program.tableName, 2);
if (xdt != null && xdt.Rows.Count > 0)
{
code = xdt.Rows[0]["BarCode"].ToString();
_scanPartNo = xdt.Rows[0]["PartNo"].ToString();
}
else
{
MessageBox.Show("条码有误!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
return;
}
if (scanBarCode.Contains('#') == false)
{
barcode = scanBarCode.Trim().Split('.');
DataTable dt = bll.SearchInfoByPartNo(barcode[0]);
if (dt != null && dt.Rows.Count > 0)
{
textBox4.Text = dt.Rows[0]["ProductName"].ToString();
row = Convert.ToInt32(dt.Rows[0]["Rows"].ToString());
col = Convert.ToInt32(dt.Rows[0]["Cols"].ToString());
picture = dt.Rows[0]["PicturePath"].ToString();
}
}
else
{
barcode = scanBarCode.Trim().Split('#');
DataTable dt = bll.SearchInfoByPartNo(barcode[0]);
if (dt != null && dt.Rows.Count > 0)
{
textBox4.Text = dt.Rows[0]["ProductName"].ToString();
row = Convert.ToInt32(dt.Rows[0]["Rows"].ToString());
col = Convert.ToInt32(dt.Rows[0]["Cols"].ToString());
picture = dt.Rows[0]["PicturePath"].ToString();
}
}
}
try
{
#region Load PictureBox
if (!string.IsNullOrEmpty(picture))
{
if (!File.Exists(System.IO.Directory.GetCurrentDirectory() + @"\" + picture))
{
//string strImageURL = ConfigurationManager.AppSettings["PicturePath"] + picture;
string strImageURL = "http://10.60.101.59:8001/PDF/" + picture;
System.Net.WebClient webClient = new System.Net.WebClient();
webClient.DownloadFile(strImageURL, Directory.GetCurrentDirectory() + @"\" + picture);
}
FileStream fs = new FileStream(Directory.GetCurrentDirectory() + "\\" + picture, FileMode.Open,
FileAccess.Read); //获取图片文件流
Image img = Image.FromStream(fs); // 文件流转换成Image格式
pictureBox2.Image = img; //给 图片框设置要显示的图片
fs.Close(); // 关闭流,释放图片资源
}
#endregion
}
catch (Exception ex)
{
LogErrBLL.AddInfo(ex.ToString(), MethodBase.GetCurrentMethod());
}
#region 缺陷图划分区域
Label[] lb = new Label[5];
string[] str =
{
"A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T",
"U", "V", "W", "X", "Y", "Z"
};
for (int i = 0; i < col; i++)
{
for (int j = 0; j < row; j++)
{
lb[i] = new Label();
lb[i].Text = str[i + col * j].ToString();
lb[i].Font = new Font(lb[i].Font.FontFamily, 32, FontStyle.Bold);
lb[i].Size = new Size(pictureBox2.Width / col, pictureBox2.Height / row);
lb[i].Location = new Point(0 + i * lb[i].Size.Width, 0 + j * lb[i].Size.Height);
lb[i].BorderStyle = BorderStyle.FixedSingle;
lb[i].BackColor = Color.Transparent;
lb[i].TextAlign = ContentAlignment.MiddleCenter;
pictureBox2.Controls.Add(lb[i]);
lb[i].Click += new EventHandler(lblRoom_Click);
}
}
#endregion
#region 缺陷原因
StationBLL sbll = new StationBLL();
DataTable sdt = sbll.SearchInfoByNo(Program.station);
if (sdt != null && sdt.Rows.Count > 0)
{
LineID = sdt.Rows[0]["LineID"].ToString();
}
int drow = 0, dcol = 6;
DefectBLL dbll = new DefectBLL();
DataTable dt3 = dbll.SearchInfo(LineID);
if (dt3 != null && dt3.Rows.Count > 0)
{
drow = Convert.ToInt32(Math.Ceiling((double)dt3.Rows.Count / dcol));
Label[] dLb = new Label[7];
string[] dstr = new string[dt3.Rows.Count];
for (int i = 0; i < dt3.Rows.Count; i++)
{
dstr[i] = dt3.Rows[i]["DefectName"].ToString();
}
for (int i = 0; i < dcol; i++) //列
{
for (int j = 0; j < drow; j++) //行
{
dLb[i] = new Label();
if ((i + dcol * j) < dstr.Length)
{
dLb[i].Text = dstr[i + dcol * j].ToString();
dLb[i].Font = new Font(dLb[i].Font.FontFamily, 20, FontStyle.Bold);
dLb[i].Size = new Size(130, 50);
dLb[i].Location = new Point(50 + i * (dLb[i].Size.Width + 25),
50 + j * (dLb[i].Size.Height + 20));
dLb[i].BorderStyle = BorderStyle.FixedSingle;
dLb[i].BackColor = Color.Transparent;
dLb[i].TextAlign = ContentAlignment.MiddleCenter;
panel2.Controls.Add(dLb[i]);
dLb[i].Click += new EventHandler(dLbRoom_Click);
}
}
}
}
#endregion
if (ConfigurationManager.AppSettings["IsLast"] == "1")
{
timer2.Enabled = true;
}
else if (ConfigurationManager.AppSettings["IsLast"] == "0")
{
timer2.Enabled = false;
label9.Visible = false;
}
}
private void label2_Click(object sender, EventArgs e)
{
this.Close();
if(QualityViewClosed != null)
{
QualityViewClosed(_boxDelList);
}
//Environment.Exit(0);
}
/// <summary>
/// 扫描箱码,整箱报废
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void textBox1_KeyDown(object sender, KeyEventArgs e)
{
try
{
InjectionBoxBLL bll=new InjectionBoxBLL();
BarCodeBLL pbll =new BarCodeBLL();
if (e.KeyCode == Keys.Enter)
{
string packageCode = txtBoxCode.Text.Trim();
if (string.IsNullOrEmpty(packageCode)) return;
DataTable packageTable = pbll.SearchBarCode(packageCode, Program.tableName, "100");
if(packageTable.Rows.Count == 0)
{
//MessageBox.Show($"扫描箱单[{packageCode}]在系统中不存在!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
MessageBox.Show($"扫描箱单[{packageCode}]不存在未报废订单!");
txtBoxCode.Focus();
return;
}
_boxDetailTable = packageTable;
DataRow dr = packageTable.Rows[0];
textBox2.Text = packageTable.Rows.Count.ToString();
BarCodeScan(dr["OneBarCode"].ToString());
//if (textBox1.Text.Trim() == "")
//{
// MessageBox.Show("请扫描或输入箱单!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
// textBox1.Focus();
// return;
//}
//if (textBox1.Text.Contains('.')==false)
//{
// MessageBox.Show("箱单格式有误!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
// textBox1.Focus();
// return;
//}
//#region 判断箱单是否为小件,即看零件号是否需要打印单个条码
//string[] aa = textBox1.Text.Split('.');
//string partNo = aa[0].ToString().Trim();
//DataTable dt = pbll.SearchInfoByPartNo(partNo);
//if (dt != null && dt.Rows.Count > 0)
//{
// if (dt.Rows[0]["IsPrintOneTag"].ToString() == "1")
// {
// MessageBox.Show("该零件有单个条码,不能扫描箱单!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
// textBox1.Focus();
// return;
// }
//}
//else
//{
// MessageBox.Show("该箱单有误,请重新扫描或输入!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
// textBox1.Focus();
// return;
//}
//#endregion
//_isScanBarCode = false;
//DataTable dt1 = bll.SearchBox(textBox1.Text);
//if (dt1 != null && dt1.Rows.Count > 0)
//{
// textBox2.Text = dt1.Rows[0]["BoxCount"].ToString();
//}
//else
//{
// MessageBox.Show("该箱单不存在!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
// textBox1.Focus();
// return;
//}
}
}
catch (Exception ex)
{
LogErrBLL.AddInfo(ex.ToString(), MethodBase.GetCurrentMethod());
}
}
private void timer2_Tick(object sender, EventArgs e)
{
GetClass();
}
private DateTime GetDateTime()
{
string sql = "";
DateTime time;
DataTable dt;
try
{
sql = @"select convert(char(23),getdate(),121) as time";
dt = SqlHelper.ExecuteDataset(SqlHelper.GetConnSting(), CommandType.Text, sql, null).Tables[0];
if (dt != null && dt.Rows.Count > 0)
{
time = DateTime.ParseExact(dt.Rows[0]["time"].ToString(), "yyyy-MM-dd HH:mm:ss.fff",
System.Globalization.CultureInfo.CurrentCulture);
}
else
{
time = DateTime.Now;
}
return time;
}
catch (Exception ex)
{
LogErrBLL.AddInfo(ex.ToString(), MethodBase.GetCurrentMethod());
return DateTime.Now;
}
}
private void GetClass()
{
try
{
DateTime aa = GetDateTime();
if (GetDateTime().Hour >= 8 && GetDateTime().Hour < 20)
{
Program.Shift = "白班";
}
else
{
Program.Shift = "夜班";
}
comboBox1.Text = Program.Shift;
}
catch (Exception ex)
{
LogErrBLL.AddInfo(ex.ToString(), MethodBase.GetCurrentMethod());
}
}
private void rbtn1_CheckedChanged(object sender, EventArgs e)
{
if (rbtn1.Checked)
{
txtBoxCode.Enabled = true;
txtScanBarCode.Text = "";
textBox2.Text = "";
textBox4.Text = "";
txtBoxCode.Focus();
}
else
{
txtBoxCode.Enabled = false;
}
}
private void rbtn2_CheckedChanged(object sender, EventArgs e)
{
if (rbtn2.Checked)
{
txtScanBarCode.Enabled = true;
txtBoxCode.Text = "";
textBox2.Text = "";
textBox4.Text = "";
txtScanBarCode.Focus();
}
else
{
txtScanBarCode.Enabled = false;
}
}
private void GetBadCount()
{
try
{
BadInjectionBLL bll = new BadInjectionBLL();
string startTime = "", endTime = "";
if (comboBox1.Text == "白班")
{
startTime = DateTime.Now.ToString("yyyy-MM-dd") + " 08:00:00";
endTime = DateTime.Now.ToString("yyyy-MM-dd") + " 20:00:00";
}
else
{
if (DateTime.Now.Hour <= 7)
{
startTime = DateTime.Now.AddDays(-1).ToString("yyyy-MM-dd") + " 20:00:00";
endTime = DateTime.Now.ToString("yyyy-MM-dd") + " 08:00:00";
}
else
{
startTime = DateTime.Now.ToString("yyyy-MM-dd") + " 20:00:00";
endTime = DateTime.Now.AddDays(1).ToString("yyyy-MM-dd") + " 08:00:00";
}
}
textBox2.Text = bll.BadCount(startTime, endTime, stationId);
}
catch (Exception ex)
{
LogErrBLL.AddInfo(ex.ToString(),MethodBase.GetCurrentMethod());
}
}
}
}