我創建了一個共享庫,用於從Delphi/Lazarus應用程序加載的輪廓檢測。主應用程序將指針傳遞給庫中的函數處理的位圖。OpenCV指向位圖處理的指針
下面是庫中的函數。參數「img」是指向我的位圖的指針。
extern "C" {
void detect_contour(int imgWidth, int imgHeight, unsigned char * img, int &x, int &y, int &w, int &h)
{
Mat threshold_output;
vector<vector<Point> > contours;
vector<Vec4i> hierarchy;
Mat src_gray;
int thresh = 100;
int max_thresh = 255;
RNG rng(12345);
/// Load source image and convert it to gray
Mat src(imgHeight, imgWidth, CV_8UC4);
int idx;
src.data = img;
/// Convert image to gray and blur it
cvtColor(src, src_gray, CV_BGRA2GRAY);
blur(src_gray, src_gray, Size(10,10));
/// Detect edges using Threshold
threshold(src_gray, threshold_output, thresh, 255, THRESH_BINARY);
/// Find contours
findContours(threshold_output, contours, hierarchy, CV_RETR_TREE, CV_CHAIN_APPROX_SIMPLE, Point(0, 0));
/// Approximate contours to polygons + get bounding rects and circles
vector<vector<Point> > contours_poly(contours.size());
vector<Rect> boundRect(contours.size());
vector<Point2f>center(contours.size());
vector<float>radius(contours.size());
int lArea = 0;
int lBigger = -1;
for(int i = 0; i < contours.size(); i++)
{
approxPolyDP(Mat(contours[i]), contours_poly[i], 3, true);
boundRect[i] = boundingRect(Mat(contours_poly[i]));
if(lArea < boundRect[i].width * boundRect[i].height)
{
lArea = boundRect[i].width * boundRect[i].height;
lBigger = i;
}
}
if(lBigger > -1)
{
x = boundRect[lBigger].x;
y = boundRect[lBigger].y;
w = boundRect[lBigger].width;
h = boundRect[lBigger].height;
}
}
}
從德爾福的一面,我傳遞一個指向該結構的陣列:
TBGRAPixel = packed record
blue, green, red, alpha: byte;
end;
我需要處理內存中的位圖,這就是爲什麼我不加載來自庫內的文件。
問題是:這是一個正確的方式來分配一個位圖到cv :: Mat嗎?
我問這是因爲代碼在Linux中沒有問題,但在與Mingw編譯的Windows上失敗。
注:它無法與這條線SIGSEGV:
blur(src_gray, src_gray, Size(10,10));
編輯:只有當我編譯的OpenCV在Release模式,在調試模式下它的工作原理確定的SIGSEGV提高。
在此先感謝, 萊昂納多。
謝謝喬納斯。我嘗試了你的建議,它可以在Linux上運行,但SIGSEGV在Windows上仍然存在。 – leonardorame