From 0ab0fde3216783ee2694d8d4bfbb94237e25a4bb Mon Sep 17 00:00:00 2001
From: C3031 <shitiangui@lanpucloud.cn>
Date: 星期五, 06 三月 2026 16:52:56 +0800
Subject: [PATCH] 新增了图像增强算法及图像滤波算法
---
LB_VisionProcesses/Cameras/BaseCamera.cs | 150 ++++++++++++-------------------------------------
1 files changed, 38 insertions(+), 112 deletions(-)
diff --git a/LB_VisionProcesses/Cameras/BaseCamera.cs b/LB_VisionProcesses/Cameras/BaseCamera.cs
index 5f6db1d..7be4f11 100644
--- a/LB_VisionProcesses/Cameras/BaseCamera.cs
+++ b/LB_VisionProcesses/Cameras/BaseCamera.cs
@@ -14,7 +14,20 @@
protected BaseCamera() { }
#region Parm
+ /// <summary>
+ /// 鐩告満SN鍙�
+ /// </summary>
public string SN { get; set; } = string.Empty;
+
+ /// <summary>
+ /// 鐩告満鍚嶇О
+ /// </summary>
+ public string CameraName { get; set; } = string.Empty;
+
+ /// <summary>
+ /// 鐩告満纭Е鍙戣幏鍙栧浘鍍忚Е鍙戝搴旂殑妫�娴嬫祦绋�
+ /// </summary>
+ public Action<string, string> TriggerRunMessageReceived;
public CameraBrand Brand { get; set; } = CameraBrand.UNSUPPORTED;
public bool isGrabbing = false;
@@ -64,96 +77,24 @@
public abstract bool InitDevice(string SN, object Handle = null);
- public bool StartWith_SoftTriggerModel()
- {
- SetTriggerMode(TriggerMode.Off, TriggerSource.Software);
- return StartGrabbing();
- }
+ public abstract bool StartWith_SoftTriggerModel();
- public bool StartWith_HardTriggerModel(TriggerSource hardtriggeritem = TriggerSource.Line0)
- {
- if (hardtriggeritem == TriggerSource.Software) hardtriggeritem = TriggerSource.Line0;
- SetTriggerMode(TriggerMode.On, hardtriggeritem);
- return StartGrabbing();
- }
+ public abstract bool StartWith_HardTriggerModel(TriggerSource hardtriggeritem = TriggerSource.Line0);
/// <summary>
- /// 绛夊緟纭Е鍙戣幏鍙栧浘鍍�
+ /// 绛夊緟杞�/纭Е鍙戣幏鍙栧浘鍍�
/// </summary>
/// <param name="bitmap"></param>
/// <param name="outtime"></param>
/// <returns></returns>
- public bool GetImage(out Bitmap bitmap, int outtime = 3000)
- {
- bitmap = null;
-
- try
- {
- // 璁剧疆瓒呮椂鏃堕棿
- DateTime lastTime = DateTime.Now.AddMilliseconds(outtime);
- // 鍒ゆ柇鏄惁瓒呮椂
- while (lastTime > DateTime.Now)// 璁剧疆瓒呮椂鏃堕棿涓� 3 绉�
- {
- if (CallBackImg != null)
- {
- lock (CallBackImg)
- {
- // 淇濆瓨鏃� Bitmap 骞堕噴鏀�
- bitmap = CallBackImg.Clone() as Bitmap; // 鍒涘缓鍓湰
- }
-
- // 閲婃斁鏃ц祫婧�
- CallBackImg.Dispose();
- CallBackImg = null;
- return true;
- }
- }
-
- return false;
- }
- catch { return bitmap == null ? false : true; }
- }
-
+ public abstract bool GetImage(out Bitmap bitmap, int outtime = 3000);
/// <summary>
/// 杞Е鍙戣幏鍙栧浘鍍�
/// </summary>
/// <param name="bitmap"></param>
/// <param name="outtime"></param>
/// <returns></returns>
- public bool GetImageWithSoftTrigger(out Bitmap bitmap, int outtime = 3000)
- {
- if (!isGrabbing)
- StartGrabbing();
-
- GetTriggerMode(out TriggerMode triggerMode, out TriggerSource triggerSource);
-
- if (triggerMode != TriggerMode.On && triggerSource != TriggerSource.Software)
- SetTriggerMode(TriggerMode.On, TriggerSource.Software);
-
- bitmap = null;
- CallBackImg = null;
-
- if (!SoftTrigger())
- return false;
-
- // 寮�濮嬫椂闂�
- DateTime startTime = DateTime.Now; // 褰撳墠鏃堕棿
-
- // 鍒ゆ柇鏄惁瓒呮椂
- while (DateTime.Now < startTime.AddMilliseconds(outtime))// 璁剧疆瓒呮椂鏃堕棿涓� 3 绉�
- {
- GetImage(out bitmap, 50);
- if (bitmap != null)
- break;
-
- Thread.Sleep(10);
- }
-
- if (triggerMode != TriggerMode.On)
- SetTriggerMode(TriggerMode.On, triggerSource);
-
- return (bitmap != null);
- }
+ public abstract bool GetImageWithSoftTrigger(out Bitmap bitmap, int outtime = 3000);
/// <summary>
/// 杞Е鍙�
@@ -195,40 +136,8 @@
#endregion
#region SettingConfig
- public void SetCamConfig(CameraConfig config)
- {
- if (Enum.TryParse(config.Params.Inputs["瑙﹀彂妯″紡"].ToString(), out TriggerMode TriggerMode)
- && Enum.TryParse(config.Params.Inputs["瑙﹀彂鏂瑰紡"].ToString(), out TriggerSource TriggerSource)
- && Enum.TryParse(config.Params.Inputs["瑙﹀彂鏋佹��"].ToString(), out TriggerPolarity TriggerPolarity)
- )
- {
- SetTriggerMode(TriggerMode, TriggerSource);
- SetTriggerPolarity(TriggerPolarity);
- SetTriggerFliter(Convert.ToDouble(config.Params.Inputs["瑙﹀彂娑堟姈"].ToString()));
- SetTriggerDelay(Convert.ToDouble(config.Params.Inputs["瑙﹀彂寤舵椂"].ToString()));
- SetExpouseTime(Convert.ToDouble(config.Params.Inputs["鏇濆厜鏃堕棿"].ToString()));
- SetGain(Convert.ToDouble(config.Params.Inputs["澧炵泭"].ToString()));
- }
- }
-
- public void GetCamConfig(out CameraConfig config)
- {
- GetTriggerMode(out TriggerMode triggerMode, out TriggerSource triggerSource);
- GetTriggerPolarity(out TriggerPolarity triggerPolarity);
- GetTriggerFliter(out double triggerfilter);
- GetTriggerDelay(out double triggerdelay);
- GetExpouseTime(out double expouseTime);
- GetGain(out double gain);
-
- config = new CameraConfig(null);
- config.Params.Inputs.Add("瑙﹀彂妯″紡", triggerMode);
- config.Params.Inputs.Add("瑙﹀彂鏂瑰紡", triggerSource);
- config.Params.Inputs.Add("瑙﹀彂鏋佹��", triggerPolarity);
- config.Params.Inputs.Add("瑙﹀彂娑堟姈", triggerfilter);
- config.Params.Inputs.Add("瑙﹀彂寤舵椂", triggerdelay);
- config.Params.Inputs.Add("鏇濆厜鏃堕棿", expouseTime);
- config.Params.Inputs.Add("澧炵泭", gain);
- }
+ public abstract void SetCamConfig(CameraConfig config);
+ public abstract void GetCamConfig(out CameraConfig config);
/// <summary>
/// 璁剧疆瑙﹀彂妯″紡鍙婅Е鍙戞簮
@@ -282,12 +191,29 @@
#region protected abstract
/// <summary>
- /// 寮�濮嬮噰鍥�
+ /// 寮�濮嬮噰鍥撅紙榛樿鍗曟閲囬泦锛�
/// </summary>
/// <returns></returns>
public abstract bool StartGrabbing();
/// <summary>
+ /// 鍗曟閲囬泦妯″紡锛堥�傜敤浜庣嚎鎵浉鏈猴級
+ /// </summary>
+ /// <returns></returns>
+ public virtual bool StartSingleGrab()
+ {
+ // 榛樿瀹炵幇锛氭櫘閫氱浉鏈轰笉鏀寔鍗曟閲囬泦锛岀洿鎺ヨ繑鍥瀎alse
+ // 绾挎壂鐩告満闇�瑕侀噸鍐欐鏂规硶
+ return false;
+ }
+
+ /// <summary>
+ /// 杩炵画閲囬泦妯″紡
+ /// </summary>
+ /// <returns></returns>
+ public abstract bool StartContinuousGrab();
+
+ /// <summary>
/// 鍋滄閲囧浘
/// </summary>
/// <returns></returns>
--
Gitblit v1.9.3