我在stackoverflow中经历了许多turorials和cupple问题,我发现了以下用于绘制矩形的方法。

public static void drawSquares( IplImage image, final CvSeq squares )
{
    if(!squares.isNull()){
            CvSeq p = new CvSeq(squares.total());
            cvCvtSeqToArray(squares, p, CV_WHOLE_SEQ);
            System.out.println(squares.total());
        for(int i = 0; i < squares.total(); i ++  )
        {
             CvPoint pts = new CvPoint(4);

             cvCvtSeqToArray(p.position(i), pts, CV_WHOLE_SEQ);
//                 //cvBoundingRect(image, i);
            int npt[] = {4, 4};
//                //DrawLine() reference http://opencv.willowgarage.com/documentation/cpp/drawing_functions.html#cv-line
            cvDrawLine(image, new CvPoint(pts.position(0).x(),pts.position(0).y()), new CvPoint(pts.position(1).x(),pts.position(1).y()), CvScalar.GREEN, 3, CV_AA, 0);
            cvDrawLine(image, new CvPoint(pts.position(1).x(),pts.position(1).y()), new CvPoint(pts.position(2).x(),pts.position(2).y()), CvScalar.GREEN, 3, CV_AA, 0);
            cvDrawLine(image, new CvPoint(pts.position(2).x(),pts.position(2).y()), new CvPoint(pts.position(3).x(),pts.position(3).y()), CvScalar.GREEN, 3, CV_AA, 0);
            cvDrawLine(image, new CvPoint(pts.position(3).x(),pts.position(3).y()), new CvPoint(pts.position(0).x(),pts.position(0).y()), CvScalar.GREEN, 3, CV_AA, 0);

        }
    }
    final CanvasFrame canvas = new CanvasFrame(wndname);
    canvas.setDefaultCloseOperation(javax.swing.JFrame.EXIT_ON_CLOSE);
    canvas.showImage(image);
}

这段代码在绘制矩形时正是这样做的。但是我需要修改这个方法来绘制具有 8 个边的多边形。我尝试按如下方式更改代码,但没有达到我的预期。
public static void drawPoly( IplImage image, final CvSeq poly )
{
    if(!poly.isNull()){
            CvSeq p = new CvSeq(poly.total());
            cvCvtSeqToArray(poly, p, CV_WHOLE_SEQ);
            System.out.println(poly.total());
        for(int i = 0; i < poly.total(); i ++  )
        {
                System.out.println(i);
             CvPoint pts = new CvPoint(8);

             cvCvtSeqToArray(p.position(i), pts, CV_WHOLE_SEQ);

            cvDrawLine(image, new CvPoint(pts.position(0).x(),pts.position(0).y()), new CvPoint(pts.position(1).x(),pts.position(1).y()), CvScalar.GREEN, 3, CV_AA, 0);
            cvDrawLine(image, new CvPoint(pts.position(1).x(),pts.position(1).y()), new CvPoint(pts.position(2).x(),pts.position(2).y()), CvScalar.GREEN, 3, CV_AA, 0);
            cvDrawLine(image, new CvPoint(pts.position(2).x(),pts.position(2).y()), new CvPoint(pts.position(3).x(),pts.position(3).y()), CvScalar.GREEN, 3, CV_AA, 0);
            cvDrawLine(image, new CvPoint(pts.position(3).x(),pts.position(3).y()), new CvPoint(pts.position(4).x(),pts.position(4).y()), CvScalar.GREEN, 3, CV_AA, 0);
            cvDrawLine(image, new CvPoint(pts.position(4).x(),pts.position(4).y()), new CvPoint(pts.position(5).x(),pts.position(5).y()), CvScalar.GREEN, 3, CV_AA, 0);
            cvDrawLine(image, new CvPoint(pts.position(5).x(),pts.position(5).y()), new CvPoint(pts.position(6).x(),pts.position(6).y()), CvScalar.GREEN, 3, CV_AA, 0);
            cvDrawLine(image, new CvPoint(pts.position(6).x(),pts.position(6).y()), new CvPoint(pts.position(7).x(),pts.position(7).y()), CvScalar.GREEN, 3, CV_AA, 0);
            cvDrawLine(image, new CvPoint(pts.position(7).x(),pts.position(7).y()), new CvPoint(pts.position(0).x(),pts.position(0).y()), CvScalar.GREEN, 3, CV_AA, 0);

        }
    }
    final CanvasFrame canvas = new CanvasFrame("Test inside last");
    canvas.setDefaultCloseOperation(javax.swing.JFrame.EXIT_ON_CLOSE);
    canvas.showImage(image);
}

这导致以下错误消息,但我无法理解比的原因。
0
#
# A fatal error has been detected by the Java Runtime Environment:
#
#  EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc=0x5c995048, pid=5992, tid=4464
#
# JRE version: 6.0_16-b01
# Java VM: Java HotSpot(TM) Client VM (14.2-b01 mixed mode, sharing windows-x86 )
# Problematic frame:
# C  [opencv_core240.dll+0x55048]
#
# An error report file with more information is saved as:
# C:\Users\Space\Documents\NetBeansProjects\1MyJavacv\hs_err_pid5992.log
#
# If you would like to submit a bug report, please visit:
#   http://java.sun.com/webapps/bugreport/crash.jsp
# The crash happened outside the Java Virtual Machine in native code.
# See problematic frame for where to report the bug.
#
Java Result: 1

请有人解释为什么它不运行以及我的方法有什么问题?

最佳答案

您需要做的第一件事是将问题域缩减为一个简单的可重复案例。确定导致崩溃的多边形形状。您可以查看 opencv 的 C/C++ 源代码以查看它不执行哪些检查,例如它是否允许屏幕外像素?

您可以更进一步编写一个包装类,该类执行一系列检查并记录每个函数调用,让您准确地知道错误何时发生、错误是否每次都发生在同一个地方以及导致的事件顺序到错误。

或者,您可以通过暂时让 drawPoly 调用 drawPoly 来测试传递给 drawSquare 的点数,首先发送点 0-3,然后点 4-7,只是为了验证发送的点数不会触发问题的事实。

关于java - 如何编辑此方法以使用 javacv 绘制多边形?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/11464759/

10-12 00:34
查看更多