DockManage.xaml.cs 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Windows;
  6. using System.Windows.Controls;
  7. using System.Windows.Data;
  8. using System.Windows.Documents;
  9. using System.Windows.Input;
  10. using System.Windows.Media;
  11. using System.Windows.Media.Imaging;
  12. using System.Windows.Shapes;
  13. using System.Configuration;
  14. using System.Data;
  15. using System.Data.SqlClient;
  16. namespace AGV_WPF
  17. {
  18. /// <summary>
  19. /// DockManage.xaml 的交互逻辑
  20. /// </summary>
  21. public partial class DockManage : Window
  22. {
  23. //实际的AGV数量
  24. public byte AGVNUM_MAX = Convert.ToByte(ConfigurationManager.AppSettings["AGVNUM_MAX"]);
  25. public int docknum = 0;
  26. public DAL.ZSql sql = new DAL.ZSql();
  27. /// <summary>
  28. /// 构造函数
  29. /// </summary>
  30. public DockManage()
  31. {
  32. InitializeComponent();
  33. InitComboBox();
  34. InitDockNum();
  35. }
  36. /// <summary>
  37. /// 绑定下拉列表
  38. /// </summary>
  39. private void InitComboBox()
  40. {
  41. BindWorkLineComboBox();
  42. BindRouteComboBox();
  43. BindAGVComboBox();
  44. }
  45. /// <summary>
  46. /// 生产区下拉列表绑定
  47. /// </summary>
  48. private void BindWorkLineComboBox()
  49. {
  50. DAL.ZSql sql1 = new DAL.ZSql();
  51. sql1.Open("Select DISTINCT WorkLine from T_Mark");
  52. cbSWorkLine.ItemsSource = sql1.m_table.DefaultView;
  53. cbSWorkLine.DisplayMemberPath = "WorkLine";
  54. cbSWorkLine.SelectedValuePath = "WorkLine";
  55. cbEWorkLine.ItemsSource = sql1.m_table.DefaultView;
  56. cbEWorkLine.DisplayMemberPath = "WorkLine";
  57. cbEWorkLine.SelectedValuePath = "WorkLine";
  58. sql1.Close();
  59. }
  60. /// <summary>
  61. /// 路线下拉列表绑定
  62. /// </summary>
  63. private void BindRouteComboBox()
  64. {
  65. //线路加载初始化
  66. DAL.ZSql sql1 = new DAL.ZSql();
  67. sql1.Open("select DISTINCT LineNum from T_Line order by LineNum");
  68. cbRouteNum.ItemsSource = sql1.m_table.DefaultView;
  69. cbRouteNum.DisplayMemberPath = "LineNum";
  70. cbRouteNum.SelectedValuePath = "LineNum";
  71. sql1.Close();
  72. }
  73. /// <summary>
  74. /// 车辆下拉列表绑定
  75. /// </summary>
  76. private void BindAGVComboBox()
  77. {
  78. //小车编号加载初始化
  79. for (int i = 0; i < AGVNUM_MAX; i++)
  80. {
  81. cbAGVNum.Items.Add((i + 1).ToString());
  82. }
  83. }
  84. /// <summary>
  85. /// 停靠区编号绑定
  86. /// </summary>
  87. private void InitDockNum()
  88. {
  89. DAL.ZSql sql1 = new DAL.ZSql();
  90. sql1.Open("select DISTINCT DockNum from T_DockArea order by DockNum");
  91. cbDockNum.ItemsSource = sql1.m_table.DefaultView;
  92. cbDockNum.DisplayMemberPath = "DockNum";
  93. cbDockNum.SelectedValuePath = "DockNum";
  94. sql1.Close();
  95. }
  96. /// <summary>
  97. /// 加载表格
  98. /// </summary>
  99. /// <param name="paradocknum">停靠区编号</param>
  100. private void LoadDataGrid(int paradocknum)
  101. {
  102. if (paradocknum > 0)
  103. {
  104. DAL.ZSql sql1 = new DAL.ZSql();
  105. sql1.Open("select * from T_DockSetting where DockNum=" + Convert.ToString(paradocknum) + " order by AGVNum");
  106. dataGrid1.ItemsSource = sql1.m_table.DefaultView;
  107. sql1.Close();
  108. DAL.ZSql sql2 = new DAL.ZSql();
  109. sql2.Open("select * from T_DockArea where DockNum=" + Convert.ToString(paradocknum));
  110. dataGrid2.ItemsSource = sql2.m_table.DefaultView;
  111. sql2.Close();
  112. docknum = paradocknum;
  113. }
  114. else
  115. {
  116. dataGrid1.ItemsSource = null;
  117. dataGrid2.ItemsSource = null;
  118. }
  119. }
  120. /// <summary>
  121. /// 表格选择不同行消息触发
  122. /// </summary>
  123. /// <param name="sender"></param>
  124. /// <param name="e"></param>
  125. private void dataGrid1_SelectionChanged(object sender, SelectionChangedEventArgs e)
  126. {
  127. DataRowView selectItem = dataGrid1.SelectedItem as DataRowView;
  128. if (selectItem != null)
  129. {
  130. cbAGVNum.Text = selectItem["AGVNum"].ToString().Trim();
  131. cbRouteNum.Text = selectItem["RouteNum"].ToString().Trim();
  132. }
  133. else
  134. {
  135. cbAGVNum.Text = "";
  136. cbRouteNum.Text = "";
  137. }
  138. }
  139. /// <summary>
  140. /// 停靠区编号选择消息响应
  141. /// </summary>
  142. /// <param name="sender"></param>
  143. /// <param name="e"></param>
  144. private void cbDockNum_SelectionChanged(object sender, SelectionChangedEventArgs e)
  145. {
  146. if (cbDockNum.SelectedValue != null)
  147. {
  148. docknum = Convert.ToUInt16(cbDockNum.SelectedValue.ToString().Trim());
  149. LoadDataGrid(docknum);
  150. }
  151. }
  152. /// <summary>
  153. /// 表格选择不同行消息触发
  154. /// </summary>
  155. /// <param name="sender"></param>
  156. /// <param name="e"></param>
  157. private void dataGrid2_SelectionChanged(object sender, SelectionChangedEventArgs e)
  158. {
  159. DataRowView selectItem = dataGrid2.SelectedItem as DataRowView;
  160. if (selectItem != null)
  161. {
  162. cbSWorkLine.Text = selectItem["DockSSLine"].ToString().Trim();
  163. cbSMark.Text = selectItem["DockSSNum"].ToString().Trim();
  164. cbEWorkLine.Text = selectItem["DockESLine"].ToString().Trim();
  165. cbEMark.Text = selectItem["DockESNum"].ToString().Trim();
  166. }
  167. else
  168. {
  169. cbSWorkLine.Text = "";
  170. cbSMark.Text = "";
  171. cbEWorkLine.Text = "";
  172. cbEMark.Text = "";
  173. }
  174. }
  175. /// <summary>
  176. /// 增加
  177. /// </summary>
  178. /// <param name="sender"></param>
  179. /// <param name="e"></param>
  180. private void btnDockAdd_Click(object sender, RoutedEventArgs e)
  181. {
  182. if (!Vertify_Input())
  183. {
  184. return;
  185. }
  186. //验证是否已存在相同的停靠区
  187. sql.Open("select * from T_DockArea where DockNum=" + cbDockNum.Text.Trim());
  188. if (sql.rowcount > 0)
  189. {
  190. MessageBox.Show("输入的停靠区编号已存在!");
  191. cbDockNum.Focus();
  192. return;
  193. }
  194. sql.Open("insert into T_DockArea (DockNum,DockSSNum,DockSSLine,DockESNum,DockESLine) Values (@docknum,@dockssnum,@dockssline,@dockesnum,@dockesline)",
  195. new SqlParameter[]{
  196. new SqlParameter("docknum",cbDockNum.Text.Trim()),
  197. new SqlParameter("dockssnum",cbSMark.Text.Trim()),
  198. new SqlParameter("dockssline",cbSWorkLine.Text.Trim()),
  199. new SqlParameter("dockesnum",cbEMark.Text.Trim()),
  200. new SqlParameter("dockesline",cbEWorkLine.Text.Trim())
  201. });
  202. sql.Close();
  203. MessageBox.Show("添加成功!");
  204. docknum = Convert.ToInt32(cbDockNum.Text.Trim());
  205. InitDockNum();
  206. LoadDataGrid(docknum);
  207. }
  208. /// <summary>
  209. /// 修改
  210. /// </summary>
  211. /// <param name="sender"></param>
  212. /// <param name="e"></param>
  213. private void btnDockModify_Click(object sender, RoutedEventArgs e)
  214. {
  215. if (!Vertify_Input())
  216. {
  217. return;
  218. }
  219. //验证是否已存在相同的停靠区
  220. sql.Open("select * from T_DockArea where DockNum=" + cbDockNum.Text.Trim());
  221. if (sql.rowcount <= 0)
  222. {
  223. MessageBox.Show("输入的停靠区不存在!");
  224. cbDockNum.Focus();
  225. return;
  226. }
  227. sql.Open("update T_DockArea set DockSSNum=@dockssnum,DockSSLine=@dockssline,DockESNum=@dockesnum,DockESLine=@dockesline where DockNum=@docknum",
  228. new SqlParameter[]{
  229. new SqlParameter("@docknum",cbDockNum.Text.Trim()),
  230. new SqlParameter("@dockssnum",cbSMark.Text.Trim()),
  231. new SqlParameter("@dockssline",cbSWorkLine.Text.Trim()),
  232. new SqlParameter("@dockesnum",cbEMark.Text.Trim()),
  233. new SqlParameter("@dockesline",cbEWorkLine.Text.Trim())
  234. });
  235. sql.Close();
  236. MessageBox.Show("修改成功!");
  237. docknum = Convert.ToInt32(cbDockNum.Text.Trim());
  238. LoadDataGrid(docknum);
  239. }
  240. /// <summary>
  241. /// 删除
  242. /// </summary>
  243. /// <param name="sender"></param>
  244. /// <param name="e"></param>
  245. private void btnDockDelete_Click(object sender, RoutedEventArgs e)
  246. {
  247. if (string.IsNullOrEmpty(cbDockNum.Text.Trim()))
  248. {
  249. MessageBox.Show("请输入停靠区编号!");
  250. return;
  251. }
  252. sql.Open("select * from T_DockArea where DockNum=" + cbDockNum.Text.Trim());
  253. if (sql.rowcount <= 0)
  254. {
  255. MessageBox.Show("您输入的停靠区编号不存在!");
  256. return;
  257. }
  258. sql.Open("delete from T_DockArea where DockNum=" + cbDockNum.Text.Trim());
  259. sql.Open("delete from T_DockSetting where DockNum=" + cbDockNum.Text.Trim());
  260. sql.Close();
  261. MessageBox.Show("删除成功!");
  262. InitDockNum();
  263. cbDockNum.SelectedIndex = 0;
  264. }
  265. /// <summary>
  266. /// 增加
  267. /// </summary>
  268. /// <param name="sender"></param>
  269. /// <param name="e"></param>
  270. private void btnSettingAdd_Click(object sender, RoutedEventArgs e)
  271. {
  272. if (string.IsNullOrEmpty(cbDockNum.Text.Trim()) || string.IsNullOrEmpty(cbAGVNum.Text.Trim()) || string.IsNullOrEmpty(cbRouteNum.Text.Trim()))
  273. {
  274. MessageBox.Show("请输入完整信息!");
  275. return;
  276. }
  277. sql.Open("select * from T_DockSetting where DockNum=" + cbDockNum.Text.Trim() + " and AGVNum=" + cbAGVNum.Text.Trim());
  278. if (sql.rowcount > 0)
  279. {
  280. MessageBox.Show("添加失败!您输入的AGV车辆线路设置已存在!");
  281. return;
  282. }
  283. sql.Open("insert into T_DockSetting (DockNum,AGVNum,RouteNum) Values (@docknum,@agvnum,@routenum)",
  284. new SqlParameter[]{
  285. new SqlParameter("@docknum",cbDockNum.Text.Trim()),
  286. new SqlParameter("@agvnum",cbAGVNum.Text.Trim()),
  287. new SqlParameter("@routenum",cbRouteNum.Text.Trim())
  288. });
  289. sql.Close();
  290. MessageBox.Show("添加成功!");
  291. docknum = Convert.ToInt32(cbDockNum.Text.Trim());
  292. LoadDataGrid(docknum);
  293. }
  294. /// <summary>
  295. /// 修改
  296. /// </summary>
  297. /// <param name="sender"></param>
  298. /// <param name="e"></param>
  299. private void btnSettingModify_Click(object sender, RoutedEventArgs e)
  300. {
  301. if (string.IsNullOrEmpty(cbDockNum.Text.Trim()) || string.IsNullOrEmpty(cbAGVNum.Text.Trim()) || string.IsNullOrEmpty(cbRouteNum.Text.Trim()))
  302. {
  303. MessageBox.Show("请输入完整信息!");
  304. return;
  305. }
  306. sql.Open("select * from T_DockSetting where DockNum=" + cbDockNum.Text.Trim() + " and AGVNum=" + cbAGVNum.Text.Trim());
  307. if (sql.rowcount <= 0)
  308. {
  309. MessageBox.Show("修改失败!您输入的AGV车辆线路设置不存在!");
  310. return;
  311. }
  312. sql.Open("update T_DockSetting set RouteNum=@routenum where DockNum=@docknum and AGVNum=@agvnum",
  313. new SqlParameter[]{
  314. new SqlParameter("@docknum",cbDockNum.Text.Trim()),
  315. new SqlParameter("@agvnum",cbAGVNum.Text.Trim()),
  316. new SqlParameter("@routenum",cbRouteNum.Text.Trim())
  317. });
  318. sql.Close();
  319. MessageBox.Show("修改成功!");
  320. docknum = Convert.ToInt32(cbDockNum.Text.Trim());
  321. LoadDataGrid(docknum);
  322. }
  323. /// <summary>
  324. /// 删除
  325. /// </summary>
  326. /// <param name="sender"></param>
  327. /// <param name="e"></param>
  328. private void btnSettingDelete_Click(object sender, RoutedEventArgs e)
  329. {
  330. if (string.IsNullOrEmpty(cbDockNum.Text.Trim()) || string.IsNullOrEmpty(cbAGVNum.Text.Trim()))
  331. {
  332. MessageBox.Show("请输入停靠区编号和AGV编号!");
  333. return;
  334. }
  335. sql.Open("select * from T_DockSetting where DockNum=" + cbDockNum.Text.Trim() + " and AGVNum=" + cbAGVNum.Text.Trim());
  336. if (sql.rowcount <= 0)
  337. {
  338. MessageBox.Show("删除失败!您输入的AGV车辆线路设置不存在!");
  339. return;
  340. }
  341. sql.Open("delete from T_DockSetting where DockNum=" + cbDockNum.Text.Trim() + " and AGVNum=" + cbAGVNum.Text.Trim());
  342. sql.Close();
  343. MessageBox.Show("删除成功!");
  344. docknum = Convert.ToInt32(cbDockNum.Text.Trim());
  345. LoadDataGrid(docknum);
  346. }
  347. /// <summary>
  348. /// 验证输入
  349. /// </summary>
  350. /// <returns>是否满足要求</returns>
  351. private bool Vertify_Input()
  352. {
  353. if (string.IsNullOrEmpty(cbDockNum.Text.Trim()) || string.IsNullOrEmpty(cbSWorkLine.Text.Trim()) ||
  354. string.IsNullOrEmpty(cbSMark.Text.Trim()) || string.IsNullOrEmpty(cbEWorkLine.Text.Trim()) || string.IsNullOrEmpty(cbEMark.Text.Trim()))
  355. {
  356. MessageBox.Show("请输入完整信息!");
  357. return false;
  358. }
  359. sql.Open("select * from T_Mark where WorkLine=" + cbSWorkLine.Text.Trim() + " and Mark=" + cbSMark.Text.Trim() + " and VirtualMark=0");
  360. if (sql.rowcount < 1)
  361. {
  362. MessageBox.Show("输入的起点地标不存在或为虚拟地标!");
  363. cbSMark.Focus();
  364. return false;
  365. }
  366. sql.Open("select * from T_Mark where WorkLine=" + cbEWorkLine.Text.Trim() + " and Mark=" + cbEMark.Text.Trim() + " and VirtualMark=0");
  367. if (sql.rowcount < 1)
  368. {
  369. MessageBox.Show("输入的终点地标不存在或为虚拟地标!");
  370. cbEMark.Focus();
  371. return false;
  372. }
  373. return true;
  374. }
  375. }
  376. }