规范类名及命名空间名称
This commit is contained in:
@@ -0,0 +1,102 @@
|
||||
// ============================================================================
|
||||
// Copyright © 2026 Hexagon Technology Center GmbH. All Rights Reserved.
|
||||
// 文件� MorphologyProcessor.cs
|
||||
// æ��è¿°: å½¢æ€�å¦å¤„ç�†ç®—å�,用于二值图åƒ�的形æ€�妿“�作
|
||||
// 功能:
|
||||
// - è…�蚀(Erodeï¼‰ï¼šæ”¶ç¼©ç›®æ ‡åŒºåŸŸ
|
||||
// - 膨胀(Dilateï¼‰ï¼šæ‰©å¼ ç›®æ ‡åŒºåŸŸ
|
||||
// - å¼€è¿�算(Open):先è…�蚀å�Žè†¨èƒ€ï¼Œå޻除å°�ç›®æ ‡
|
||||
// - é—è¿�算(Close):先膨胀å�Žè…�蚀,填充å°�唿´ž
|
||||
// 算法: æ•°å¦å½¢æ€�å¦è¿�ç®—
|
||||
// 作� �伟 wei.lw.li@hexagon.com
|
||||
// ============================================================================
|
||||
|
||||
using Emgu.CV;
|
||||
using Emgu.CV.CvEnum;
|
||||
using Emgu.CV.Structure;
|
||||
using Serilog;
|
||||
using System.Drawing;
|
||||
using XP.ImageProcessing.Core;
|
||||
|
||||
namespace XP.ImageProcessing.Processors;
|
||||
|
||||
/// <summary>
|
||||
/// å½¢æ€�å¦å¤„ç�†ç®—å�
|
||||
/// </summary>
|
||||
public class MorphologyProcessor : ImageProcessorBase
|
||||
{
|
||||
private static readonly ILogger _logger = Log.ForContext<MorphologyProcessor>();
|
||||
|
||||
public MorphologyProcessor()
|
||||
{
|
||||
Name = LocalizationHelper.GetString("MorphologyProcessor_Name");
|
||||
Description = LocalizationHelper.GetString("MorphologyProcessor_Description");
|
||||
}
|
||||
|
||||
protected override void InitializeParameters()
|
||||
{
|
||||
Parameters.Add("Operation", new ProcessorParameter(
|
||||
"Operation",
|
||||
LocalizationHelper.GetString("MorphologyProcessor_Operation"),
|
||||
typeof(string),
|
||||
"Erode",
|
||||
null,
|
||||
null,
|
||||
LocalizationHelper.GetString("MorphologyProcessor_Operation_Desc"),
|
||||
new string[] { "Erode", "Dilate", "Open", "Close" }));
|
||||
|
||||
Parameters.Add("KernelSize", new ProcessorParameter(
|
||||
"KernelSize",
|
||||
LocalizationHelper.GetString("MorphologyProcessor_KernelSize"),
|
||||
typeof(int),
|
||||
3,
|
||||
1,
|
||||
21,
|
||||
LocalizationHelper.GetString("MorphologyProcessor_KernelSize_Desc")));
|
||||
|
||||
Parameters.Add("Iterations", new ProcessorParameter(
|
||||
"Iterations",
|
||||
LocalizationHelper.GetString("MorphologyProcessor_Iterations"),
|
||||
typeof(int),
|
||||
1,
|
||||
1,
|
||||
10,
|
||||
LocalizationHelper.GetString("MorphologyProcessor_Iterations_Desc")));
|
||||
_logger.Debug("InitializeParameters");
|
||||
}
|
||||
|
||||
public override Image<Gray, byte> Process(Image<Gray, byte> inputImage)
|
||||
{
|
||||
string operation = GetParameter<string>("Operation");
|
||||
int kernelSize = GetParameter<int>("KernelSize");
|
||||
int iterations = GetParameter<int>("Iterations");
|
||||
|
||||
var kernel = CvInvoke.GetStructuringElement(ElementShape.Rectangle, new Size(kernelSize, kernelSize), new Point(-1, -1));
|
||||
var result = inputImage.Clone();
|
||||
|
||||
switch (operation)
|
||||
{
|
||||
case "Erode":
|
||||
CvInvoke.Erode(inputImage, result, kernel, new Point(-1, -1),
|
||||
iterations, BorderType.Default, default);
|
||||
break;
|
||||
|
||||
case "Dilate":
|
||||
CvInvoke.Dilate(inputImage, result, kernel, new Point(-1, -1),
|
||||
iterations, BorderType.Default, default);
|
||||
break;
|
||||
|
||||
case "Open":
|
||||
CvInvoke.MorphologyEx(inputImage, result, MorphOp.Open, kernel,
|
||||
new Point(-1, -1), iterations, BorderType.Default, default);
|
||||
break;
|
||||
|
||||
case "Close":
|
||||
CvInvoke.MorphologyEx(inputImage, result, MorphOp.Close, kernel,
|
||||
new Point(-1, -1), iterations, BorderType.Default, default);
|
||||
break;
|
||||
}
|
||||
_logger.Debug("Process:Operation = {operation},KernelSize = {kernelSize},Iterations = {iterations}", operation, kernelSize, iterations);
|
||||
return result;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user