当前位置: 首页>>代码示例>>C#>>正文


C# Mat.copyTo方法代码示例

本文整理汇总了C#中Mat.copyTo方法的典型用法代码示例。如果您正苦于以下问题:C# Mat.copyTo方法的具体用法?C# Mat.copyTo怎么用?C# Mat.copyTo使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Mat的用法示例。


在下文中一共展示了Mat.copyTo方法的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: MarkerDetector

    /// <summary>
    /// Initializes a new instance of the <see cref="MarkerDetector"/> class.
    /// </summary>
    /// <param name="camMatrix">Cam matrix.</param>
    /// <param name="distCoeff">Dist coeff.</param>
    public MarkerDetector(Mat camMatrix, Mat distCoeff)
    {
        m_minContourLengthAllowed = 100;
                markerSize = new Size (100, 100);

                camMatrix.copyTo (this.camMatrix);
                distCoeff.copyTo (this.distCoeff);

                List<Point3> m_markerCorners3dList = new List<Point3> ();

                m_markerCorners3dList.Add (new Point3 (-0.5f, -0.5f, 0));
                m_markerCorners3dList.Add (new Point3 (+0.5f, -0.5f, 0));
                m_markerCorners3dList.Add (new Point3 (+0.5f, +0.5f, 0));
                m_markerCorners3dList.Add (new Point3 (-0.5f, +0.5f, 0));

                m_markerCorners3d.fromList (m_markerCorners3dList);

                List<Point> m_markerCorners2dList = new List<Point> ();

                m_markerCorners2dList.Add (new Point (0, 0));
                m_markerCorners2dList.Add (new Point (markerSize.width - 1, 0));
                m_markerCorners2dList.Add (new Point (markerSize.width - 1, markerSize.height - 1));
                m_markerCorners2dList.Add (new Point (0, markerSize.height - 1));

                m_markerCorners2d.fromList (m_markerCorners2dList);
    }
开发者ID:prlosana,项目名称:MarkerBasedARSample,代码行数:31,代码来源:MarkerDetector.cs

示例2: rotate

		/// <summary>
		/// Rotate the specified inMat.
		/// </summary>
		/// <param name="inMat">In mat.</param>
		public static Mat rotate (Mat inMat)
		{
				byte[] b = new byte[1];

				Mat outMat = new Mat ();
				inMat.copyTo (outMat);
				for (int i=0; i<inMat.rows(); i++) {
						for (int j=0; j<inMat.cols(); j++) {
								inMat.get (inMat.cols () - j - 1, i, b);
								outMat.put (i, j, b);

						}
				}
				return outMat;
		}
开发者ID:wlstks7,项目名称:MarkerBasedARSample,代码行数:19,代码来源:Marker.cs

示例3: Start

        // Use this for initialization
        void Start()
        {
            Texture2D imageTexture = Resources.Load ("lena") as Texture2D;

            Mat image = new Mat (imageTexture.height, imageTexture.width, CvType.CV_8UC3);

            Utils.texture2DToMat (imageTexture, image);
            Debug.Log ("image.ToString() " + image.ToString ());

            Texture2D maskTexture = Resources.Load ("lena_grabcut_mask") as Texture2D;

            Mat mask = new Mat (imageTexture.height, imageTexture.width, CvType.CV_8UC1);

            Utils.texture2DToMat (maskTexture, mask);
            Debug.Log ("mask.ToString() " + mask.ToString ());

            OpenCVForUnity.Rect rectangle = new OpenCVForUnity.Rect (10, 10, image.cols () - 20, image.rows () - 20);

            Mat bgdModel = new Mat (); // extracted features for background
            Mat fgdModel = new Mat (); // extracted features for foreground

            convertToGrabCutValues (mask); // from grayscale values to grabcut values

            int iterCount = 5;
            //          Imgproc.grabCut (image, mask, rectangle, bgdModel, fgdModel, iterCount, Imgproc.GC_INIT_WITH_RECT);
            Imgproc.grabCut (image, mask, rectangle, bgdModel, fgdModel, iterCount, Imgproc.GC_INIT_WITH_MASK);

            convertToGrayScaleValues (mask); // back to grayscale values
            Imgproc.threshold (mask, mask, 128, 255, Imgproc.THRESH_TOZERO);

            Mat foreground = new Mat (image.size (), CvType.CV_8UC3, new Scalar (0, 0, 0));
            image.copyTo (foreground, mask);

            Texture2D texture = new Texture2D (image.cols (), image.rows (), TextureFormat.RGBA32, false);

            Utils.matToTexture2D (foreground, texture);

            gameObject.GetComponent<Renderer> ().material.mainTexture = texture;
        }
开发者ID:EnoxSoftware,项目名称:OpenCVForUnity,代码行数:40,代码来源:GrabCutSample.cs

示例4: MarkerDetector

		/// <summary>
		/// Initializes a new instance of the <see cref="MarkerDetector"/> class.
		/// </summary>
		/// <param name="camMatrix">Cam matrix.</param>
		/// <param name="distCoeff">Dist coeff.</param>
		public MarkerDetector (Mat camMatrix, Mat distCoeff, MarkerDesign markerDesign)
		{
				m_minContourLengthAllowed = 100;
				markerSize = new Size (100, 100);


				camMatrix.copyTo (this.camMatrix);
				distCoeff.copyTo (this.distCoeff);


				List<Point3> m_markerCorners3dList = new List<Point3> ();

				m_markerCorners3dList.Add (new Point3 (-0.5f, -0.5f, 0));
				m_markerCorners3dList.Add (new Point3 (+0.5f, -0.5f, 0));
				m_markerCorners3dList.Add (new Point3 (+0.5f, +0.5f, 0));
				m_markerCorners3dList.Add (new Point3 (-0.5f, +0.5f, 0));

				m_markerCorners3d.fromList (m_markerCorners3dList);


				List<Point> m_markerCorners2dList = new List<Point> ();

				m_markerCorners2dList.Add (new Point (0, 0));
				m_markerCorners2dList.Add (new Point (markerSize.width - 1, 0));
				m_markerCorners2dList.Add (new Point (markerSize.width - 1, markerSize.height - 1));
				m_markerCorners2dList.Add (new Point (0, markerSize.height - 1));

				m_markerCorners2d.fromList (m_markerCorners2dList);

				if (markerDesign != null) {
						m_markerDesign = new byte[markerDesign.gridSize, markerDesign.gridSize];
						for (int y = 0; y < m_markerDesign.GetLength(0); y++) {
								for (int x = 0; x < m_markerDesign.GetLength(1); x++) {
										if (markerDesign.data [y*markerDesign.gridSize + x]) {
												m_markerDesign [y, x] = 0;
										} else {
												m_markerDesign [y, x] = 1;
										}
								}
						}
				}
		}
开发者ID:wlstks7,项目名称:MarkerBasedARSample,代码行数:47,代码来源:MarkerDetector.cs

示例5: trackFilteredObject

                /// <summary>
                /// Tracks the filtered object.
                /// </summary>
                /// <param name="theColorObject">The color object.</param>
                /// <param name="threshold">Threshold.</param>
                /// <param name="HSV">HS.</param>
                /// <param name="cameraFeed">Camera feed.</param>
                void trackFilteredObject (ColorObject theColorObject, Mat threshold, Mat HSV, Mat cameraFeed)
                {

                        List<ColorObject> colorObjects = new List<ColorObject> ();
                        Mat temp = new Mat ();
                        threshold.copyTo (temp);
                        //these two vectors needed for output of findContours
                        List<MatOfPoint> contours = new List<MatOfPoint> ();
                        Mat hierarchy = new Mat ();
                        //find contours of filtered image using openCV findContours function
                        Imgproc.findContours (temp, contours, hierarchy, Imgproc.RETR_CCOMP, Imgproc.CHAIN_APPROX_SIMPLE);
                        //use moments method to find our filtered object
                        double refArea = 0;
                        bool colorObjectFound = false;
                        if (hierarchy.rows () > 0) {
                                int numObjects = hierarchy.rows ();

            //						Debug.Log("hierarchy " + hierarchy.ToString());

                                //if number of objects greater than MAX_NUM_OBJECTS we have a noisy filter
                                if (numObjects < MAX_NUM_OBJECTS) {
                                        for (int index = 0; index >= 0; index = (int)hierarchy.get(0, index)[0]) {

                                                Moments moment = Imgproc.moments (contours [index]);
                                                double area = moment.get_m00 ();

                                                //if the area is less than 20 px by 20px then it is probably just noise
                                                //if the area is the same as the 3/2 of the image size, probably just a bad filter
                                                //we only want the object with the largest area so we safe a reference area each
                                                //iteration and compare it to the area in the next iteration.
                                                if (area > MIN_OBJECT_AREA) {

                                                        ColorObject colorObject = new ColorObject ();

                                                        colorObject.setXPos ((int)(moment.get_m10 () / area));
                                                        colorObject.setYPos ((int)(moment.get_m01 () / area));
                                                        colorObject.setType (theColorObject.getType ());
                                                        colorObject.setColor (theColorObject.getColor ());

                                                        colorObjects.Add (colorObject);

                                                        colorObjectFound = true;

                                                } else {
                                                        colorObjectFound = false;
                                                }
                                        }
                                        //let user know you found an object
                                        if (colorObjectFound == true) {
                                                //draw object location on screen
                                                drawObject (colorObjects, cameraFeed, temp, contours, hierarchy);
                                        }

                                } else {
                                        Core.putText (cameraFeed, "TOO MUCH NOISE!", new Point (5, cameraFeed.rows () - 10), Core.FONT_HERSHEY_SIMPLEX, 1.0, new Scalar (255, 255, 255, 255), 2, Core.LINE_AA, false);
                                }
                        }
                }
开发者ID:xinfushe,项目名称:OpenCVForUnity,代码行数:65,代码来源:MultiObjectTrackingBasedOnColorSample.cs

示例6: inv_simil

		Mat inv_simil (Mat S)
		{
				Mat Si = new Mat (2, 3, CvType.CV_32F);
				float d = (float)S.get (0, 0) [0] * (float)S.get (1, 1) [0] - (float)S.get (1, 0) [0] * (float)S.get (0, 1) [0];

				Si.put (0, 0, S.get (1, 1) [0] / d);
				Si.put (0, 1, -S.get (0, 1) [0] / d);
				Si.put (1, 1, S.get (0, 0) [0] / d);
				Si.put (1, 0, -S.get (1, 0) [0] / d);

				Mat Ri = new Mat (Si, new OpenCVForUnity.Rect (0, 0, 2, 2));


				Mat negaRi = new Mat ();
				Core.multiply (Ri, new Scalar (-1), negaRi);
				Mat t = new Mat ();
				Core.gemm (negaRi, S.col (2), 1, new Mat (negaRi.rows (), negaRi.cols (), negaRi.type ()), 0, t);

				Mat St = Si.col (2);
				t.copyTo (St);

				return Si;
		}
开发者ID:Thecontrarian,项目名称:unity-blink-detection,代码行数:23,代码来源:PatchModels.cs

示例7: Mattting

    void Mattting(int index)
    {
        if (index > textures.Count - 1)
        {
            return;
        }

        ClearAllRendererTexture();

        Texture2D imgTexture = Resources.Load(textures[index]) as Texture2D;

        SetTexture(SourceTextureObject, imgTexture);

        Mat imgMat = new Mat(imgTexture.height, imgTexture.width, CvType.CV_8UC4);
        Mat thresholdImageMat = new Mat(imgTexture.height, imgTexture.width, CvType.CV_8UC1);

        Utils.texture2DToMat(imgTexture, imgMat);

        // Threshold to make picture more clean
        //
        Utils.texture2DToMat(imgTexture, thresholdImageMat);

        Imgproc.threshold(thresholdImageMat, thresholdImageMat, minThreshold, maxThreshold, Imgproc.THRESH_BINARY | Imgproc.THRESH_OTSU);

        if (ThresholdRenderObject)
        {
            SetTexture(ThresholdRenderObject, thresholdImageMat);
        }

        // find Contours
        //
        List<MatOfPoint> contours = new List<MatOfPoint>();
        Mat hierachy = new Mat();
        Imgproc.findContours(thresholdImageMat, contours, hierachy, Imgproc.RETR_CCOMP, Imgproc.CHAIN_APPROX_TC89_KCOS);

        Debug.Log(contours.Count);

        // sort contours by rows from large to small, first one is we wanted
        //
        contours.Reverse();

        // made mask
        //
        Mat mask = new Mat(imgTexture.height, imgTexture.width, CvType.CV_8UC4, new Scalar(0, 0, 0, 0));

        Imgproc.drawContours(mask, contours, 0, new Scalar(255, 255, 255, 255), -1);

        if (MaskRenderObject)
        {
            SetTexture(MaskRenderObject, mask);
        }

        //CopyTo
        //
        Mat result = new Mat(imgTexture.height, imgTexture.width, CvType.CV_8UC4);
        imgMat.copyTo(result, mask);

        SetTexture(gameObject, result);
    }
开发者ID:wudixiaop,项目名称:OpenCVSample,代码行数:59,代码来源:Koutu.cs


注:本文中的Mat.copyTo方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。