Пример #1
0
        private void btnDrawRect1_Click(object sender, EventArgs e)
        {
            ROIRectangle1 rect1 = new ROIRectangle1();

            _roiCtrl.setROIShape(rect1);
        }
Пример #2
0
        public string RunMaxPoint(HObject Image, HObject orgionImage, HWindow_Final hWindow_Final, HTuple Homat, out FindMaxResult fResult)
        {
            fResult = new FindMaxResult();
            try
            {
                HObject Line = new HObject();
                //PreHandle(Image, out ScaleImage);
                FitLine(Image, null, out Line, Homat);

                //Image = hWindow_Final.Image;
                double xResolution = 0.006;
                if (MyGlobal.GoSDK.context.xResolution != 0)
                {
                    xResolution = MyGlobal.GoSDK.context.xResolution;
                }

                double     MoveLeft   = (inParam.PlateWidth) / xResolution;
                double     BaseOffset = inParam.BaseOffset / xResolution;
                HTuple     baseZ      = new HTuple();
                List <ROI> _roiList   = new List <ROI>();
                if (Homat.Length != 0)
                {
                    for (int i = 0; i < roiList.Count; i++)
                    {
                        _roiList.Add(new ROI());
                        HTuple coord = roiList[i].getModelData();
                        HTuple affinePx, affinePy, affinePx1, affinePy1;
                        HOperatorSet.AffineTransPoint2d(Homat, coord[0], coord[1], out affinePx, out affinePy);
                        HOperatorSet.AffineTransPoint2d(Homat, coord[2], coord[3], out affinePx1, out affinePy1);
                        ROI roi = new ROIRectangle1(affinePx, affinePy, affinePx1, affinePy1);
                        _roiList[i] = roi;
                    }
                }
                else
                {
                    _roiList = roiList;
                }
                if (_roiList.Count > 2)
                {
                    HTuple grayValue = new HTuple();
                    for (int i = 0; i < 2; i++)
                    {
                        HTuple  recR, recC;
                        HRegion temp = _roiList[i].getRegion();
                        HOperatorSet.GetRegionPoints(temp, out recR, out recC);
                        hWindow_Final.viewWindow.displayHobject(temp, "green", true);
                        HTuple GrayValue = new HTuple();

                        HTuple width, height;
                        HOperatorSet.GetImageSize(Image, out width, out height);
                        HTuple newReq = recR.TupleLessElem(height);
                        HTuple newCeq = recC.TupleLessElem(width);
                        HTuple Rid    = newReq.TupleFind(1);
                        HTuple Cid    = newCeq.TupleFind(1);
                        HTuple id     = Rid.TupleIntersection(Cid);
                        if (id.Length != 0)
                        {
                            recR = recR[id];
                            recC = recC[id];

                            HOperatorSet.GetGrayval(orgionImage, recR, recC, out GrayValue);
                            HTuple newGray = GrayValue.TupleGreaterElem(-30);
                            HTuple NeqId   = new HTuple();
                            HOperatorSet.TupleFind(newGray, 1, out NeqId);
                            GrayValue = GrayValue[NeqId];
                            HOperatorSet.TupleSort(GrayValue, out GrayValue);
                            int len   = GrayValue.Length;
                            int len10 = (int)(len * 0.05);
                            GrayValue = GrayValue.TupleSelectRange(len10, len - 1);
                            GrayValue = GrayValue.TupleSelectRange(0, GrayValue.Length - len10);
                            HTuple mean = GrayValue.TupleMean();
                            grayValue = grayValue.TupleConcat(mean);
                        }
                        else
                        {
                            return("基准区域超出图像");
                        }
                    }
                    baseZ = grayValue.TupleMean();
                }

                HTuple MaxZ = new HTuple();
                for (int i = 2; i < _roiList.Count; i++)
                {
                    HRegion temp          = _roiList[i].getRegion();
                    HObject regionContour = new HObject();
                    HOperatorSet.GenContourRegionXld(temp, out regionContour, "border");
                    HTuple intersectR, intersectC, isOverlapping;

                    //hWindow_Final.viewWindow.displayHobject(regionContour, "red", true);

                    HOperatorSet.IntersectionContoursXld(regionContour, Line, "mutual", out intersectR, out intersectC, out isOverlapping);
                    if (intersectR.Length > 1)
                    {
                        HTuple  Coord    = _roiList[i].getModelData();
                        HTuple  colLeft  = intersectC[0] - MoveLeft;
                        HTuple  rowLeft  = Coord[0];
                        HTuple  colRight = intersectC[1] + BaseOffset;
                        HTuple  rowRight = Coord[2];
                        HObject rec      = new HObject();
                        if (colRight.D <= colLeft.D)
                        {
                            colRight = colLeft.D + 1;
                        }
                        HOperatorSet.GenRectangle1(out rec, rowLeft, colLeft, rowRight, colRight);
                        //HOperatorSet.SetColor(hWindow_Final.HWindowHalconID, "red");
                        //HOperatorSet.SetDraw(hWindow_Final.HWindowHalconID, "fill");
                        //HOperatorSet.DispObj(rec, hWindow_Final.HWindowHalconID);
                        hWindow_Final.viewWindow.displayHobject(rec, "red", true);
                        HTuple recR, recC;
                        HOperatorSet.GetRegionPoints(rec, out recR, out recC);
                        HTuple GrayValue = new HTuple();
                        HTuple width, height;
                        HOperatorSet.GetImageSize(Image, out width, out height);
                        HTuple newReq = recR.TupleLessElem(height);
                        HTuple newCeq = recC.TupleLessElem(width);
                        HTuple Rid    = newReq.TupleFind(1);
                        HTuple Cid    = newCeq.TupleFind(1);
                        HTuple id     = Rid.TupleIntersection(Cid);
                        if (id.Length != 0)
                        {
                            recR = recR[id];
                            recC = recC[id];
                            HOperatorSet.GetGrayval(orgionImage, recR, recC, out GrayValue);
                        }
                        else
                        {
                            return("感光片区域超出图像");
                        }
                        HTuple newGray = GrayValue.TupleFind(-30);
                        GrayValue = GrayValue.TupleRemove(newGray);
                        HOperatorSet.TupleSort(GrayValue, out GrayValue);
                        int len   = GrayValue.Length;
                        int len10 = (int)(len * 0.05);
                        //GrayValue = GrayValue.TupleSelectRange(len10, len - 1);
                        GrayValue = GrayValue.TupleSelectRange(GrayValue.Length - len10 * 3 - 1, GrayValue.Length - len10);

                        HTuple max    = GrayValue.TupleMean();
                        HTuple subMax = max.D - baseZ.D;
                        double maxSub = Math.Round(subMax.D, 3);
                        MaxZ = MaxZ.TupleConcat(maxSub);
                        HOperatorSet.SetColor(hWindow_Final.HWindowHalconID, "blue");
                        HOperatorSet.SetFont(hWindow_Final.HWindowHalconID, "-Arial - 20 -");
                        HOperatorSet.SetTposition(hWindow_Final.HWindowHalconID, i * 10, 10);
                        HOperatorSet.WriteString(hWindow_Final.HWindowHalconID, maxSub.ToString());
                    }
                }
                if (MaxZ.Length == 0)
                {
                    return("遮光片区域未找到");
                }
                fResult.Max = MaxZ;
                HTuple maxAll = MaxZ.TupleMax();
                if (maxAll.D > inParam.DownLimits && maxAll.D < inParam.UpLimits)
                {
                    fResult.DetectOK = true;
                    HOperatorSet.SetColor(hWindow_Final.HWindowHalconID, "green");
                    HOperatorSet.SetFont(hWindow_Final.HWindowHalconID, "-Arial - 50 -");
                    HOperatorSet.SetTposition(hWindow_Final.HWindowHalconID, 0, 10);
                    HOperatorSet.WriteString(hWindow_Final.HWindowHalconID, "OK");
                }
                else
                {
                    fResult.DetectOK = false;
                    HOperatorSet.SetColor(hWindow_Final.HWindowHalconID, "red");
                    HOperatorSet.SetFont(hWindow_Final.HWindowHalconID, "-Arial - 50 -");
                    HOperatorSet.SetTposition(hWindow_Final.HWindowHalconID, 0, 10);
                    HOperatorSet.WriteString(hWindow_Final.HWindowHalconID, "NG");
                }
                return("OK");
            }
            catch (Exception ex)
            {
                return("RunMaxPoint" + ex.Message);
            }
        }
Пример #3
0
        private void button2_Click(object sender, EventArgs e)
        {
            ROI rOI = new ROIRectangle1(15000, 4000, 3000, 3000);

            m_roiList.Add(rOI);
        }
Пример #4
0
        /// <summary>
        /// 指定ROI类型画ROI
        /// </summary>
        /// <param name="ROI_TYPE">ROI.ROI_TYPE</param>
        /// <returns></returns>
        public ROI DrawROI(int ROI_TYPE)
        {
            ROI NewROI = null;

            viewController.setViewState(HWndCtrl.MODE_ROI_Create);
            WPF_HWindow.HalconWindow.SetColor("red");

            if (ROI_TYPE == ROI.ROI_TYPE_LINE)
            {
                double row1, row2, column1, column2;
                hv_window.DrawLine(out row1, out column1, out row2, out column2);
                if (row1 == 0 && row2 == 0 && column1 == 0 && column2 == 0)
                {
                    Console.WriteLine("空的ROI");
                }
                else
                {
                    ROILine _ROI = new ROILine();
                    _ROI.createROI(row1, column1, row2, column2);
                    NewROI = _ROI;
                }
            }
            else if (ROI_TYPE == ROI.ROI_TYPE_RECTANGLE1)
            {//如果type是Rectangle1
                double row1, row2, column1, column2;
                hv_window.DrawRectangle1(out row1, out column1, out row2, out column2);

                if (row1 == 0 && row2 == 0 && column1 == 0 && column2 == 0)
                {
                    Console.WriteLine("空的ROI");
                }
                else
                {
                    ROIRectangle1 _ROI = new ROIRectangle1();
                    _ROI.createROI(row1, column1, row2, column2);
                    NewROI = _ROI;
                }
            }
            else if (ROI_TYPE == ROI.ROI_TYPE_RECTANGLE2)
            {//
                double row, column, phi, length1, length2;
                hv_window.DrawRectangle2(out row, out column, out phi, out length1, out length2);

                if (row == 0 && column == 0 && length1 == 0 && length2 == 0)
                {
                    Console.WriteLine("空的ROI");
                }
                else
                {
                    ROIRectangle2 _ROI = new ROIRectangle2();
                    _ROI.createROI(row, column, phi, length1, length2);
                    NewROI = _ROI;
                }
            }
            else if (ROI_TYPE == ROI.ROI_TYPE_REGION)
            {//如果type是Region
                HRegion hr = hv_window.DrawRegion();
                if (hr.Area.L == 0)
                {
                    Console.WriteLine("空的ROI");
                }
                else
                {
                    NewROI = new ROIRegion(hr);
                }
            }
            else if (ROI_TYPE == ROI.ROI_TYPE_CIRCLE)
            {
                double row, column, radius;
                hv_window.DrawCircle(out row, out column, out radius);
                if (row == 0 && column == 0 && radius == 0)
                {
                    Console.WriteLine("空的ROI");
                }
                else
                {
                    ROICircle _ROI = new ROICircle();
                    _ROI.createROI(column, row, radius);
                    NewROI = _ROI;
                }
            }

            DelaySetViewState(HWndCtrl.MODE_VIEW_MOVE);
            //hv_window.DispObj(hr);
            return(NewROI);
        }