From ba8aa925e7901381ceb394adb53eca8723d1c4c5 Mon Sep 17 00:00:00 2001
From: leiqunqing <zhengqifeng@hnkhzn.com>
Date: 星期一, 19 一月 2026 11:05:49 +0800
Subject: [PATCH] 完善工位界面
---
代码管理/WIDESEAWCS_Server/WIDESEAWCS_Server/WIDESEAWCS_BasicInfoService/ScanStationService.cs | 208 +++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 206 insertions(+), 2 deletions(-)
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEAWCS_Server/WIDESEAWCS_Server/WIDESEAWCS_BasicInfoService/ScanStationService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEAWCS_Server/WIDESEAWCS_Server/WIDESEAWCS_BasicInfoService/ScanStationService.cs"
index 172962a..4a5fcda 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEAWCS_Server/WIDESEAWCS_Server/WIDESEAWCS_BasicInfoService/ScanStationService.cs"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/WIDESEAWCS_Server/WIDESEAWCS_Server/WIDESEAWCS_BasicInfoService/ScanStationService.cs"
@@ -1,20 +1,224 @@
-锘縰sing System;
+锘縰sing Autofac.Core;
+using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
+using WIDESEAWCS_Common.PLCEnum;
+using WIDESEAWCS_Core;
using WIDESEAWCS_Core.BaseRepository;
using WIDESEAWCS_Core.BaseServices;
+using WIDESEAWCS_DTO.BasicInfo;
using WIDESEAWCS_Model.Models;
+using WIDESEAWCS_QuartzJob;
namespace WIDESEAWCS_BasicInfoService
{
public class ScanStationService : ServiceBase<Dt_ScanStation, IRepository<Dt_ScanStation>>, IScanStationService
{
- public ScanStationService(IRepository<Dt_ScanStation> BaseDal) : base(BaseDal)
+ private readonly IFormulaService _formulaService;
+ private readonly IFormulaDetailService _formulaDetailService;
+
+ public ScanStationService(IRepository<Dt_ScanStation> BaseDal,
+ IFormulaService formulaService,
+ IFormulaDetailService formulaDetailService
+ ) : base(BaseDal)
{
+ _formulaService = formulaService;
+ _formulaDetailService = formulaDetailService;
}
public IRepository<Dt_ScanStation> Repository => BaseDal;
+
+
+ /// <summary>
+ /// 鍚姩PLC
+ /// </summary>
+ /// <returns></returns>
+ /// <exception cref="Exception"></exception>
+ /// <summary>
+ public WebResponseContent StartPLC(bool isStop)
+ {
+ try
+ {
+ OtherDevice? device = Storage.Devices.FirstOrDefault(x => x.DeviceName == "涓绘帶PLC") as OtherDevice;
+ if (device == null) throw new Exception("鏈壘鍒颁富鎺LC璁惧淇℃伅");
+ if (!device.IsConnected) throw new Exception($"涓绘帶PLC璁惧閫氳寮傚父");
+ if (isStop)
+ {
+ device.SetValue(W_PLCDBName.wboolAutoStart, false);
+ //鏆傚仠淇″彿
+ device.SetValue(W_PLCDBName.wboolAutoPause, false);
+ return WebResponseContent.Instance.OK();
+ }
+ var Heart = device.GetValue<R_PLCDBName, bool>(R_PLCDBName.rboolHeart);
+ var EMG = device.GetValue<R_PLCDBName, bool>(R_PLCDBName.rboolEMG);
+ var OnlineExecuting = device.GetValue<R_PLCDBName, bool>(R_PLCDBName.rboolOnlineExecuting);
+ var Error = device.GetValue<R_PLCDBName, bool>(R_PLCDBName.rboolError);
+
+ if (Heart && !EMG && OnlineExecuting && !Error)
+ {
+ device.SetValue(W_PLCDBName.wboolAutoStart, true);
+ //鏆傚仠淇″彿
+ device.SetValue(W_PLCDBName.wboolAutoPause, false);
+ return WebResponseContent.Instance.OK();
+ }
+
+ return WebResponseContent.Instance.Error("璁惧涓嶆槸鍦ㄧ嚎鐘舵��");
+ }
+ catch (Exception ex)
+ {
+ return WebResponseContent.Instance.Error(ex.Message);
+ }
+ }
+
+
+ /// <summary>
+ /// 鏆傚仠/鎭㈠PLC锛堝弻鍚戞帶鍒讹級
+ /// </summary>
+ /// <param name="isPause">鏄惁涓烘殏鍋滄搷浣滐細true=鏆傚仠锛宖alse=鎭㈠</param>
+ /// <returns>缁熶竴鏍煎紡鐨勫搷搴旂粨鏋�</returns>
+ public WebResponseContent PausePLC(bool isPause)
+ {
+ try
+ {
+ OtherDevice? device = Storage.Devices.FirstOrDefault(x => x.DeviceName == "涓绘帶PLC") as OtherDevice;
+ if (device == null) throw new Exception("鏈壘鍒颁富鎺LC璁惧淇℃伅");
+ if (!device.IsConnected) throw new Exception($"涓绘帶PLC璁惧閫氳寮傚父");
+
+ var Heart = device.GetValue<R_PLCDBName, bool>(R_PLCDBName.rboolHeart);
+ var EMG = device.GetValue<R_PLCDBName, bool>(R_PLCDBName.rboolEMG);
+ var Error = device.GetValue<R_PLCDBName, bool>(R_PLCDBName.rboolError);
+ if(!device.GetValue<W_PLCDBName, bool>(W_PLCDBName.wboolAutoStart))
+ {
+ return WebResponseContent.Instance.Error("璁惧鏈惎鍔�");
+ }
+
+ if (!Heart || EMG || Error)
+ {
+ return WebResponseContent.Instance.Error("璁惧鐘舵�佸紓甯革紝鏃犳硶鎵ц鏆傚仠/鎭㈠鎿嶄綔");
+ }
+ device.SetValue(W_PLCDBName.wboolAutoPause, isPause);
+ return WebResponseContent.Instance.OK();
+ }
+ catch (Exception ex)
+ {
+ return WebResponseContent.Instance.Error(ex.Message);
+ }
+ }
+
+
+ /// <summary>
+ /// 杩斿洖淇″彿
+ /// </summary>
+ /// <returns></returns>
+ /// <exception cref="Exception"></exception>
+ public WebResponseContent GetSignalStates()
+ {
+ OtherDevice? device = Storage.Devices.FirstOrDefault(x => x.DeviceName == "涓绘帶PLC") as OtherDevice;
+ if (device == null) throw new Exception("鏈壘鍒颁富鎺LC璁惧淇℃伅");
+ if (!device.IsConnected) throw new Exception($"涓绘帶PLC璁惧閫氳寮傚父");
+
+ //鑾峰彇淇″彿鐏姸鎬�
+ var Heart = device.GetValue<R_PLCDBName, bool>(R_PLCDBName.rboolHeart);
+ var EMG = device.GetValue<R_PLCDBName, bool>(R_PLCDBName.rboolEMG);
+ var AutoExecuting = device.GetValue<R_PLCDBName, bool>(R_PLCDBName.rboolAutoExecuting);
+ var OnlineExecuting = device.GetValue<R_PLCDBName, bool>(R_PLCDBName.rboolOnlineExecuting);
+ var Error = device.GetValue<R_PLCDBName, bool>(R_PLCDBName.rboolError);
+
+ //鑾峰彇鍚姩鏆傚仠鐘舵��
+ var IsStarted = device.GetValue<W_PLCDBName, bool>(W_PLCDBName.wboolAutoStart);
+ var IsPaused = device.GetValue<W_PLCDBName, bool>(W_PLCDBName.wboolAutoPause);
+
+ //杩斿洖瀵硅薄
+ var responseData = new
+ {
+ // 淇″彿鐏姸鎬佹暟缁勶紙淇濇寔鍘熸湁椤哄簭锛�
+ signalStates = new bool[] { Heart, EMG, AutoExecuting, OnlineExecuting, Error },
+ // PLC鍚姩/鏆傚仠鐘舵�佸璞�
+ plcStatus = new
+ {
+ isStarted = IsStarted,
+ isPaused = IsPaused
+ }
+ };
+ return WebResponseContent.Instance.OK(data: responseData);
+ }
+
+ /// <summary>
+ /// 鑾峰彇鎴愬搧淇℃伅
+ /// </summary>
+ /// <returns></returns>
+ public WebResponseContent GetLeftInitialData()
+ {
+ try
+ {
+ Dt_ScanStation dt_ScanStation = BaseDal.QueryFirst(x => x.StationCode == "001");
+ if (dt_ScanStation == null)
+ {
+ return WebResponseContent.Instance.Error("鏈壘鍒板伐浣嶇紪鐮佷负001鐨勫伐浣嶄俊鎭�");
+ }
+ Dt_Formula dt_Formula = _formulaService.Repository.QueryFirst(x => x.ProductCode == dt_ScanStation.StationEndProduct);
+ if (dt_Formula == null)
+ {
+ return WebResponseContent.Instance.Error($"鏈壘鍒版垚鍝佺紪鍙枫�恵dt_ScanStation.StationEndProduct}銆戝搴旂殑閰嶆柟淇℃伅");
+ }
+ List<Dt_FormulaDetail> dt_FormulaDetails = _formulaDetailService.Repository.QueryData(x => x.FormulaId == dt_Formula.Id);
+
+ var responseData = new
+ {
+ finishedProductId = dt_Formula.Id,
+ finishedProduct = dt_Formula.ProductCode,
+ leftPartCodes = new List<string>(),
+ leftPartIds = new List<int>(),
+ leftPartChecked = new List<int>()
+ };
+
+ foreach (var detail in dt_FormulaDetails.Take(10))
+ {
+ responseData.leftPartCodes.Add(detail.ComponentCode ?? "");
+ responseData.leftPartIds.Add(detail.Id);
+ responseData.leftPartChecked.Add(detail.IsScanned);
+ }
+
+ int needFillCount = 10 - responseData.leftPartCodes.Count;
+ for (int i = 0; i < needFillCount; i++)
+ {
+ responseData.leftPartCodes.Add("");
+ responseData.leftPartIds.Add(0);
+ responseData.leftPartChecked.Add(0);
+ }
+ return WebResponseContent.Instance.OK("鑾峰彇宸︿晶鍒濆鏁版嵁鎴愬姛", responseData);
+ }
+ catch (Exception ex)
+ {
+ return WebResponseContent.Instance.Error($"鑾峰彇宸︿晶鍒濆鏁版嵁澶辫触锛岃绋嶅悗閲嶈瘯銆恵ex.Message}銆�");
+ }
+ }
+
+ /// <summary>
+ /// 鏇存柊鏄惁鎵爜
+ /// </summary>
+ /// <param name="updatePartScannedStatusRequest"></param>
+ /// <returns></returns>
+ public WebResponseContent UpdatePartScannedStatus(UpdatePartScannedStatusRequest updatePartScannedStatusRequest)
+ {
+ try
+ {
+ Dt_FormulaDetail dt_FormulaDetail = _formulaDetailService.Repository.QueryFirst(x => x.Id == updatePartScannedStatusRequest.Id);
+ dt_FormulaDetail.IsScanned = updatePartScannedStatusRequest.IsScanned;
+ bool flag = _formulaDetailService.Repository.UpdateData(dt_FormulaDetail);
+ if (flag)
+ {
+ return WebResponseContent.Instance.OK();
+ }
+ return WebResponseContent.Instance.Error("鏇存柊閿欒");
+ }
+ catch (Exception ex)
+ {
+ return WebResponseContent.Instance.Error("鑾峰彇鏁版嵁澶辫触");
+ }
+ }
+
}
}
--
Gitblit v1.9.3