#include <iostream>
int main(
int argc,
char** argv)
{
"{input i|building.jpg|輸入影像}"
"{refine r|false|如果為真,則使用 LSD_REFINE_STD 方法,如果為假,則使用 LSD_REFINE_NONE 方法}"
"{canny c|false|使用 Canny 邊緣檢測器}"
"{overlay o|false|在輸入影像上顯示結果}"
"{help h|false|顯示幫助資訊}");
if (parser.
get<
bool>(
"help"))
{
return 0;
}
bool useRefine = parser.
get<
bool>(
"refine");
bool useCanny = parser.
get<
bool>(
"canny");
bool overlay = parser.
get<
bool>(
"overlay");
Mat image = imread(filename, IMREAD_GRAYSCALE);
if( image.empty() )
{
cout << "無法載入 " << filename;
return 1;
}
imshow("原始影像", image);
if (useCanny)
{
Canny(image, image, 50, 200, 3);
}
Ptr<LineSegmentDetector> ls = useRefine ? createLineSegmentDetector(LSD_REFINE_STD) : createLineSegmentDetector(LSD_REFINE_NONE);
double start = double(getTickCount());
vector<Vec4f> lines_std;
ls->detect(image, lines_std);
double duration_ms = (double(getTickCount()) - start) * 1000 / getTickFrequency();
std::cout << "耗時 " << duration_ms << " 毫秒。" << std::endl;
if (!overlay || useCanny)
{
}
ls->drawSegments(image, lines_std);
String window_name = useRefine ?
"結果 - 標準最佳化" :
"結果 - 無最佳化";
window_name += useCanny ? " - 使用 Canny 邊緣檢測器" : "";
imshow(window_name, image);
cv::Mat::empty
return 0;
}
如果陣列沒有元素,則返回 true。
int64_t int64
T get(const String &name, bool space_delete=true) const
按名稱訪問引數。
定義 utility.hpp:956
void printMessage() const
列印幫助資訊。
std::string String
定義 cvstd.hpp:151
std::shared_ptr< _Tp > Ptr
Definition cvstd_wrapper.hpp:23
int main(int argc, char *argv[])
定義 highgui_qt.cpp:3