【问题标题】:Houghlines in android with opencv带有opencv的android中的Houghlines
【发布时间】:2015-10-06 17:07:44
【问题描述】:

我正在尝试使用 opencv3 对四边形对象进行透视校正。我设法显示线条并使用Imgproc.HoughLinesP() 实现了Houghlines,并尝试使用Imgproc.lines() 突出显示线条,但输出没有成功。下面是我的代码,我还附上了我的输出图像。

请让我知道发生了什么错误以及应该做什么......

Mat initImg; // initial image
Mat greyImg; // converted to grey

Mat lines = new Mat();
int threshold = 50;
int minLineSize = 20;
int lineGap = 10;

initImg = Imgcodecs.imread(imgLoc, 1);
greyImg = new Mat();
Imgproc.cvtColor(initImg, greyImg, Imgproc.COLOR_BGR2GRAY);
Bitmap bitm = Bitmap.createBitmap(greyImg.cols(), greyImg.rows(),Bitmap.Config.ARGB_8888);

Imgproc.blur(greyImg, greyImg, new Size(3.d, 3.d));
Imgproc.adaptiveThreshold(greyImg, greyImg, 255, Imgproc.ADAPTIVE_THRESH_MEAN_C, Imgproc.THRESH_BINARY_INV, 15, 4);

Imgproc.HoughLinesP(greyImg, lines, 1, Math.PI/180, threshold,
        minLineSize, lineGap);
// lines returns rows x columns and rows is always 1. I dont know why please help me to understand
for (int x = 0; x < lines.cols(); x++) {

    double[] vec = lines.get(0, x);
    double[] val = new double[4];

    double x1 = vec[0],
            y1 = vec[1],
            x2 = vec[2],
            y2 = vec[3];

    System.out.println(TAG+"Coordinates: x1=>"+x1+" y1=>"+y1+" x2=>"+x2+" y2=>"+y2);
    Point start = new Point(x1, y1);
    Point end = new Point(x2, y2);

    Imgproc.line(greyImg, start, end, new Scalar(0,255, 0, 255), 3);

}

Utils.matToBitmap(greyImg, bitm);

if(bitm!=null){
    Toast.makeText(getApplicationContext(), "Bitmap not null", Toast.LENGTH_SHORT).show();
    iv.setImageBitmap(bitm);
}else{
    Toast.makeText(getApplicationContext(), "Bitmap null", Toast.LENGTH_SHORT).show();
}

我的输出:

【问题讨论】:

    标签: android opencv opencv3.0


    【解决方案1】:

    我终于设法得到了底线。灰色图像中没有显示轮廓线,我在灰色图像中提取了轮廓线,但在彩色图像中绘制了线条并且它起作用了。

    Imgproc.HoughLinesP(greyImg, lines, 1, Math.PI/180, threshold,
                    minLineSize, lineGap);
    
            for (int x = 0; x < lines.rows(); x++)
            {
                double[] vec = lines.get(x, 0);
                double x1 = vec[0],
                        y1 = vec[1],
                        x2 = vec[2],
                        y2 = vec[3];
                Point start = new Point(x1, y1);
                Point end = new Point(x2, y2);
                double dx = x1 - x2;
                double dy = y1 - y2;
    
                double dist = Math.sqrt (dx*dx + dy*dy);
    
                if(dist>300.d)  // show those lines that have length greater than 300
                    Imgproc.line(initImg, start, end, new Scalar(0,255, 0, 255),5);// here initimg is the original image.
    
            }
    

    【讨论】:

      猜你喜欢
      • 2013-03-30
      • 1970-01-01
      • 2012-03-07
      • 1970-01-01
      • 1970-01-01
      • 2015-03-12
      • 1970-01-01
      • 2015-07-04
      • 1970-01-01
      相关资源
      最近更新 更多