void CMFCApplication2Dlg::OnBnClickedBm()
{
// TODO: 在此添加控制元件通知處理程式代碼
IplImage * img1 = cvLoadImage((LPSTR)(LPCTSTR)strFileName1,0);
IplImage * img2 = cvLoadImage((LPSTR)(LPCTSTR)strFileName2,0);
cv::StereoSGBM sgbm;
int SADWindowSize = 9;
sgbm.preFilterCap = 63;
sgbm.SADWindowSize = SADWindowSize > 0 ? SADWindowSize : 3;
int cn = img1->nChannels;
int numberOfDisparities=64;
sgbm.P1 = 8*cn*sgbm.SADWindowSize*sgbm.SADWindowSize;
sgbm.P2 = 32*cn*sgbm.SADWindowSize*sgbm.SADWindowSize;
sgbm.minDisparity = 0;
sgbm.numberOfDisparities = numberOfDisparities;
sgbm.uniquenessRatio = 10;
sgbm.speckleWindowSize = 100;
sgbm.speckleRange = 32;
sgbm.disp12MaxDiff = 1;
Mat disp, disp8;
int64 t = getTickCount();
sgbm((Mat)img1, (Mat)img2, disp);
t = getTickCount() - t;
cout<<"Time elapsed:"<<t*1000/getTickFrequency()<<endl;
disp.convertTo(disp8, CV_8U, 255/(numberOfDisparities*16.));
namedWindow("left", 1);
cvShowImage("left", img1);
namedWindow("right", 1);
cvShowImage("right", img2);
namedWindow("disparity", 1);
imshow("disparity", disp8);
waitKey();
imwrite("sgbm_disparity.png", disp8);
cvDestroyAllWindows();
}
strFileName1,2 是讀入的兩個影像,本意是想弄讀兩個影像然后做視差圖顯示的。
uj5u.com熱心網友回復:
字串轉換不建議這樣 (LPSTR)(LPCTSTR), UNICODE下有問題檔案打開 加載一般應該判斷是否成功
代碼不長, 設定斷點 單步除錯運行
uj5u.com熱心網友回復:
IplImage * img1 = cvLoadImage((LPTSTR)(LPCTSTR)strFileName1,0);
用LPTSTR,然后單步除錯跟蹤一下
uj5u.com熱心網友回復:
請在Debug模式下單步執行一下看看轉載請註明出處,本文鏈接:https://www.uj5u.com/gongcheng/75389.html
標籤:基礎類
