可以移动textbox
更改错误提示 修改多边形
This commit is contained in:
parent
5e8b5c4cb0
commit
424c9b9aaa
@ -127,7 +127,7 @@ namespace PBAnaly.Module
|
|||||||
private const int CircleRadius = 5;
|
private const int CircleRadius = 5;
|
||||||
private bool lineOn =false;
|
private bool lineOn =false;
|
||||||
private bool drawLine = false;
|
private bool drawLine = false;
|
||||||
private bool drawTextbox = false;// 绘制textbox的标签
|
private bool TextboxOn = false;// 绘制textbox的标签
|
||||||
|
|
||||||
|
|
||||||
private bool CircleOn = false;
|
private bool CircleOn = false;
|
||||||
@ -158,7 +158,9 @@ namespace PBAnaly.Module
|
|||||||
private CirceAndInfo cireOriginalCire;
|
private CirceAndInfo cireOriginalCire;
|
||||||
|
|
||||||
private List<TextBoxInfo> textBoxInfos = new List<TextBoxInfo>();
|
private List<TextBoxInfo> textBoxInfos = new List<TextBoxInfo>();
|
||||||
|
private bool drawTextBox = false;
|
||||||
private int curTextBox = -1;
|
private int curTextBox = -1;
|
||||||
|
private TextBoxInfo curTextBoxinfo;
|
||||||
private List<RectAttribute> wandRectangle = new List<RectAttribute>(); // 存储所有绘制完成的矩形
|
private List<RectAttribute> wandRectangle = new List<RectAttribute>(); // 存储所有绘制完成的矩形
|
||||||
private bool drawpolygon = false;
|
private bool drawpolygon = false;
|
||||||
private List<PolygonAndInfo> PolygonAndInfoList = new List<PolygonAndInfo>();
|
private List<PolygonAndInfo> PolygonAndInfoList = new List<PolygonAndInfo>();
|
||||||
@ -530,12 +532,12 @@ namespace PBAnaly.Module
|
|||||||
}
|
}
|
||||||
if (image_mark_L16 == null)
|
if (image_mark_L16 == null)
|
||||||
{
|
{
|
||||||
MessageBox.Show("缺少mark图 请检查文件夹中是否存在mark图");
|
MessageBox.Show("样品图加载不正确,请重新加载.....");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (image_org_L16 == null)
|
if (image_org_L16 == null)
|
||||||
{
|
{
|
||||||
MessageBox.Show("缺少为彩图 请检查文件夹中是否存在伪彩图");
|
MessageBox.Show("缺少伪彩图 请检查文件夹中是否存在伪彩图");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
imagePanel.SetButtomLabel($"{image_mark_L16.Width} x {image_mark_L16.Height}");
|
imagePanel.SetButtomLabel($"{image_mark_L16.Width} x {image_mark_L16.Height}");
|
||||||
@ -1158,7 +1160,7 @@ namespace PBAnaly.Module
|
|||||||
index++;
|
index++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (drawRect)
|
if (drawRect|| drawTextBox)
|
||||||
{
|
{
|
||||||
if (currentRectangle.HasValue)
|
if (currentRectangle.HasValue)
|
||||||
{
|
{
|
||||||
@ -1288,22 +1290,7 @@ namespace PBAnaly.Module
|
|||||||
{
|
{
|
||||||
int isStart = 0;
|
int isStart = 0;
|
||||||
System.Drawing.Point point = new System.Drawing.Point();
|
System.Drawing.Point point = new System.Drawing.Point();
|
||||||
foreach (var item1 in PolygonAndInfoList)
|
|
||||||
{
|
|
||||||
foreach (var item in item1.points)
|
|
||||||
{
|
|
||||||
if (isStart == 0)
|
|
||||||
{
|
|
||||||
point = ImageProcess.ConvertRealToPictureBox( item,imagePanel.image_pl);
|
|
||||||
}
|
|
||||||
System.Drawing.Point curpoint = ImageProcess.ConvertRealToPictureBox(item, imagePanel.image_pl);
|
|
||||||
ImageProcess.DrawCircle(g, curpoint, CircleRadius, Pens.Blue, Brushes.LightBlue);
|
|
||||||
g.DrawLine(Pens.Red, curpoint, point);
|
|
||||||
point = curpoint;
|
|
||||||
isStart++;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
if (drawpolygon)
|
if (drawpolygon)
|
||||||
{
|
{
|
||||||
@ -1326,6 +1313,22 @@ namespace PBAnaly.Module
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
foreach (var item1 in PolygonAndInfoList)
|
||||||
|
{
|
||||||
|
foreach (var item in item1.points)
|
||||||
|
{
|
||||||
|
if (isStart == 0)
|
||||||
|
{
|
||||||
|
point = ImageProcess.ConvertRealToPictureBox(item, imagePanel.image_pl);
|
||||||
|
}
|
||||||
|
System.Drawing.Point curpoint = ImageProcess.ConvertRealToPictureBox(item, imagePanel.image_pl);
|
||||||
|
ImageProcess.DrawCircle(g, curpoint, CircleRadius, Pens.Blue, Brushes.LightBlue);
|
||||||
|
g.DrawLine(Pens.Red, curpoint, point);
|
||||||
|
point = curpoint;
|
||||||
|
isStart++;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
if (curPolygonAndInfoList.pdinfovc != null)
|
if (curPolygonAndInfoList.pdinfovc != null)
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -1350,21 +1353,33 @@ namespace PBAnaly.Module
|
|||||||
}
|
}
|
||||||
index++;
|
index++;
|
||||||
}
|
}
|
||||||
|
index = 0;
|
||||||
foreach (var textBoxInfo in textBoxInfos)
|
foreach (var textBoxInfo in textBoxInfos)
|
||||||
{
|
{
|
||||||
System.Drawing.Rectangle p = textBoxInfo.rect;
|
System.Drawing.Rectangle p = textBoxInfo.rect;
|
||||||
//if (isTextBoxRecDragging)
|
if (isTextBoxRecDragging)
|
||||||
//{
|
{
|
||||||
// if (index == rectDragStartIndex)
|
if (index == rectDragStartIndex)
|
||||||
// {
|
{
|
||||||
// p = recDragRect;
|
p = recDragRect;
|
||||||
|
|
||||||
// }
|
}
|
||||||
//}
|
}
|
||||||
var r = ImageProcess.ConvertRealRectangleToPictureBox(p, imagePanel.image_pl);
|
var r = ImageProcess.ConvertRealRectangleToPictureBox(p, imagePanel.image_pl);
|
||||||
e.Graphics.DrawRectangle(Pens.Red, r);
|
e.Graphics.DrawRectangle(Pens.Red, r);
|
||||||
|
|
||||||
|
System.Drawing.Point[] corners = new System.Drawing.Point[]
|
||||||
|
{
|
||||||
|
new System.Drawing.Point(r.Left, r.Top), // 左上角
|
||||||
|
new System.Drawing.Point(r.Right, r.Top), // 右上角
|
||||||
|
new System.Drawing.Point(r.Left, r.Bottom), // 左下角
|
||||||
|
new System.Drawing.Point(r.Right, r.Bottom) // 右下角
|
||||||
|
};
|
||||||
|
foreach (var item in corners)
|
||||||
|
{
|
||||||
|
|
||||||
|
ImageProcess.DrawCircle(g, new System.Drawing.Point(item.X, item.Y), 2, Pens.Blue, Brushes.LightBlue);
|
||||||
|
}
|
||||||
|
|
||||||
// 居中显示值
|
// 居中显示值
|
||||||
StringFormat sf = new StringFormat();
|
StringFormat sf = new StringFormat();
|
||||||
@ -1372,6 +1387,7 @@ namespace PBAnaly.Module
|
|||||||
sf.LineAlignment = StringAlignment.Center;
|
sf.LineAlignment = StringAlignment.Center;
|
||||||
Font customFont = new Font("Arial", 12, FontStyle.Bold);
|
Font customFont = new Font("Arial", 12, FontStyle.Bold);
|
||||||
g.DrawString(textBoxInfo.value, customFont, Brushes.Red, r, sf);
|
g.DrawString(textBoxInfo.value, customFont, Brushes.Red, r, sf);
|
||||||
|
index++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1401,6 +1417,92 @@ namespace PBAnaly.Module
|
|||||||
imagePaletteForm.flb_act_mm.Text = value.ToString() + " mm";
|
imagePaletteForm.flb_act_mm.Text = value.ToString() + " mm";
|
||||||
imagePaletteForm.flb_act_mm.Refresh();
|
imagePaletteForm.flb_act_mm.Refresh();
|
||||||
}
|
}
|
||||||
|
else if (drawTextBox)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (currentRectangle.HasValue)
|
||||||
|
{
|
||||||
|
TextBoxInfo textBoxInfo = new TextBoxInfo();
|
||||||
|
imagePaletteForm.dtb_textbox.Text = "info";
|
||||||
|
textBoxInfo.value = "info";
|
||||||
|
textBoxInfo.rect = currentRectangle.Value;
|
||||||
|
|
||||||
|
if (textBoxInfos.Count == 0)
|
||||||
|
{
|
||||||
|
textBoxInfo.index = 0;
|
||||||
|
}
|
||||||
|
else if (textBoxInfos.Count == 1)
|
||||||
|
{
|
||||||
|
if (textBoxInfos[0].index == 0)
|
||||||
|
{
|
||||||
|
textBoxInfo.index = 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
textBoxInfo.index = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
List<int> ints = new List<int>();
|
||||||
|
foreach (var i in textBoxInfos)
|
||||||
|
{
|
||||||
|
ints.Add(i.index);
|
||||||
|
}
|
||||||
|
ints.Sort();
|
||||||
|
|
||||||
|
Random rand = new Random();
|
||||||
|
int potentialInt;
|
||||||
|
|
||||||
|
|
||||||
|
int lowerBound = 0;
|
||||||
|
int upperBound = 65535;
|
||||||
|
|
||||||
|
while (true)
|
||||||
|
{
|
||||||
|
potentialInt = rand.Next(lowerBound, upperBound + 1);
|
||||||
|
if (ints.Contains(potentialInt) == false)
|
||||||
|
{
|
||||||
|
textBoxInfo.index = potentialInt;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// 完成绘制并保存矩形
|
||||||
|
if (Arrangement == 2)
|
||||||
|
{
|
||||||
|
foreach (var item in bioanalysisMannages)
|
||||||
|
{
|
||||||
|
|
||||||
|
item.Value.textBoxInfos.Add(textBoxInfo);
|
||||||
|
item.Value.curTextBox = textBoxInfos.Count - 1;
|
||||||
|
item.Value.drawTextBox = false;
|
||||||
|
item.Value.currentRectangle = null;
|
||||||
|
item.Value.imagePanel.image_pl.Invalidate();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
|
||||||
|
textBoxInfos.Add(textBoxInfo);
|
||||||
|
curTextBox = textBoxInfos.Count - 1;
|
||||||
|
drawTextBox = false;
|
||||||
|
currentRectangle = null;
|
||||||
|
imagePanel.image_pl.Invalidate();
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
imagePaletteForm.SetInfo = "w:" + textBoxInfo.rect.Width.ToString() + "h:" + textBoxInfo.rect.Height.ToString();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
drawTextBox = false;
|
||||||
|
if (!isContinuous)
|
||||||
|
TextboxOn = false;
|
||||||
|
}
|
||||||
else if (drawRect)
|
else if (drawRect)
|
||||||
{
|
{
|
||||||
if (currentRectangle.HasValue)
|
if (currentRectangle.HasValue)
|
||||||
@ -1531,38 +1633,45 @@ namespace PBAnaly.Module
|
|||||||
}
|
}
|
||||||
else if (isTextBoxRecDragging)
|
else if (isTextBoxRecDragging)
|
||||||
{
|
{
|
||||||
|
TextBoxInfo rattb = new TextBoxInfo();
|
||||||
|
rattb.rect = recDragRect;
|
||||||
|
rattb.value = textBoxInfos[rectDragStartIndex].value;
|
||||||
|
rattb.index = textBoxInfos[rectDragStartIndex].index;
|
||||||
|
|
||||||
|
|
||||||
|
if (Arrangement == 2)
|
||||||
|
{
|
||||||
|
foreach (var item in bioanalysisMannages)
|
||||||
|
{
|
||||||
|
for (int i = 0; i < item.Value.textBoxInfos.Count; i++)
|
||||||
|
{
|
||||||
|
if (item.Value.textBoxInfos[i].index == rattb.index)
|
||||||
|
{
|
||||||
|
item.Value.textBoxInfos[i] = rattb;
|
||||||
|
item.Value.isTextBoxRecDragging = false;
|
||||||
|
item.Value.rectActiveCorner = Corner.None;
|
||||||
|
item.Value.rectDragStartIndex = -1;
|
||||||
|
item.Value.imagePanel.image_pl.Invalidate();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
textBoxInfos[rectDragStartIndex] = rattb;
|
||||||
|
isTextBoxRecDragging = false;
|
||||||
|
rectActiveCorner = Corner.None;
|
||||||
|
rectDragStartIndex = -1;
|
||||||
|
imagePanel.image_pl.Invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
|
imagePaletteForm.SetInfo = "w:" + recDragRect.Width.ToString() + "h:" + recDragRect.Height.ToString();
|
||||||
|
|
||||||
//if (Arrangement == 2)
|
|
||||||
//{
|
|
||||||
// //for (int i = 0; i < textBoxInfos.Count; i++)
|
|
||||||
// //{
|
|
||||||
// // TextBoxInfo textBoxInfo = new TextBoxInfo();
|
|
||||||
// // textBoxInfo.rect = recDragRect;
|
|
||||||
// // textBoxInfo.value = textBoxInfos[rectDragStartIndex].value;
|
|
||||||
// // textBoxInfo.index = textBoxInfos[rectDragStartIndex].index;
|
|
||||||
// // item = textBoxInfo;
|
|
||||||
// //}
|
|
||||||
// //foreach (var item in textBoxInfos)
|
|
||||||
// //{
|
|
||||||
|
|
||||||
// //}
|
|
||||||
//}
|
|
||||||
//else
|
|
||||||
//{
|
|
||||||
// TextBoxInfo textBoxInfo = new TextBoxInfo();
|
|
||||||
// textBoxInfo.rect = recDragRect;
|
|
||||||
// textBoxInfo.value = textBoxInfos[rectDragStartIndex].value;
|
|
||||||
// textBoxInfo.index = textBoxInfos[rectDragStartIndex].index;
|
|
||||||
// textBoxInfos[rectDragStartIndex] = textBoxInfo;
|
|
||||||
//}
|
|
||||||
|
|
||||||
//imagePaletteForm.SetInfo = "w:" + recDragRect.Width.ToString() + "h:" + recDragRect.Height.ToString();
|
|
||||||
//isRecDragging = false;
|
|
||||||
//rectActiveCorner = Corner.None;
|
|
||||||
//rectDragStartIndex = -1;
|
|
||||||
|
|
||||||
//imagePanel.image_pl.Invalidate();
|
|
||||||
//isTextBoxRecDragging = false;
|
|
||||||
}
|
}
|
||||||
else if (isRecDragging)
|
else if (isRecDragging)
|
||||||
{
|
{
|
||||||
@ -1678,6 +1787,17 @@ namespace PBAnaly.Module
|
|||||||
endPoint = readLoction; // 更新终点位置
|
endPoint = readLoction; // 更新终点位置
|
||||||
imagePanel.image_pl.Invalidate(); // 触发重绘
|
imagePanel.image_pl.Invalidate(); // 触发重绘
|
||||||
}
|
}
|
||||||
|
else if (drawTextBox && e.Button == MouseButtons.Left)
|
||||||
|
{
|
||||||
|
// 动态调整矩形大小
|
||||||
|
int x = Math.Min(leftTopPoint.X, readLoction.X);
|
||||||
|
int y = Math.Min(leftTopPoint.Y, readLoction.Y);
|
||||||
|
int width = Math.Abs(readLoction.X - leftTopPoint.X);
|
||||||
|
int height = Math.Abs(readLoction.Y - leftTopPoint.Y);
|
||||||
|
imagePaletteForm.SetInfo = "w:" + width + "h:" + height;
|
||||||
|
currentRectangle = new System.Drawing.Rectangle(x, y, width, height);
|
||||||
|
imagePanel.image_pl.Invalidate(); // 触发重绘
|
||||||
|
}
|
||||||
else if (drawRect && e.Button == MouseButtons.Left)
|
else if (drawRect && e.Button == MouseButtons.Left)
|
||||||
{
|
{
|
||||||
// 动态调整矩形大小
|
// 动态调整矩形大小
|
||||||
@ -1728,7 +1848,7 @@ namespace PBAnaly.Module
|
|||||||
}
|
}
|
||||||
else if (isTextBoxRecDragging)
|
else if (isTextBoxRecDragging)
|
||||||
{
|
{
|
||||||
recDragRect = rectOriginalRect.rect;
|
recDragRect = curTextBoxinfo.rect;
|
||||||
switch (rectActiveCorner)
|
switch (rectActiveCorner)
|
||||||
{
|
{
|
||||||
case Corner.drawMouse:
|
case Corner.drawMouse:
|
||||||
@ -1890,8 +2010,9 @@ namespace PBAnaly.Module
|
|||||||
double deltaX = lastPoint.X - firstPoint.X;
|
double deltaX = lastPoint.X - firstPoint.X;
|
||||||
double deltaY = lastPoint.Y - firstPoint.Y;
|
double deltaY = lastPoint.Y - firstPoint.Y;
|
||||||
var value = Math.Sqrt(deltaX * deltaX + deltaY * deltaY);
|
var value = Math.Sqrt(deltaX * deltaX + deltaY * deltaY);
|
||||||
if (value <= 5)
|
if (value <= 10)
|
||||||
{
|
{
|
||||||
|
PolygonAndInfoList.Clear();
|
||||||
lastPoint = firstPoint;
|
lastPoint = firstPoint;
|
||||||
drawpolygon = false;
|
drawpolygon = false;
|
||||||
linepolygonON = false;
|
linepolygonON = false;
|
||||||
@ -1902,39 +2023,57 @@ namespace PBAnaly.Module
|
|||||||
float _max = algAttribute.colorValue;
|
float _max = algAttribute.colorValue;
|
||||||
float _min = algAttribute.colorMinValue;
|
float _min = algAttribute.colorMinValue;
|
||||||
List<Point_VC> curVclist = new List<Point_VC>();
|
List<Point_VC> curVclist = new List<Point_VC>();
|
||||||
Pseudo_infoVC curpdinfovc = null;
|
|
||||||
foreach (var item in curPolygonAndInfoList.points)
|
foreach (var item in curPolygonAndInfoList.points)
|
||||||
{
|
{
|
||||||
Point_VC pvc = new Point_VC(item.X, item.Y);
|
Point_VC pvc = new Point_VC(item.X, item.Y);
|
||||||
curVclist.Add(pvc);
|
curVclist.Add(pvc);
|
||||||
|
|
||||||
}
|
}
|
||||||
unsafe
|
|
||||||
{
|
|
||||||
fixed (byte* pseu_16_byte_src = image_org_byte)
|
|
||||||
{
|
|
||||||
curpdinfovc = pbpvc.get_pseudo_info_polygon_vc(pseu_16_byte_src, 16,
|
|
||||||
(ushort)image_org_L16.Width, (ushort)image_org_L16.Height, _max, _min, curVclist);
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
curPolygonAndInfoList.pdinfovc = curpdinfovc;
|
|
||||||
if (Arrangement == 2)
|
if (Arrangement == 2)
|
||||||
{
|
{
|
||||||
foreach (var item in bioanalysisMannages)
|
foreach (var item in bioanalysisMannages)
|
||||||
{
|
{
|
||||||
item.Value.PolygonAndInfoList.Add(curPolygonAndInfoList);
|
item.Value.PolygonAndInfoList.Clear();
|
||||||
|
item.Value.curPolygonAndInfoList.pdinfovc = null;
|
||||||
|
Pseudo_infoVC curpdinfovc = null;
|
||||||
|
unsafe
|
||||||
|
{
|
||||||
|
fixed (byte* pseu_16_byte_src = item.Value.image_org_byte)
|
||||||
|
{
|
||||||
|
curpdinfovc = item.Value.pbpvc.get_pseudo_info_polygon_vc(pseu_16_byte_src, 16,
|
||||||
|
(ushort)image_org_L16.Width, (ushort)image_org_L16.Height, _max, _min, curVclist);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
item.Value.curPolygonAndInfoList.points = curPolygonAndInfoList.points;
|
||||||
|
item.Value.curPolygonAndInfoList.pdinfovc = curpdinfovc;
|
||||||
|
item.Value.PolygonAndInfoList.Add(item.Value.curPolygonAndInfoList);
|
||||||
|
item.Value.imagePanel.image_pl.Invalidate();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
Pseudo_infoVC curpdinfovc = null;
|
||||||
|
unsafe
|
||||||
|
{
|
||||||
|
fixed (byte* pseu_16_byte_src = image_org_byte)
|
||||||
|
{
|
||||||
|
curpdinfovc = pbpvc.get_pseudo_info_polygon_vc(pseu_16_byte_src, 16,
|
||||||
|
(ushort)image_org_L16.Width, (ushort)image_org_L16.Height, _max, _min, curVclist);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
curPolygonAndInfoList.pdinfovc = curpdinfovc;
|
||||||
PolygonAndInfoList.Add(curPolygonAndInfoList);
|
PolygonAndInfoList.Add(curPolygonAndInfoList);
|
||||||
|
imagePanel.image_pl.Invalidate();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
imagePanel.image_pl.Invalidate();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1951,12 +2090,19 @@ namespace PBAnaly.Module
|
|||||||
curTmpDownShapePoint = readLoction;
|
curTmpDownShapePoint = readLoction;
|
||||||
if (IsPointInRectangles(readLoction, textBoxInfos, out var cner3, out var cr3, out var index3)) // 遍历是否在所有矩形或者角点附近
|
if (IsPointInRectangles(readLoction, textBoxInfos, out var cner3, out var cr3, out var index3)) // 遍历是否在所有矩形或者角点附近
|
||||||
{
|
{
|
||||||
imagePaletteForm.dtb_textbox.Text = cr3.value;
|
rectActiveCorner = cner3;
|
||||||
curTextBox = index3;
|
|
||||||
isTextBoxRecDragging = true;
|
if (rectActiveCorner != Corner.None)
|
||||||
recDragStart = readLoction;
|
{
|
||||||
rectDragStartIndex = index3;
|
curTmpDownShape = ShapeForm.TextBoxRect;
|
||||||
recDragStart = readLoction;
|
curTextBox = index3;
|
||||||
|
isTextBoxRecDragging = true;
|
||||||
|
recDragStart = readLoction;
|
||||||
|
curTextBoxinfo = cr3;
|
||||||
|
rectDragStartIndex = index3;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
else if (IsPointInRectangles(readLoction, rectangles, out var cner, out var cr, out var index))
|
else if (IsPointInRectangles(readLoction, rectangles, out var cner, out var cr, out var index))
|
||||||
{
|
{
|
||||||
@ -1988,49 +2134,13 @@ namespace PBAnaly.Module
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
else if (drawTextbox)
|
else if (TextboxOn)
|
||||||
{
|
{
|
||||||
TextBoxInfo textBoxInfo = new TextBoxInfo();
|
// 开始绘制新矩形
|
||||||
imagePaletteForm.dtb_textbox.Text = "info";
|
drawTextBox = true;
|
||||||
textBoxInfo.value = "info";
|
leftTopPoint = readLoction;
|
||||||
textBoxInfo.rect = new System.Drawing.Rectangle(readLoction.X, readLoction.Y, 250, 70);
|
currentRectangle = new System.Drawing.Rectangle(readLoction.X, readLoction.Y, 0, 0);
|
||||||
if (textBoxInfos.Count == 0)
|
|
||||||
{
|
|
||||||
textBoxInfo.index = 0;
|
|
||||||
}
|
|
||||||
else if (textBoxInfos.Count == 1)
|
|
||||||
{
|
|
||||||
if (textBoxInfos[0].index == 0)
|
|
||||||
{
|
|
||||||
textBoxInfo.index = 1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
textBoxInfo.index = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
List<int> ints = new List<int>();
|
|
||||||
foreach (var i in textBoxInfos)
|
|
||||||
{
|
|
||||||
ints.Add(i.index);
|
|
||||||
}
|
|
||||||
ints.Sort();
|
|
||||||
for (int i = 0; i < ints.Count; i++)
|
|
||||||
{
|
|
||||||
if (ints[i] != i)
|
|
||||||
{
|
|
||||||
textBoxInfo.index = i;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
textBoxInfos.Add(textBoxInfo);
|
|
||||||
curTextBox = textBoxInfos.Count - 1;
|
|
||||||
drawTextbox = false;
|
|
||||||
imagePanel.image_pl.Invalidate();
|
|
||||||
}
|
}
|
||||||
else if (iswandON)
|
else if (iswandON)
|
||||||
{
|
{
|
||||||
@ -2087,6 +2197,16 @@ namespace PBAnaly.Module
|
|||||||
circleRadio = readLoction;
|
circleRadio = readLoction;
|
||||||
circleCenter = readLoction;
|
circleCenter = readLoction;
|
||||||
}
|
}
|
||||||
|
else if (drawpolygon)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (curPolygonAndInfoList.points == null)
|
||||||
|
{
|
||||||
|
curPolygonAndInfoList.points = new List<System.Drawing.Point>();
|
||||||
|
}
|
||||||
|
System.Drawing.Point curPoint = readLoction;
|
||||||
|
curPolygonAndInfoList.points.Add(curPoint);
|
||||||
|
}
|
||||||
else if (linepolygonON)
|
else if (linepolygonON)
|
||||||
{
|
{
|
||||||
drawpolygon = true;
|
drawpolygon = true;
|
||||||
@ -2094,6 +2214,10 @@ namespace PBAnaly.Module
|
|||||||
{
|
{
|
||||||
curPolygonAndInfoList.points = new List<System.Drawing.Point>();
|
curPolygonAndInfoList.points = new List<System.Drawing.Point>();
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
curPolygonAndInfoList.points.Clear();
|
||||||
|
}
|
||||||
System.Drawing.Point curPoint = readLoction;
|
System.Drawing.Point curPoint = readLoction;
|
||||||
curPolygonAndInfoList.points.Add(curPoint);
|
curPolygonAndInfoList.points.Add(curPoint);
|
||||||
}
|
}
|
||||||
@ -2539,12 +2663,28 @@ namespace PBAnaly.Module
|
|||||||
{
|
{
|
||||||
if (imagePaletteForm.dtb_textbox.Text != textBoxInfos[curTextBox].value)
|
if (imagePaletteForm.dtb_textbox.Text != textBoxInfos[curTextBox].value)
|
||||||
{
|
{
|
||||||
TextBoxInfo textBoxInfo = new TextBoxInfo();
|
if (Arrangement == 2)
|
||||||
textBoxInfo.value = imagePaletteForm.dtb_textbox.Text;
|
{
|
||||||
textBoxInfo.rect = textBoxInfos[curTextBox].rect;
|
foreach (var item in bioanalysisMannages)
|
||||||
textBoxInfo.index = textBoxInfos[curTextBox].index;
|
{
|
||||||
textBoxInfos[curTextBox] = textBoxInfo;
|
TextBoxInfo textBoxInfo = new TextBoxInfo();
|
||||||
imagePanel.image_pl.Invalidate();
|
textBoxInfo.value = imagePaletteForm.dtb_textbox.Text;
|
||||||
|
textBoxInfo.rect = textBoxInfos[curTextBox].rect;
|
||||||
|
textBoxInfo.index = textBoxInfos[curTextBox].index;
|
||||||
|
item.Value.textBoxInfos[curTextBox] = textBoxInfo;
|
||||||
|
item.Value.imagePanel.image_pl.Invalidate();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
TextBoxInfo textBoxInfo = new TextBoxInfo();
|
||||||
|
textBoxInfo.value = imagePaletteForm.dtb_textbox.Text;
|
||||||
|
textBoxInfo.rect = textBoxInfos[curTextBox].rect;
|
||||||
|
textBoxInfo.index = textBoxInfos[curTextBox].index;
|
||||||
|
textBoxInfos[curTextBox] = textBoxInfo;
|
||||||
|
imagePanel.image_pl.Invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -2552,7 +2692,7 @@ namespace PBAnaly.Module
|
|||||||
|
|
||||||
private void Ava_textbox_Click(object sender, EventArgs e)
|
private void Ava_textbox_Click(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
drawTextbox = true;
|
TextboxOn = true;
|
||||||
}
|
}
|
||||||
private void Cb_continuous_CheckedChanged(object sender, BoolEventArgs e)
|
private void Cb_continuous_CheckedChanged(object sender, BoolEventArgs e)
|
||||||
{
|
{
|
||||||
|
@ -135,7 +135,9 @@ PBBiologyVC::Pseudo_infoVC^ PBBiologyVC::PBImageProcessVC::get_pseudo_info_wand_
|
|||||||
cv::Mat image_8bit;
|
cv::Mat image_8bit;
|
||||||
cv::normalize(image, image_8bit, 0, 255, cv::NORM_MINMAX); // 归一化到 0-255
|
cv::normalize(image, image_8bit, 0, 255, cv::NORM_MINMAX); // 归一化到 0-255
|
||||||
image_8bit.convertTo(image_8bit, CV_8UC1); // 转换为 CV_8UC1
|
image_8bit.convertTo(image_8bit, CV_8UC1); // 转换为 CV_8UC1
|
||||||
cv::Mat mask = get_magic_wand_image(image_8bit, x, y, th);
|
int _max = max / 256;
|
||||||
|
int _min = min / 256;
|
||||||
|
cv::Mat mask = get_magic_wand_image(image_8bit, x, y, _max,_min);
|
||||||
PseudoInfo pinfo = get_pseudo_info(image, mask, max, min);
|
PseudoInfo pinfo = get_pseudo_info(image, mask, max, min);
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user