为什么Android中的凸性缺陷OpenCV会出错?

时间:2015-06-15 06:03:01

标签: java android opencv convexity-defects

我是Android开发中的初学者,也是OpenCV中的新手。我有关于Android手势识别的项目。我想对它做凸性缺陷。在我做凸性缺陷之前,我应该找到轮廓和凸包。我已经做过了。现在,我正在做凸度缺陷以获得手和手指的缺陷。但是有些不对劲。当我在我的Android中使用凸性缺陷构建我的代码时,很遗憾它停止了。我不知道我的凸性缺陷函数是错误的,还是我得到缺陷值(MatOfInt4)到Point的方式是错误的。有人,请帮帮我。谢谢。这是我的代码:

List<MatOfInt> hull = new ArrayList<MatOfInt>();
List<MatOfInt4> defect = new ArrayList<MatOfInt4>();
for(int i = 0; i < newContours.size(); i++)
    {
        hull.add(new MatOfInt());
        Imgproc.convexHull(newContours.get(i), hull.get(i));
        Imgproc.convexityDefects(newContours.get(i), hull.get(i), defect.get(i));
    }

    Point defectSP= new Point();
    Point defectEP= new Point();
    Point defectFP= new Point();
    for(int i = 0; i < defect.size(); i++)
    {
        Point[] startP = new Point[newContours.get(i).rows()];
        Point[] endP = new Point[newContours.get(i).rows()];
        Point[] farP = new Point[newContours.get(i).rows()];
        Point[] depthP = new Point[newContours.get(i).rows()];

        for(int j = 0; j < defect.get(i).rows(); j++)
        {
            int distP = (int) defect.get(i).get(j, 3)[3];
            if (distP > 20*256)
            {
                startId = (int) defect.get(i).get(j, 0)[0];
                endId = (int) defect.get(i).get(j, 1)[1];
                farId = (int) defect.get(i).get(j, 2)[2];

                defectSP.x = startId;
                defectSP.y = startId;
                defectEP.x = endId;
                defectEP.y = endId;
                defectFP.x = farId;
                defectFP.y = farId;
            }
         }
     }

0 个答案:

没有答案