|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Collections.ObjectModel;
|
|
|
|
|
using System.Data;
|
|
|
|
|
using System.Data.SqlClient;
|
|
|
|
|
using System.IO;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Text;
|
|
|
|
|
using System.Text.RegularExpressions;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using System.Windows;
|
|
|
|
|
using System.Windows.Controls;
|
|
|
|
|
using System.Windows.Data;
|
|
|
|
|
using System.Windows.Documents;
|
|
|
|
|
using System.Windows.Forms;
|
|
|
|
|
using System.Windows.Input;
|
|
|
|
|
using System.Windows.Media;
|
|
|
|
|
using System.Windows.Media.Imaging;
|
|
|
|
|
using System.Windows.Navigation;
|
|
|
|
|
using System.Windows.Shapes;
|
|
|
|
|
using System.Windows.Threading;
|
|
|
|
|
using Xceed.Wpf.Toolkit.PropertyGrid.Attributes;
|
|
|
|
|
using static System.Net.Mime.MediaTypeNames;
|
|
|
|
|
//using static System.Windows.Forms.VisualStyles.VisualStyleElement;
|
|
|
|
|
|
|
|
|
|
namespace formula_manage
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// MainWindow.xaml 的交互逻辑
|
|
|
|
|
/// </summary>
|
|
|
|
|
public partial class MainWindow : Window
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
DataTable STUFFdataTable = new DataTable(); //建立STUFF缓存
|
|
|
|
|
|
|
|
|
|
public string INIPath = Convert.ToString(System.AppDomain.CurrentDomain.BaseDirectory) + "formula.ini"; //配置文件路径
|
|
|
|
|
|
|
|
|
|
string TEXT_SQLIP;
|
|
|
|
|
string TEXT_SQLNAME;
|
|
|
|
|
string TEXT_SQMOD;
|
|
|
|
|
string TEXT_SQLUSER;
|
|
|
|
|
string TEXT_SQLPASWOR;
|
|
|
|
|
string Connstr_SC;
|
|
|
|
|
|
|
|
|
|
public MainWindow()
|
|
|
|
|
{
|
|
|
|
|
int ID_N = 1;
|
|
|
|
|
|
|
|
|
|
WindowStartupLocation = WindowStartupLocation.CenterScreen;
|
|
|
|
|
InitializeComponent();
|
|
|
|
|
this.Closing += Window_Closing; //添加窗口关闭事件
|
|
|
|
|
|
|
|
|
|
USER.Text = App.USER_Purview;
|
|
|
|
|
|
|
|
|
|
sql_Stuff();//查询stuff表
|
|
|
|
|
|
|
|
|
|
//bindDataGridDatas
|
|
|
|
|
//SelectionList = STUFFdataTable;
|
|
|
|
|
// Grid_RRODUCT.ItemsSource
|
|
|
|
|
|
|
|
|
|
//Grid_RRODUCT.ItemsSource = STUFFdataTable.DefaultView; //new ObservableCollection<string>();
|
|
|
|
|
|
|
|
|
|
CountDown();//执行循环方法
|
|
|
|
|
|
|
|
|
|
DataTable dataTable = new DataTable();
|
|
|
|
|
dataTable.Columns.Add("ID", typeof(int));
|
|
|
|
|
dataTable.Columns.Add("PRODUCT_CODE", typeof(string));
|
|
|
|
|
dataTable.Columns.Add("CONC", typeof(string));
|
|
|
|
|
dataTable.Columns.Add("SHIFT", typeof(string));
|
|
|
|
|
dataTable.Columns.Add("PRODUCT_NAME", typeof(string));
|
|
|
|
|
dataTable.Columns.Add("TARGET_WT", typeof(float));
|
|
|
|
|
dataTable.Columns.Add("UNIT", typeof(string));
|
|
|
|
|
dataTable.Columns.Add("REMARK", typeof(string));
|
|
|
|
|
|
|
|
|
|
DataRow row = dataTable.NewRow(); //ID列
|
|
|
|
|
row["ID"] = ID_N;
|
|
|
|
|
dataTable.Rows.Add(row);
|
|
|
|
|
|
|
|
|
|
for (ID_N = 2; ID_N <= 64; ID_N++)
|
|
|
|
|
{
|
|
|
|
|
row = dataTable.NewRow();
|
|
|
|
|
row["ID"] = ID_N;
|
|
|
|
|
dataTable.Rows.Add(row);
|
|
|
|
|
}
|
|
|
|
|
// DetailedGrid.DataContext = dataTable;
|
|
|
|
|
Grid_RRODUCT.ItemsSource = dataTable.DefaultView;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private async void sql_Stuff()
|
|
|
|
|
{
|
|
|
|
|
UserClass.IniFile.IniFiles Configini = new UserClass.IniFile.IniFiles(INIPath);//生效配置读取
|
|
|
|
|
TEXT_SQLIP = Configini.IniReadvalue("SQL_SERVER", "SQL1"); //读配置文件
|
|
|
|
|
TEXT_SQLNAME = Configini.IniReadvalue("SQL_SERVER", "SQL2");
|
|
|
|
|
TEXT_SQMOD = Configini.IniReadvalue("SQL_SERVER", "SQL3");
|
|
|
|
|
TEXT_SQLUSER = Configini.IniReadvalue("SQL_SERVER", "SQL4");
|
|
|
|
|
TEXT_SQLPASWOR = Configini.IniReadvalue("SQL_SERVER", "SQL5");
|
|
|
|
|
if (TEXT_SQMOD == "0") //判断连接方式
|
|
|
|
|
{
|
|
|
|
|
Connstr_SC = "server=" + TEXT_SQLIP + ";database=" + TEXT_SQLNAME + ";Trusted_Connection=SSPI";
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
Connstr_SC = "server=" + TEXT_SQLIP + ";database=" + TEXT_SQLNAME + ";User ID=" + TEXT_SQLUSER + ";Password=" + TEXT_SQLPASWOR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
string Stuff_sql = "SELECT ProductCode ,ProductName ,ProductType ,Concentration FROM [Dispensing].[dbo].[PRODUCT]";//查询语句
|
|
|
|
|
|
|
|
|
|
SqlConnection conn_SC = new SqlConnection(Connstr_SC); //实例化
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
await conn_SC.OpenAsync(); //打开数据连接
|
|
|
|
|
SqlDataAdapter Stuff_data = new SqlDataAdapter(Stuff_sql, Connstr_SC); //查询
|
|
|
|
|
|
|
|
|
|
//DataTable dataTable = new DataTable(); //建立缓存
|
|
|
|
|
Stuff_data.Fill(STUFFdataTable); //查询结果存入缓存
|
|
|
|
|
conn_SC.Close(); //关闭连接
|
|
|
|
|
//DataGridStuff.ItemsSource = dataTable.DefaultView; //数据加入表格
|
|
|
|
|
}
|
|
|
|
|
catch (Exception)
|
|
|
|
|
{
|
|
|
|
|
System.Windows.MessageBox.Show("请求原料信息失败,检查连接");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Window_Closing(object sender, System.ComponentModel.CancelEventArgs e) //窗口关闭事件
|
|
|
|
|
{
|
|
|
|
|
string logpath = System.Environment.CurrentDirectory + "\\Log";//日志文件目录
|
|
|
|
|
string logPath = "" + System.Environment.CurrentDirectory + "\\Log\\Log.txt";//日志文件
|
|
|
|
|
string Log_time = "[" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "]:";
|
|
|
|
|
|
|
|
|
|
System.IO.DirectoryInfo log = new System.IO.DirectoryInfo(@logpath);//生成日志文件目录
|
|
|
|
|
FileStream fs = new FileStream(logPath, FileMode.Append, FileAccess.Write);
|
|
|
|
|
StreamWriter wr = new StreamWriter(fs);//创建文件
|
|
|
|
|
wr.WriteLine(Log_time + "FORMULA_STOP");
|
|
|
|
|
wr.Close();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private DispatcherTimer disTimer = new DispatcherTimer();//循环功能
|
|
|
|
|
|
|
|
|
|
public void DisTimer_Tick(object sender, EventArgs e)//循环事件
|
|
|
|
|
{
|
|
|
|
|
USERTIME.Text = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
|
|
|
|
|
}
|
|
|
|
|
public void CountDown()
|
|
|
|
|
{
|
|
|
|
|
//设置定时器
|
|
|
|
|
disTimer.Tick += new EventHandler(DisTimer_Tick);//每一秒执行的方法
|
|
|
|
|
disTimer.Interval = new TimeSpan(10000000); //时间间隔为一秒。
|
|
|
|
|
disTimer.Start();//计时开始
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void SearchBox_OnKeyDownd(object sender, System.Windows.Input.KeyEventArgs e) //回车跳转功能
|
|
|
|
|
{
|
|
|
|
|
if (e.Key == Key.Enter)
|
|
|
|
|
{
|
|
|
|
|
UserClass.PressKey.PressKeys(Keys.Tab, false);
|
|
|
|
|
UserClass.PressKey.PressKeys(Keys.Tab, true);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
string Prepose; //料单前置
|
|
|
|
|
string PreposeT; //料单时间
|
|
|
|
|
|
|
|
|
|
private void Window_MIN(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
UserClass.IniFile.IniFiles Configini = new UserClass.IniFile.IniFiles(INIPath);
|
|
|
|
|
Prepose = Configini.IniReadvalue("SOFTWARE_SET", "T1"); //自定义料单前缀
|
|
|
|
|
PreposeT = Configini.IniReadvalue("SOFTWARE_SET", "T2"); //自定义料单时间
|
|
|
|
|
Number.Text = Prepose + System.DateTime.Now.ToString(PreposeT); //生成料单号
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Tb_KeyPress(object sender, TextCompositionEventArgs e)//输入事件
|
|
|
|
|
{
|
|
|
|
|
//Regex re = new Regex("[^0-9.-]+");
|
|
|
|
|
Regex re = new Regex(@"^[0-9]+(.[0-9]{1,3})?$");// 非零的正整数
|
|
|
|
|
e.Handled = !re.IsMatch(e.Text);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Tb_KeyFloating(object sender, TextCompositionEventArgs e)//输入事件
|
|
|
|
|
{
|
|
|
|
|
//Regex re = new Regex("[^0-9.-]+");
|
|
|
|
|
Regex re = new Regex(@"^[.][0-9]+$|^[0-9]*[.]{0,1}[0-9]*$");// 非负浮点数
|
|
|
|
|
e.Handled = !re.IsMatch(e.Text) ;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void SQL(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
Windows.Sql sql= new Windows.Sql();
|
|
|
|
|
sql.ShowDialog();//实例化并置顶打开数据库设置窗口
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void SQLBAK(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
MessageBoxResult sql_bak = System.Windows.MessageBox.Show("注意此功能仅作用与本地数据库(Dispensing)对于远端数据库的操作可能失败如果需要继续操作单击确定", "SQL", MessageBoxButton.OKCancel, MessageBoxImage.Exclamation); //连接失败提示
|
|
|
|
|
if( sql_bak == MessageBoxResult.OK)
|
|
|
|
|
{
|
|
|
|
|
Windows.SQL_BAK sqlbak = new Windows.SQL_BAK();
|
|
|
|
|
sqlbak.ShowDialog();//实例化并置顶打开数据库备份窗口
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
private void SOFTWARE_SET(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
Windows.APP_set APP_set = new Windows.APP_set();
|
|
|
|
|
APP_set.ShowDialog();//实例化并置顶打开设置窗口
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void USER_SET(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
Windows.User user_set = new Windows.User();
|
|
|
|
|
user_set.ShowDialog();//实例化并置顶打开用户窗口
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void HELP(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
Help help_page = new Help();
|
|
|
|
|
help_page.ShowDialog();//实例化并置顶打开信息窗口
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void MAC_SET(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
Windows.Machine mac = new Windows.Machine();
|
|
|
|
|
mac.ShowDialog();//实例化并置顶打开设置窗口
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void STUFF(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
Windows.Stuff stuff = new Windows.Stuff();
|
|
|
|
|
stuff.ShowDialog();//实例化并置顶打开设置窗口
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void print(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void confirm(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void delete(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void save(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Button_NewOrder(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
Number.Text = Prepose + System.DateTime.Now.ToString(PreposeT);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private void Button_up(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
int i = int.Parse(Procedures_N.Text);
|
|
|
|
|
if (i < 999) Procedures_N.Text = ( i + 1).ToString();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Button_dow(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
int i = int.Parse(Procedures_N.Text);
|
|
|
|
|
int P = int.Parse(Procedures_P.Text);
|
|
|
|
|
if (i > 1) Procedures_N.Text = (i - 1).ToString();
|
|
|
|
|
if (P >= i) Procedures_P.Text = Procedures_N.Text;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Button_StepUp(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
int I = int.Parse(Procedures_N.Text);
|
|
|
|
|
int P = int.Parse(Procedures_P.Text);
|
|
|
|
|
if (P < I) Procedures_P.Text = (P + 1).ToString();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Button_StepDow(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
int P = int.Parse(Procedures_P.Text);
|
|
|
|
|
if (P > 1) Procedures_P.Text = (P - 1).ToString();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Button_Technology(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
Deputy.Content = new View.ViewProcess(); //打开工艺选择
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Button_Formula(object sender, RoutedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
Deputy.Content = new View.Formula(); //打开配方选择
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void DataGrid_InitializingNewItem(object sender, InitializingNewItemEventArgs e) //DetailedGrid生成行事件
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Weight(object sender, TextChangedEventArgs e) //重量输入框
|
|
|
|
|
{
|
|
|
|
|
float a, b, c;
|
|
|
|
|
a = float.Parse(list_Weight.Text);
|
|
|
|
|
if (list_Proportion.Text != "") //判断比例是否有效
|
|
|
|
|
{
|
|
|
|
|
b = float.Parse(list_Proportion.Text);
|
|
|
|
|
c = a * b;
|
|
|
|
|
string listtotal = c.ToString();
|
|
|
|
|
list_Total.Text = listtotal;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Proportion(object sender, TextChangedEventArgs e) //浴比输入
|
|
|
|
|
{
|
|
|
|
|
float a, b, c;
|
|
|
|
|
b = float.Parse(list_Proportion.Text);
|
|
|
|
|
if (list_Weight.Text != "") //判断比例是否有效
|
|
|
|
|
{
|
|
|
|
|
a = float.Parse(list_Weight.Text);
|
|
|
|
|
c = a * b;
|
|
|
|
|
string listtotal = c.ToString();
|
|
|
|
|
list_Total.Text = listtotal;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void CP_PRODUCT_CODE_KeyUp(object sender, System.Windows.Input.KeyEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
//string dsa= CP_PRODUCT_CODE //Grid_RRODUCT.SelectedItems[0].ToString();
|
|
|
|
|
|
|
|
|
|
// int index = Grid_RRODUCT.CurrentCell;
|
|
|
|
|
// DataGridTemplateColumn templeColumn = Grid_RRODUCT.Columns[1] as DataGridTemplateColumn;
|
|
|
|
|
|
|
|
|
|
/* for (int k = 0; k < this.Grid_RRODUCT.Items.Count; k++)
|
|
|
|
|
{
|
|
|
|
|
//首先获取DataGridTemplateColumn所在列
|
|
|
|
|
DataGridTemplateColumn tempColumn = this.Grid_RRODUCT.Columns[9] as DataGridTemplateColumn;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//然后获取DataGridTemplateColumn单元格元素
|
|
|
|
|
FrameworkElement element = this.Grid_RRODUCT.Columns[9].GetCellContent(this.Grid_RRODUCT.Items[k]);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (element != null)
|
|
|
|
|
{
|
|
|
|
|
//把单元格元素转换为相应的控件,再从该控件中取值
|
|
|
|
|
System.Windows.Controls.CheckBox ck = Grid_RRODUCT.SelectedItems[1].CellTemplate.FindName("CP_PRODUCT_CODE", element) as System.Windows.Controls.CheckBox;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (ck.IsChecked.Value)
|
|
|
|
|
{
|
|
|
|
|
//do something here
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}*/
|
|
|
|
|
|
|
|
|
|
if (e.Key == Key.Enter)
|
|
|
|
|
{
|
|
|
|
|
UserClass.PressKey.PressKeys(Keys.Right, false);
|
|
|
|
|
UserClass.PressKey.PressKeys(Keys.Right, true);
|
|
|
|
|
UserClass.PressKey.PressKeys(Keys.Up, false);
|
|
|
|
|
UserClass.PressKey.PressKeys(Keys.Up, true);
|
|
|
|
|
UserClass.PressKey.PressKeys(Keys.Tab, false);
|
|
|
|
|
UserClass.PressKey.PressKeys(Keys.Tab, true);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void CP_CONC_KeyUp(object sender, System.Windows.Input.KeyEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
if (e.Key == Key.Enter)
|
|
|
|
|
{
|
|
|
|
|
UserClass.PressKey.PressKeys(Keys.Left, false);
|
|
|
|
|
UserClass.PressKey.PressKeys(Keys.Left, true);
|
|
|
|
|
UserClass.PressKey.PressKeys(Keys.Tab, false);
|
|
|
|
|
UserClass.PressKey.PressKeys(Keys.Tab, true);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|