Android Opencv

Posted danfengw

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Android Opencv相关的知识,希望对你有一定的参考价值。

图层金字塔与reSize

Pyramid中文金字塔,因此pyrDown和pyrUp函数也是十分形象的,
pyrDown和pyrUp都是先进行了5x5的高斯模糊,再进行了大小的改变。
pyrDown和pyrUp每调用一次,只能缩小2倍或者放大2倍。如果就单纯的图片尺寸的缩放来说,效率没有reSize高。
resize就是纯粹的根据比例改变长宽。

pyrDown(src, dst, dstsize);中的
dstsize参数,并不是输出图片的尺寸,因为每调用一次,只能缩小2倍,需要缩小4倍则需要被调用2次。因此这里的dstsize大致理解为输出图片的容器大小。
在运算速度上,reSize要比pyr快。

角点检测

goodFeaturesToTrack(image, corners, maxCorners, qualityLevel, minDistance)
image :必须为8bit或者浮点32bit单通道矩阵
corners:输出角点集合
maxCorners:最大角点数
qualityLevel:角点可接待最小特征 范围0.01-1,效果区别不大。

//转换为单通道            Imgproc.cvtColor(drawing,drawing,COLOR_RGB2GRAY);
            drawing.convertTo(drawing,CvType.CV_8UC1);
            Imgproc.goodFeaturesToTrack(drawing,corners,4,0.1,30);
            MatOfPoint2f point2f=new MatOfPoint2f();
            corners.convertTo(point2f,CvType.CV_32FC2);
            Point[] allpoint=point2f.toArray();
            for (Point point:allpoint)
                Imgproc.circle(drawing,point,50,new Scalar(255,0,255));
            

线段检测

    public static final Mat lineSegmentDetector(Mat srcmat) 
        Mat line = new Mat();
        LineSegmentDetector lsd = new Imgproc().createLineSegmentDetector();
        lsd.detect(srcmat, line);
        lsd.drawSegments(srcmat, line);
       return srcmat;
    

质心

  Moments moments = Imgproc.moments(drawing);
        Point centerpoint = new Point(moments.get_m10() / moments.get_m00(), moments.get_m01() / moments.get_m00());

根据2点计算所在直线参数

private  static double[] getLineParams(Point linepoint1, Point linepoint2)
        // 两点式公式为(y - y1)/(x - x1) = (y2 - y1)/ (x2 - x1)
        // 化简为一般式为(y2 - y1)x + (x1 - x2)y + (x2y1 - x1y2) = 0
        // A = y2 - y1
        // B = x1 - x2
        // C = x2y1 - x1y2
        double a = linepoint2.y - linepoint1.y;
        double b = linepoint1.x - linepoint2.x;
        double c = linepoint2.x * linepoint1.y - linepoint1.x * linepoint2.y;
        double[] abc=new double[]a,b,c;
        return abc;
    

以上是关于Android Opencv的主要内容,如果未能解决你的问题,请参考以下文章

opencv+python实现视频实时质心读取

目标跟踪入门:使用OpenCV实现质心跟踪

openCV C++ 将对象/斑点减少到质心

使用OpenCV绘制连接对象质心的线

youcans 的 OpenCV 例程200篇197.轮廓的基本特征

什么叫图像或轮廓的空间矩中心矩归一化中心矩?并利用OpenCV的类Moments计算轮廓的这几个矩和质心位置