using OpenCvSharp;
using PaintDotNet.Adjust;
using PaintDotNet.Base.Functionodel;
using PaintDotNet.CustomControl;
using PaintDotNet;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Drawing.Drawing2D;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using Point = System.Drawing.Point;
using PaintDotNet.Annotation;
namespace PaintDotNet.DedicatedAnalysis.NonferrousMetals.IntegrationClass
{
internal class MetalsBoundaryEditingDialog : Form
{
///
/// 公共按钮
///
private CommonControlButtons commonControlButtons;
///
/// 主控件
///
private AppWorkspace appWorkspace;
private DocumentWorkspaceWindow documentWorkspace;
///
/// 外接矩形,或者是计算的矩形
///
protected RectangleF rectangle = new RectangleF();
/////
///// 用于get处理后的图像
/////
//private Mat phaseMat;
/////
///// 辅助线集成
/////
//private GrainSizeGuideClass guideClass;
//public object SelectedItem;
Color phaseColor;
Mat phaseMatCopy = new Mat();
///
/// 当前处理的程序
///
private Data.Action.Action911 action = new Data.Action.Action911();
///
/// 操作类型
/// 0,没有操作 1,折线添加 2,直线添加
/// 11,多边形删除 12,圆形删除 13,矩形删除 14,椭圆删除
///
private int pointKtype = 0;
///
/// 起始点
///
private Point startPoint = new Point(-1, -1);
///
/// 是否绘制了起始点
///
private bool drawedStartPoint = false;
///
/// 结束点
///
private Point endPoint = new Point(-1, -1);
///
/// 折线点的集合
///
public List pointArray = new List();
///
/// 是否显示视场
///
Boolean ShowDrawClassView = true;
private GroupBox groupBox1;
private GroupBox groupBox2;
private Button button2;
private Button button1;
private Button button3;
private Button button4;
private Button button8;
private Button button7;
private Button button6;
private Button button5;
private TriangleTrackBar trackBar2;
private TextBox textBox1;
private Label label1;
private TrackBar trackBar1;
private Button button9;
private GroupBox groupBox7;
List analyzePoints;
//public GrainSizeGuideClass GuideClass
//{
// set
// {
// this.guideClass = value;
// }
//}
public MetalsBoundaryEditingDialog(AppWorkspace appWorkspace, int focusedItemIndex, Color phaseColor, List analyzePoints/*Mat analyzeMat*/, Boolean ShowDrawClassView = true)
{
this.ShowDrawClassView = ShowDrawClassView;
this.appWorkspace = appWorkspace;
InitializeComponent();
InitializeLanguageText();
//
//初始化图像控件
//
this.documentWorkspace = new DocumentWorkspaceWindow(appWorkspace);
this.documentWorkspace.Dock = DockStyle.Fill;
this.documentWorkspace.HookMouseEvents();
this.documentWorkspace.AuxiliaryLineEnabled = false;
this.documentWorkspace.Visible = false;
this.documentWorkspace.panel.MouseDown += OnMouseDown;
this.documentWorkspace.panel.Paint += Panel_Paint;
this.documentWorkspace.panel.MouseMove += onMouseMove;
this.documentWorkspace.panel.MouseUp += onMouseUp;
this.documentWorkspace.panel.Click += new EventHandler(this.pictureBox1_Click);
this.documentWorkspace.ActiveTool = Annotation.Enum.DrawToolType.InclusionNoEffect;//禁止视场移动
this.groupBox7.Controls.Add(documentWorkspace);
//
//初始化操作按钮
//
this.commonControlButtons = new CommonControlButtons();
this.commonControlButtons.Dock = DockStyle.Top;
this.commonControlButtons.Height = 30;
this.commonControlButtons.HideZoomToWindowAndActualSize();
this.groupBox7.Controls.Add(commonControlButtons);
this.phaseColor = phaseColor;
{
//
//初始化相
//
PhaseModel model = new PhaseModel();
model.choise = true;
model.mat = null;
model.color = phaseColor.ToArgb();// Color.Green/*panel2.BackColor*/.ToArgb();
model.position = this.documentWorkspace.PhaseModels.Count + 1;
model.name = PdnResources.GetString("Menu.Binarization.text");
this.documentWorkspace.PhaseModels.Add(model);
}
/////
///// 选中图片的mat
Mat imageMat = this.appWorkspace.DocumentWorkspaces[focusedItemIndex].CompositionSurface.CreatedAliasedMat();
this.analyzePoints = analyzePoints;
Document document = Document.FromImageMat(imageMat.Clone());
this.documentWorkspace.Document = document;
this.documentWorkspace.Visible = true;
if (ShowDrawClassView)
{
this.documentWorkspace.GraphicsList = this.appWorkspace.DocumentWorkspaces[focusedItemIndex].GraphicsList;
}
else
{
GraphicsList itemGraphicsList = this.appWorkspace.DocumentWorkspaces[focusedItemIndex].GraphicsList;
GraphicsList graphicsList = new GraphicsList();
for (int j = 0; j < itemGraphicsList.Count; j++)
{
if (itemGraphicsList[j].objectType != Annotation.Enum.DrawClass.View)
graphicsList.Add(itemGraphicsList[j]);
}
this.documentWorkspace.GraphicsList = graphicsList;
}
InitCommonButtonEvent();
}
#region 矩形拖动
///
/// 鼠标按下
///
///
///
private void OnMouseDown(object sender, MouseEventArgs e)
{
// 换算后的点
PointF point1 = documentWorkspace.GetScalePoint(e.Location);
if (point1.X <= this.documentWorkspace.CompositionSurface.Width
&& point1.X >= 0
&& point1.Y >= 0
&& point1.Y <= this.documentWorkspace.CompositionSurface.Height)
{
if (e.Button == MouseButtons.Left/* && e.Clicks == 1*/&& this.pointKtype >= 1)
{
if (!drawedStartPoint)
{
drawedStartPoint = true;
startPoint = new Point((int)point1.X, (int)point1.Y);
return;
}
// 折线添加
if (this.pointKtype == 1)
{
}
// 直线添加
else if (this.pointKtype == 2)
{
}
// 多边形删除
else if (this.pointKtype == 11)
{
}
}
}
else if (this.pointKtype == 14 || this.pointKtype == 13 || this.pointKtype == 12)
{
if (!drawedStartPoint)
{
drawedStartPoint = true;
startPoint = new Point((int)point1.X, (int)point1.Y);
return;
}
}
else
return;
// 右键完成操作
if (e.Button == MouseButtons.Right)
{
}
}
///
/// 移动
///
///
///
private void onMouseMove(object sender, MouseEventArgs e)
{
// 换算后的点
PointF point1 = documentWorkspace.GetScalePoint(e.Location);
if (e.Button == MouseButtons.Left)
{
// 椭圆删除/圆形删除
if ((this.pointKtype == 14 || this.pointKtype == 12) && drawedStartPoint)
{
endPoint = new Point((int)point1.X, (int)point1.Y);
if (this.startPoint.X < this.endPoint.X)
{
this.rectangle.X = this.startPoint.X;
this.rectangle.Width = this.endPoint.X - this.startPoint.X;
}
else
{
this.rectangle.X = this.endPoint.X;
this.rectangle.Width = this.startPoint.X - this.endPoint.X;
}
if (this.startPoint.Y < this.endPoint.Y)
{
this.rectangle.Y = this.startPoint.Y;
this.rectangle.Height = this.endPoint.Y - this.startPoint.Y;
}
else
{
this.rectangle.Y = this.endPoint.Y;
this.rectangle.Height = this.startPoint.Y - this.endPoint.Y;
}
this.documentWorkspace.Refresh();
}
// 矩形删除
if (this.pointKtype == 13 && drawedStartPoint)
{
endPoint = new Point((int)point1.X, (int)point1.Y);
if (this.startPoint.X < this.endPoint.X)
{
this.rectangle.X = this.startPoint.X;
this.rectangle.Width = this.endPoint.X - this.startPoint.X;
}
else
{
this.rectangle.X = this.endPoint.X;
this.rectangle.Width = this.startPoint.X - this.endPoint.X;
}
if (this.startPoint.Y < this.endPoint.Y)
{
this.rectangle.Y = this.startPoint.Y;
this.rectangle.Height = this.endPoint.Y - this.startPoint.Y;
}
else
{
this.rectangle.Y = this.endPoint.Y;
this.rectangle.Height = this.startPoint.Y - this.endPoint.Y;
}
this.documentWorkspace.Refresh();
}
// 直线添加
if (this.pointKtype == 2 && drawedStartPoint)
{
endPoint = new Point((int)point1.X, (int)point1.Y);
this.documentWorkspace.Refresh();
}
}
}
///
/// 鼠标抬起
///
///
///
private void onMouseUp(object sender, MouseEventArgs e)
{
// 换算后的点
PointF point1 = documentWorkspace.GetScalePoint(e.Location);
if (point1.X <= this.documentWorkspace.CompositionSurface.Width
&& point1.X >= 0
&& point1.Y >= 0
&& point1.Y <= this.documentWorkspace.CompositionSurface.Height) { }
else
{
if (this.pointKtype == 14 || this.pointKtype == 13 || this.pointKtype == 12)
{
//if (point1.X >= this.documentWorkspace.CompositionSurface.Width)
// point1.X = this.documentWorkspace.CompositionSurface.Width - 1;
//if (point1.X < 0)
// point1.X = 0;
//if (point1.Y >= this.documentWorkspace.CompositionSurface.Height)
// point1.Y = this.documentWorkspace.CompositionSurface.Height - 1;
//if (point1.Y < 0)
// point1.Y = 0;
}
else
return;
}
if (e.Button == MouseButtons.Right)
{
// 折线删除
if (this.pointKtype == 11 && pointArray.Count > 1)
{
pointArray.Add(new Point((int)point1.X, (int)point1.Y));
endPoint = new Point((int)point1.X, (int)point1.Y);
List pointFArray = new List();
foreach (var item in pointArray)
{
pointFArray.Add(new PointF(item.X, item.Y));
}
for (int i = this.analyzePoints.Count - 1; i >= 0; i--)
{
RectangleF analyzeF = new RectangleF(this.rectangle.X, this.rectangle.Y, Math.Min(this.rectangle.Width, this.rectangle.Height), Math.Min(this.rectangle.Width, this.rectangle.Height));
List srcPoints = this.analyzePoints[i].ToList();
this.analyzePoints.RemoveAt(i);//先移除
List tempPoints = new List();
foreach (var item in srcPoints)
{
if (!Adjust.BaseImage.BaseTools.isPointInPolygon(new System.Drawing.Point(item.X, item.Y), pointFArray))//判断如果不在折线删除的框选内
tempPoints.Add(item);
else
{
if (tempPoints.Count > 1)
this.analyzePoints.Add(tempPoints.ToArray());//后添加
tempPoints = new List();//添加后清空中间对象
}
}
if (tempPoints.Count > 1)
this.analyzePoints.Add(tempPoints.ToArray());//后添加
}
//this.documentWorkspace.PhaseModels[0].mat = PreActionIntent.PolygonDelete(this.documentWorkspace.PhaseModels[0].mat, pointFArray);
//this.documentWorkspace.PhaseModels[0].mat.CopyTo(phaseMatCopy);
//////保存处理后的图片
////Bitmap originalBit = OpenCvSharp.Extensions.BitmapConverter.ToBitmap(this.documentWorkspace.PhaseModels[0].mat);
////Bitmap newBit = originalBit.Clone(new Rectangle(0, 0, originalBit.Width, originalBit.Height), originalBit.PixelFormat);
////Graphics graphics = Graphics.FromImage(newBit);
////Draw(graphics);
////this.documentWorkspace.PhaseModels[0].mat/* = phaseMat*/ = PaintDotNet.Camera.Tools.ToMat(newBit);
this.rectangle.X = -1;
this.rectangle.Y = -1;
this.rectangle.Width = 0;
this.rectangle.Height = 0;
pointArray.Clear();
startPoint = new Point(-1, -1);
drawedStartPoint = false;
endPoint = new Point(-1, -1);
this.pointKtype = 0;
this.documentWorkspace.Refresh();
}
// 折线添加
if (this.pointKtype == 1 && pointArray.Count > 1)
{
pointArray.Add(new Point((int)point1.X, (int)point1.Y));
endPoint = new Point((int)point1.X, (int)point1.Y);
List alPoints = this.findAllPoints(pointArray);
if (alPoints.Count > 1)
analyzePoints.Add(alPoints.ToArray());
////保存处理后的图片
//Bitmap originalBit = OpenCvSharp.Extensions.BitmapConverter.ToBitmap(this.documentWorkspace.PhaseModels[0].mat);
//Bitmap newBit = originalBit.Clone(new Rectangle(0, 0, originalBit.Width, originalBit.Height), originalBit.PixelFormat);
//Graphics graphics = Graphics.FromImage(newBit);
//Draw(graphics);
//this.documentWorkspace.PhaseModels[0].mat/* = phaseMat*/ = PaintDotNet.Camera.Tools.ToMat(newBit);
//this.documentWorkspace.PhaseModels[0].mat.CopyTo(phaseMatCopy);
pointArray.Clear();
startPoint = new Point(-1, -1);
drawedStartPoint = false;
endPoint = new Point(-1, -1);
this.pointKtype = 0;
this.documentWorkspace.Refresh();
}
}
if (e.Button == MouseButtons.Left)
{
// 圆形删除/椭圆删除
if ((this.pointKtype == 14 || this.pointKtype == 12) && drawedStartPoint)
{
endPoint = new Point((int)point1.X, (int)point1.Y);
if (this.startPoint.X < this.endPoint.X)
{
this.rectangle.X = this.startPoint.X;
this.rectangle.Width = this.endPoint.X - this.startPoint.X;
}
else
{
this.rectangle.X = this.endPoint.X;
this.rectangle.Width = this.startPoint.X - this.endPoint.X;
}
if (this.startPoint.Y < this.endPoint.Y)
{
this.rectangle.Y = this.startPoint.Y;
this.rectangle.Height = this.endPoint.Y - this.startPoint.Y;
}
else
{
this.rectangle.Y = this.endPoint.Y;
this.rectangle.Height = this.startPoint.Y - this.endPoint.Y;
}
if (this.pointKtype == 14)
{
for (int i = this.analyzePoints.Count - 1; i >= 0; i--)
{
List srcPoints = this.analyzePoints[i].ToList();
this.analyzePoints.RemoveAt(i);//先移除
List tempPoints = new List();
foreach (var item in srcPoints)
{
if (!Adjust.BaseImage.BaseTools.isPointInOval(new System.Drawing.Point(item.X, item.Y), new System.Drawing.PointF(rectangle.X + rectangle.Width / 2, rectangle.Y + rectangle.Height / 2),
rectangle.Width / 2, rectangle.Height / 2 ))//判断如果不在椭圆删除的框选内
tempPoints.Add(item);
else
{
if (tempPoints.Count > 1)
this.analyzePoints.Add(tempPoints.ToArray());//后添加
tempPoints = new List();//添加后清空中间对象
}
}
if (tempPoints.Count > 1)
this.analyzePoints.Add(tempPoints.ToArray());//后添加
}
}
else
for (int i = this.analyzePoints.Count - 1; i >= 0; i--)
{
RectangleF analyzeF = new RectangleF(this.rectangle.X, this.rectangle.Y, Math.Min(this.rectangle.Width, this.rectangle.Height), Math.Min(this.rectangle.Width, this.rectangle.Height));
List srcPoints = this.analyzePoints[i].ToList();
this.analyzePoints.RemoveAt(i);//先移除
List tempPoints = new List();
foreach (var item in srcPoints)
{
if (!Adjust.BaseImage.BaseTools.isPointInOval(new System.Drawing.Point(item.X, item.Y), new System.Drawing.PointF(analyzeF.X + analyzeF.Width / 2, analyzeF.Y + analyzeF.Height / 2),
analyzeF.Width / 2, analyzeF.Height / 2))//判断如果不在椭圆删除的框选内
tempPoints.Add(item);
else
{
if (tempPoints.Count > 1)
this.analyzePoints.Add(tempPoints.ToArray());//后添加
tempPoints = new List();//添加后清空中间对象
}
}
if (tempPoints.Count > 1)
this.analyzePoints.Add(tempPoints.ToArray());//后添加
}
this.rectangle.X = -1;
this.rectangle.Y = -1;
this.rectangle.Width = 0;
this.rectangle.Height = 0;
startPoint = new Point(-1, -1);
drawedStartPoint = false;
endPoint = new Point(-1, -1);
this.pointKtype = 0;
this.documentWorkspace.Refresh();
}
// 矩形删除
if (this.pointKtype == 13 && drawedStartPoint)
{
endPoint = new Point((int)point1.X, (int)point1.Y);
if (this.startPoint.X < this.endPoint.X)
{
this.rectangle.X = this.startPoint.X;
this.rectangle.Width = this.endPoint.X - this.startPoint.X;
}
else
{
this.rectangle.X = this.endPoint.X;
this.rectangle.Width = this.startPoint.X - this.endPoint.X;
}
if (this.startPoint.Y < this.endPoint.Y)
{
this.rectangle.Y = this.startPoint.Y;
this.rectangle.Height = this.endPoint.Y - this.startPoint.Y;
}
else
{
this.rectangle.Y = this.endPoint.Y;
this.rectangle.Height = this.startPoint.Y - this.endPoint.Y;
}
for (int i = this.analyzePoints.Count - 1; i >= 0; i--)
{
List srcPoints = this.analyzePoints[i].ToList();
this.analyzePoints.RemoveAt(i);//先移除
List tempPoints = new List();
foreach (var item in srcPoints)
{
if (!rectangle.Contains(item.X, item.Y))//判断如果不在矩形删除的框选内
tempPoints.Add(item);
else
{
if (tempPoints.Count > 1)
this.analyzePoints.Add(tempPoints.ToArray());//后添加
tempPoints = new List();//添加后清空中间对象
}
}
if (tempPoints.Count > 1)
this.analyzePoints.Add(tempPoints.ToArray());//后添加
}
//this.documentWorkspace.PhaseModels[0].mat = PreActionIntent.RectangleDelete(this.documentWorkspace.PhaseModels[0].mat, this.rectangle);
//this.documentWorkspace.PhaseModels[0].mat.CopyTo(phaseMatCopy);
////保存处理后的图片
//Bitmap originalBit = OpenCvSharp.Extensions.BitmapConverter.ToBitmap(this.documentWorkspace.PhaseModels[0].mat);
//Bitmap newBit = originalBit.Clone(new Rectangle(0, 0, originalBit.Width, originalBit.Height), originalBit.PixelFormat);
//Graphics graphics = Graphics.FromImage(newBit);
//Draw(graphics);
//this.documentWorkspace.PhaseModels[0].mat/* = phaseMat*/ = PaintDotNet.Camera.Tools.ToMat(newBit);
this.rectangle.X = -1;
this.rectangle.Y = -1;
this.rectangle.Width = 0;
this.rectangle.Height = 0;
startPoint = new Point(-1, -1);
drawedStartPoint = false;
endPoint = new Point(-1, -1);
this.pointKtype = 0;
this.documentWorkspace.Refresh();
}
// 折线添加/折线删除
if (this.pointKtype == 1 || this.pointKtype == 11)
{
pointArray.Add(new Point((int)point1.X, (int)point1.Y));
if (!drawedStartPoint)
{
drawedStartPoint = true;
startPoint = new Point((int)point1.X, (int)point1.Y);
}
this.documentWorkspace.Refresh();
}
// 直线添加
if (this.pointKtype == 2 && drawedStartPoint)
{
endPoint = new Point((int)point1.X, (int)point1.Y);
if (drawedStartPoint && this.endPoint.X > -1 && this.endPoint.Y > -1)
{
List alPoints = this.findAllPoints(new List() { startPoint, endPoint });
if (alPoints.Count > 1)
analyzePoints.Add(alPoints.ToArray());
}
////保存处理后的图片
//Bitmap originalBit = OpenCvSharp.Extensions.BitmapConverter.ToBitmap(this.documentWorkspace.PhaseModels[0].mat);
//Bitmap newBit = originalBit.Clone(new Rectangle(0, 0, originalBit.Width, originalBit.Height), originalBit.PixelFormat);
//Graphics graphics = Graphics.FromImage(newBit);
//Draw(graphics);
//this.documentWorkspace.PhaseModels[0].mat/* = phaseMat*/ = PaintDotNet.Camera.Tools.ToMat(newBit);
//this.documentWorkspace.PhaseModels[0].mat.CopyTo(phaseMatCopy);
startPoint = new Point(-1, -1);
drawedStartPoint = false;
endPoint = new Point(-1, -1);
this.pointKtype = 0;
this.documentWorkspace.Refresh();
}
}
}
///
/// 根据关键点集合获取折线图上所有的点
///
/// 画折线或直线的点集合
/// 按顺序返回折线或直线上面所有的点
private List findAllPoints(List srcPoints)
{
List dstPoints = new List();
for (int i = 0; i < srcPoints.Count - 1; i++)
{
Point startP = srcPoints[i];
Point endP = srcPoints[i + 1];
int disX = Math.Abs(startP.X - endP.X);
int disY = Math.Abs(startP.Y - endP.Y);
dstPoints.Add(startP);
if (disX > disY)
{
int step = (endP.X - startP.X) / disX;
// 计算斜率
double k = ((double)(startP.Y - endP.Y)) / (startP.X - endP.X);
//循环x坐标
for (int stepI = 1; stepI < disX - 1; stepI++)
{
// 根据斜率,计算y坐标
double y = k * stepI * step + startP.Y;
// 简单判断一下y是不是整数
double d = y - (int)y;
//if (0.5 > d && d > -0.5)
{
dstPoints.Add(new Point(stepI * step + startP.X, (int)y));
}
}
}
else if (disY > 1)
{
int step = (endP.Y - startP.Y) / disY;
// 计算斜率
double k = ((double)(startP.X - endP.X)) / (startP.Y - endP.Y);
//循环y坐标
for (int stepI = 1; stepI < disY - 1; stepI++)
{
// 根据斜率,计算x坐标
double x = k * stepI * step + startP.X;
// 简单判断一下x是不是整数
double d = x - (int)x;
//if (0.5 > d && d > -0.5)
{
dstPoints.Add(new Point((int)x, stepI * step + startP.Y));
}
}
}
}
dstPoints.Add(srcPoints[srcPoints.Count - 1]);
return dstPoints;
}
#endregion
///
/// surfaceBox双击事件
/// 目前是参考AxioVision
/// 应该是把每次选的点都取最高和最低的BGR
///
///
///
private unsafe void pictureBox1_Click(object sender, EventArgs e)
{
}
///
/// 画布绘制
///
///
///
private void Panel_Paint(object sender, PaintEventArgs e)
{
if (this.documentWorkspace.CompositionSurface != null)
{
//
// 以下是计算绘制图片的位置和大小并绘制图片
//
System.Drawing.Rectangle rc = this.documentWorkspace.panel.ClientRectangle;
int width = (int)(this.documentWorkspace.CompositionSurface.Width * this.documentWorkspace.ScaleFactor.Ratio);
int height = (int)(this.documentWorkspace.CompositionSurface.Height * this.documentWorkspace.ScaleFactor.Ratio);
int x = (rc.Width < width) ? this.documentWorkspace.panel.AutoScrollPosition.X : (rc.Width - width) / 2;
int y = (rc.Height < height) ? this.documentWorkspace.panel.AutoScrollPosition.Y : (rc.Height - height) / 2;
//
// 以下是绘制网格、标注、测量、视场等开始
//
e.Graphics.TranslateTransform(x, y);
e.Graphics.ScaleTransform((float)this.documentWorkspace.ScaleFactor.Ratio, (float)this.documentWorkspace.ScaleFactor.Ratio);
//if (this.checkBox4_0.Checked)//显示网格
Draw(e.Graphics);
e.Graphics.ScaleTransform(1 / (float)this.documentWorkspace.ScaleFactor.Ratio, 1 / (float)this.documentWorkspace.ScaleFactor.Ratio);
e.Graphics.TranslateTransform(-x, -y);
}
}
///
/// 绘制
///
private void Draw(Graphics g)
{
// 抗锯齿
g.SmoothingMode = SmoothingMode.AntiAlias;
//圆形删除/椭圆删除
if ((this.pointKtype == 14 || this.pointKtype == 12) && (this.rectangle.Width > 0 || this.rectangle.Height > 0))
{
Pen pen = new Pen(this.phaseColor, 1);
pen.DashStyle = System.Drawing.Drawing2D.DashStyle.Dot;
if (this.pointKtype == 14)
g.DrawEllipse(pen, this.rectangle);
else
g.DrawEllipse(pen, new RectangleF(this.rectangle.X, this.rectangle.Y, Math.Min(this.rectangle.Width, this.rectangle.Height), Math.Min(this.rectangle.Width, this.rectangle.Height)));
pen.Dispose();
}
//矩形删除
if (this.pointKtype == 13 && (this.rectangle.Width > 0 || this.rectangle.Height > 0))
{
Pen pen = new Pen(this.phaseColor, 1);
pen.DashStyle = System.Drawing.Drawing2D.DashStyle.Dot;
g.DrawRectangle(pen, new Rectangle((int)this.rectangle.X, (int)this.rectangle.Y, (int)this.rectangle.Width, (int)this.rectangle.Height));
pen.Dispose();
}
// 折线删除
if (this.pointKtype == 11 && pointArray.Count >= 2)
{
Pen pen = new Pen(this.phaseColor, 1);
pen.DashStyle = System.Drawing.Drawing2D.DashStyle.Dot;
g.DrawPolygon(pen, pointArray.ToArray());
pen.Dispose();
}
//Mat analyzeMat = this.documentWorkspace.PhaseModels[0].mat;
////int matWidth = analyzeMat.Width;
////int matHeight = analyzeMat.Height;
////////System.Drawing.Point tempPoint;// 0)
{
Pen pen = new Pen(this.phaseColor, this.trackBar1.Value);
bool findTempLineSuccess;
//Mat erzhi = new Mat(new OpenCvSharp.Size(this.bitmap.Size.Width, this.bitmap.Size.Height), MatType.CV_8UC4, new Scalar(0, 0, 0, 0));
//int Rows = this.bitmap.Height;// analyzeMat.Rows;
//int Cols = this.bitmap.Width;// analyzeMat.Cols;
//int[] point = new int[2];
foreach (System.Drawing.Point[] tempLine1 in analyzePoints)
{
//for (int y = 0; y < tempLine1.Length - 1; y++)
//{
// System.Drawing.Point point11 = new System.Drawing.Point(tempLine1[y].X, tempLine1[y].Y);
// System.Drawing.Point point12 = new System.Drawing.Point(tempLine1[y + 1].X, tempLine1[y + 1].Y);
// g.DrawLine(pen, point11, point12);
//}
g.DrawLines(pen, tempLine1);
}
}
// 直线添加
if (this.pointKtype == 2 && drawedStartPoint && this.endPoint.X > -1 && this.endPoint.Y > -1)
{
Pen pen = new Pen(this.phaseColor, this.trackBar1.Value);
//pen.DashStyle = DashStyle.Dash;
g.DrawLine(pen, startPoint.X, startPoint.Y, endPoint.X, endPoint.Y);
pen.Dispose();
}
// 折线添加
if (this.pointKtype == 1 && pointArray.Count >= 2)
{
Pen pen = new Pen(this.phaseColor, this.trackBar1.Value);
g.DrawLines(pen, pointArray.ToArray());
pen.Dispose();
}
//// 以下为绘制样式
//Pen linePen = new Pen(Color.FromArgb(this.lineColor), this.lineWidth);
//Pen pointPen1 = new Pen(Color.Yellow, this.pointWidth1);
//Pen pointPen2 = new Pen(Color.FromArgb(this.pointColor2), this.pointWidth2);
//Pen pointPen3 = new Pen(Color.FromArgb(this.pointColor3), this.pointWidth3);
//SolidBrush brush1 = new SolidBrush(Color.FromArgb(this.pointColor1));
//SolidBrush brush2 = new SolidBrush(Color.FromArgb(this.pointColor2));
//SolidBrush brush3 = new SolidBrush(Color.FromArgb(this.pointColor3));
//// 圆形
//if (grainSizeGuideAreaMethodModel.circularGuideStyles != null)
//{
// foreach (var circularGuideStyle in grainSizeGuideAreaMethodModel.circularGuideStyles)
// {
// if (this.comboBox1.SelectedItem.Equals(circularGuideStyle.tag))
// {
// graphics.DrawEllipse(linePen, this.rectangleFLine.X, this.rectangleFLine.Y, this.rectangleFLine.Width, this.rectangleFLine.Height);
// }
// }
//}
//// 矩形
//if (grainSizeGuideAreaMethodModel.rectangleGuideStyles != null)
//{
// foreach (var rectangleGuideStyle in grainSizeGuideAreaMethodModel.rectangleGuideStyles)
// {
// if (this.comboBox1.SelectedItem.Equals(rectangleGuideStyle.tag))
// {
// graphics.DrawRectangle(linePen, this.rectangleFLine.X, this.rectangleFLine.Y, this.rectangleFLine.Width, this.rectangleFLine.Height);
// }
// }
//}
//if (this.checkBox5_0.Checked && massLabelPoints.Count > 0)
//{
// int index = 0;
// Font myFont = new Font("宋体", 12/*, FontStyle.Bold*/);
// Brush bush = new SolidBrush(this.panel1.BackColor/*Color.Red*/);//填充的颜色
// foreach (var item in massLabelPoints)
// {
// graphics.DrawString("" + (++index), myFont, bush, (float)item.X - 5, (float)item.Y - 5);
// }
//}
}
private void InitializeLanguageText()
{
this.groupBox1.Text = PdnResources.GetString("Menu.operation.text");
this.button9.Text = PdnResources.GetString("CommonAction.Undo");
this.button2.Text = PdnResources.GetString("Menu.File.Close.Text");
this.button1.Text = PdnResources.GetString("Form.OkButton.Text");
this.groupBox2.Text = PdnResources.GetString("Menu.BinaryAction.Text");
this.button8.Text = PdnResources.GetString("Menu.Ellipsedelete.text");
this.button7.Text = PdnResources.GetString("Menu.BinaryAction.RectangleDelete.Text");
this.button6.Text = PdnResources.GetString("Menu.rounddelete.text");
this.button5.Text = PdnResources.GetString("Menu.BinaryAction.PolygonleDelete.Text");
this.label1.Text = PdnResources.GetString("Menu.Linewidth.text") + ":";
this.button4.Text = PdnResources.GetString("Menu.Lineadd.text");
this.button3.Text = PdnResources.GetString("Menu.Polylineadd.text");
this.groupBox7.Text = PdnResources.GetString("Menu.Preview.text");
this.Text = PdnResources.GetString("Menu.filter.text");
}
private void InitializeComponent()
{
this.groupBox1 = new System.Windows.Forms.GroupBox();
this.button9 = new System.Windows.Forms.Button();
this.button2 = new System.Windows.Forms.Button();
this.button1 = new System.Windows.Forms.Button();
this.groupBox2 = new System.Windows.Forms.GroupBox();
this.button8 = new System.Windows.Forms.Button();
this.trackBar1 = new System.Windows.Forms.TrackBar();
this.button7 = new System.Windows.Forms.Button();
this.trackBar2 = new PaintDotNet.CustomControl.TriangleTrackBar();
this.button6 = new System.Windows.Forms.Button();
this.textBox1 = new System.Windows.Forms.TextBox();
this.button5 = new System.Windows.Forms.Button();
this.label1 = new System.Windows.Forms.Label();
this.button4 = new System.Windows.Forms.Button();
this.button3 = new System.Windows.Forms.Button();
this.groupBox7 = new System.Windows.Forms.GroupBox();
this.groupBox1.SuspendLayout();
this.groupBox2.SuspendLayout();
((System.ComponentModel.ISupportInitialize)(this.trackBar1)).BeginInit();
this.SuspendLayout();
//
// groupBox1
//
this.groupBox1.Controls.Add(this.button9);
this.groupBox1.Controls.Add(this.button2);
this.groupBox1.Controls.Add(this.button1);
this.groupBox1.Location = new System.Drawing.Point(12, 12);
this.groupBox1.Name = "groupBox1";
this.groupBox1.Size = new System.Drawing.Size(808, 45);
this.groupBox1.TabIndex = 0;
this.groupBox1.TabStop = false;
//
// button9
//
this.button9.Location = new System.Drawing.Point(468, 13);
this.button9.Name = "button9";
this.button9.Size = new System.Drawing.Size(91, 26);
this.button9.TabIndex = 3;
this.button9.UseVisualStyleBackColor = true;
this.button9.Visible = false;
//
// button2
//
this.button2.Location = new System.Drawing.Point(694, 13);
this.button2.Name = "button2";
this.button2.Size = new System.Drawing.Size(91, 26);
this.button2.TabIndex = 1;
this.button2.UseVisualStyleBackColor = true;
this.button2.Click += new System.EventHandler(this.button2_Click);
//
// button1
//
this.button1.Location = new System.Drawing.Point(582, 13);
this.button1.Name = "button1";
this.button1.Size = new System.Drawing.Size(91, 26);
this.button1.TabIndex = 0;
this.button1.UseVisualStyleBackColor = true;
this.button1.Click += new System.EventHandler(this.button1_Click);
//
// groupBox2
//
this.groupBox2.Controls.Add(this.button8);
this.groupBox2.Controls.Add(this.trackBar1);
this.groupBox2.Controls.Add(this.button7);
this.groupBox2.Controls.Add(this.trackBar2);
this.groupBox2.Controls.Add(this.button6);
this.groupBox2.Controls.Add(this.textBox1);
this.groupBox2.Controls.Add(this.button5);
this.groupBox2.Controls.Add(this.label1);
this.groupBox2.Controls.Add(this.button4);
this.groupBox2.Controls.Add(this.button3);
this.groupBox2.Location = new System.Drawing.Point(12, 63);
this.groupBox2.Name = "groupBox2";
this.groupBox2.Size = new System.Drawing.Size(233, 199);
this.groupBox2.TabIndex = 1;
this.groupBox2.TabStop = false;
//
// button8
//
this.button8.Location = new System.Drawing.Point(134, 151);
this.button8.Name = "button8";
this.button8.Size = new System.Drawing.Size(73, 26);
this.button8.TabIndex = 7;
this.button8.UseVisualStyleBackColor = true;
this.button8.Click += new System.EventHandler(this.button8_Click);
//
// trackBar1
//
this.trackBar1.AutoSize = false;
this.trackBar1.Location = new System.Drawing.Point(107, 69);
this.trackBar1.Maximum = 50;
this.trackBar1.Minimum = 1;
this.trackBar1.Name = "trackBar1";
this.trackBar1.Size = new System.Drawing.Size(104, 31);
this.trackBar1.TabIndex = 21;
this.trackBar1.TickStyle = System.Windows.Forms.TickStyle.None;
this.trackBar1.Value = 1;
this.trackBar1.Scroll += new System.EventHandler(this.trackBar1_Scroll);
//
// button7
//
this.button7.Location = new System.Drawing.Point(27, 151);
this.button7.Name = "button7";
this.button7.Size = new System.Drawing.Size(73, 26);
this.button7.TabIndex = 6;
this.button7.UseVisualStyleBackColor = true;
this.button7.Click += new System.EventHandler(this.button7_Click);
//
// trackBar2
//
this.trackBar2.Location = new System.Drawing.Point(108, 69);
this.trackBar2.Maximum = 50;
this.trackBar2.Minimum = 1;
this.trackBar2.Name = "trackBar2";
this.trackBar2.Size = new System.Drawing.Size(102, 24);
this.trackBar2.TabIndex = 20;
this.trackBar2.Value = 1;
this.trackBar2.Visible = false;
//
// button6
//
this.button6.Location = new System.Drawing.Point(134, 107);
this.button6.Name = "button6";
this.button6.Size = new System.Drawing.Size(73, 26);
this.button6.TabIndex = 5;
this.button6.UseVisualStyleBackColor = true;
this.button6.Click += new System.EventHandler(this.button6_Click);
//
// textBox1
//
this.textBox1.Location = new System.Drawing.Point(68, 69);
this.textBox1.Name = "textBox1";
this.textBox1.Size = new System.Drawing.Size(32, 21);
this.textBox1.TabIndex = 19;
this.textBox1.Text = "1";
this.textBox1.TextChanged += new System.EventHandler(this.textBox1_TextChanged);
//
// button5
//
this.button5.Location = new System.Drawing.Point(27, 107);
this.button5.Name = "button5";
this.button5.Size = new System.Drawing.Size(73, 26);
this.button5.TabIndex = 4;
this.button5.UseVisualStyleBackColor = true;
this.button5.Click += new System.EventHandler(this.button5_Click);
//
// label1
//
this.label1.AutoSize = true;
this.label1.Location = new System.Drawing.Point(28, 73);
this.label1.Name = "label1";
this.label1.Size = new System.Drawing.Size(0, 12);
this.label1.TabIndex = 18;
//
// button4
//
this.button4.Location = new System.Drawing.Point(135, 31);
this.button4.Name = "button4";
this.button4.Size = new System.Drawing.Size(73, 26);
this.button4.TabIndex = 3;
this.button4.UseVisualStyleBackColor = true;
this.button4.Click += new System.EventHandler(this.button4_Click);
//
// button3
//
this.button3.Location = new System.Drawing.Point(28, 31);
this.button3.Name = "button3";
this.button3.Size = new System.Drawing.Size(73, 26);
this.button3.TabIndex = 2;
this.button3.UseVisualStyleBackColor = true;
this.button3.Click += new System.EventHandler(this.button3_Click);
//
// groupBox7
//
this.groupBox7.Location = new System.Drawing.Point(251, 63);
this.groupBox7.Name = "groupBox7";
this.groupBox7.Size = new System.Drawing.Size(569, 502);
this.groupBox7.TabIndex = 1;
this.groupBox7.TabStop = false;
//
// MetalsBoundaryEditingDialog
//
this.ClientSize = new System.Drawing.Size(832, 577);
this.Controls.Add(this.groupBox2);
this.Controls.Add(this.groupBox7);
this.Controls.Add(this.groupBox1);
this.MaximizeBox = false;
this.MinimizeBox = false;
this.Name = "MetalsBoundaryEditingDialog";
this.groupBox1.ResumeLayout(false);
this.groupBox2.ResumeLayout(false);
this.groupBox2.PerformLayout();
((System.ComponentModel.ISupportInitialize)(this.trackBar1)).EndInit();
this.ResumeLayout(false);
}
///
/// 折线添加
///
///
///
private void button3_Click(object sender, EventArgs e)
{
pointArray.Clear();
startPoint = new Point(-1, -1);
drawedStartPoint = false;
endPoint = new Point(-1, -1);
pointKtype = 1;
this.documentWorkspace.Refresh();
}
///
/// 直线添加
///
///
///
private void button4_Click(object sender, EventArgs e)
{
startPoint = new Point(-1, -1);
drawedStartPoint = false;
endPoint = new Point(-1, -1);
pointKtype = 2;
this.documentWorkspace.Refresh();
}
private void InitCommonButtonEvent()
{
this.commonControlButtons.zoomInButton.Click += new EventHandler(zoomInButton_Click);
this.commonControlButtons.zoomOutButton.Click += new EventHandler(zoomOutButton_Click);
this.commonControlButtons.zoomToWindowButton.Click += new EventHandler(zoomToWindowButton_Click);
this.commonControlButtons.actualSizeButton.Click += new EventHandler(actualSizeButton_Click);
this.commonControlButtons.pointerButton.Click += new EventHandler(pointerButton_Click);
this.commonControlButtons.mobileModeButton.Click += new EventHandler(mobileModeButton_Click);
}
private void zoomInButton_Click(object sender, EventArgs e)
{
this.documentWorkspace.ZoomIn();
}
private void zoomOutButton_Click(object sender, EventArgs e)
{
this.documentWorkspace.ZoomOut();
}
private void zoomToWindowButton_Click(object sender, EventArgs e)
{
this.documentWorkspace.ZoomBasis = ZoomBasis.FitToWindow;
}
private void actualSizeButton_Click(object sender, EventArgs e)
{
this.documentWorkspace.ZoomBasis = ZoomBasis.ScaleFactor;
this.documentWorkspace.ScaleFactor = ScaleFactor.OneToOne;
}
private void pointerButton_Click(object sender, EventArgs e)
{
this.documentWorkspace.ActiveTool = Annotation.Enum.DrawToolType.InclusionNoEffect;
this.documentWorkspace.Cursor = Cursors.Default;
}
private void mobileModeButton_Click(object sender, EventArgs e)
{
this.documentWorkspace.ActiveTool = Annotation.Enum.DrawToolType.MoveMode;
}
//确定按钮点击事件
private void button1_Click(object sender, EventArgs e)
{
this.phaseMatCopy = this.documentWorkspace.PhaseModels[0].mat;
this.DialogResult = DialogResult.OK;
this.Close();
}
///
/// 用于get处理后的图像
///
public List AnalyzePoints
{
get
{
return this.analyzePoints;
}
//set
//{
// this.analyzePoints = value;
//}
}
///
/// 矩形删除
///
///
///
private void button7_Click(object sender, EventArgs e)
{
startPoint = new Point(-1, -1);
drawedStartPoint = false;
endPoint = new Point(-1, -1);
this.rectangle.X = -1;
this.rectangle.Y = -1;
this.rectangle.Width = 0;
this.rectangle.Height = 0;
this.pointKtype = 13;
this.documentWorkspace.Refresh();
}
///
/// 椭圆删除
///
///
///
private void button8_Click(object sender, EventArgs e)
{
startPoint = new Point(-1, -1);
drawedStartPoint = false;
endPoint = new Point(-1, -1);
this.rectangle.X = -1;
this.rectangle.Y = -1;
this.rectangle.Width = 0;
this.rectangle.Height = 0;
this.pointKtype = 14;
this.documentWorkspace.Refresh();
}
///
/// 圆形删除
///
///
///
private void button6_Click(object sender, EventArgs e)
{
startPoint = new Point(-1, -1);
drawedStartPoint = false;
endPoint = new Point(-1, -1);
this.rectangle.X = -1;
this.rectangle.Y = -1;
this.rectangle.Width = 0;
this.rectangle.Height = 0;
this.pointKtype = 12;
this.documentWorkspace.Refresh();
}
///
/// 多边形删除
///
///
///
private void button5_Click(object sender, EventArgs e)
{
pointArray.Clear();
startPoint = new Point(-1, -1);
drawedStartPoint = false;
endPoint = new Point(-1, -1);
this.rectangle.X = -1;
this.rectangle.Y = -1;
this.rectangle.Width = 0;
this.rectangle.Height = 0;
this.pointKtype = 11;
this.documentWorkspace.Refresh();
}
private void button2_Click(object sender, EventArgs e)
{
this.Close();
}
///
/// 线宽改变
///
///
///
private void textBox1_TextChanged(object sender, EventArgs e)
{
int valueT;
if (!int.TryParse(textBox1.Text, out valueT))
return;
if (this.trackBar1.Minimum > valueT)
valueT = this.trackBar1.Minimum;
if (this.trackBar1.Maximum < valueT)
valueT = this.trackBar1.Maximum;
this.trackBar1.Value = valueT;
//this.textBox1.Text = valueT + "";
this.documentWorkspace.Refresh();
}
private void trackBar1_Scroll(object sender, EventArgs e)
{
this.textBox1.Text = this.trackBar1.Value + "";
this.documentWorkspace.Refresh();
}
}
}