f07769e9d8
Conflicts: cmake/OpenCVDetectOpenCL.cmake cmake/OpenCVModule.cmake modules/imgproc/src/floodfill.cpp modules/nonfree/src/surf.ocl.cpp modules/ocl/include/opencv2/ocl/ocl.hpp modules/ocl/include/opencv2/ocl/private/util.hpp modules/ocl/perf/main.cpp modules/ocl/src/arithm.cpp modules/ocl/src/blend.cpp modules/ocl/src/build_warps.cpp modules/ocl/src/canny.cpp modules/ocl/src/cl_programcache.hpp modules/ocl/src/columnsum.cpp modules/ocl/src/haar.cpp modules/ocl/src/hog.cpp modules/ocl/src/imgproc.cpp modules/ocl/src/initialization.cpp modules/ocl/src/match_template.cpp modules/ocl/src/matrix_operations.cpp modules/ocl/src/mcwutil.cpp modules/ocl/src/moments.cpp modules/ocl/src/mssegmentation.cpp modules/ocl/src/precomp.hpp modules/ocl/src/pyrdown.cpp modules/ocl/src/pyrlk.cpp modules/ocl/src/pyrup.cpp modules/ocl/src/split_merge.cpp modules/ocl/src/stereo_csbp.cpp modules/ocl/src/stereobm.cpp modules/ocl/test/main.cpp samples/ocl/bgfg_segm.cpp samples/ocl/facedetect.cpp samples/ocl/pyrlk_optical_flow.cpp samples/ocl/squares.cpp samples/ocl/stereo_match.cpp samples/ocl/surf_matcher.cpp samples/ocl/tvl1_optical_flow.cpp
111 lines
2.8 KiB
C++
111 lines
2.8 KiB
C++
#include <iostream>
|
|
#include "opencv2/core/core.hpp"
|
|
#include "opencv2/core/utility.hpp"
|
|
#include "opencv2/imgproc/imgproc.hpp"
|
|
#include "opencv2/highgui/highgui.hpp"
|
|
#include "opencv2/ocl/ocl.hpp"
|
|
using namespace cv;
|
|
using namespace std;
|
|
|
|
Ptr<CLAHE> pFilter;
|
|
int tilesize;
|
|
int cliplimit;
|
|
string outfile;
|
|
|
|
static void TSize_Callback(int pos)
|
|
{
|
|
if(pos==0)
|
|
{
|
|
pFilter->setTilesGridSize(Size(1,1));
|
|
}
|
|
pFilter->setTilesGridSize(Size(tilesize,tilesize));
|
|
}
|
|
|
|
static void Clip_Callback(int)
|
|
{
|
|
pFilter->setClipLimit(cliplimit);
|
|
}
|
|
|
|
int main(int argc, char** argv)
|
|
{
|
|
const char* keys =
|
|
"{ i input | | specify input image }"
|
|
"{ c camera | 0 | specify camera id }"
|
|
"{ s use_cpu | false | use cpu algorithm }"
|
|
"{ o output | clahe_output.jpg | specify output save path}";
|
|
|
|
CommandLineParser cmd(argc, argv, keys);
|
|
string infile = cmd.get<string>("i");
|
|
outfile = cmd.get<string>("o");
|
|
int camid = cmd.get<int>("c");
|
|
bool use_cpu = cmd.get<bool>("s");
|
|
VideoCapture capture;
|
|
bool running = true;
|
|
|
|
namedWindow("CLAHE");
|
|
createTrackbar("Tile Size", "CLAHE", &tilesize, 32, (TrackbarCallback)TSize_Callback);
|
|
createTrackbar("Clip Limit", "CLAHE", &cliplimit, 20, (TrackbarCallback)Clip_Callback);
|
|
|
|
Mat frame, outframe;
|
|
ocl::oclMat d_outframe;
|
|
|
|
int cur_clip;
|
|
Size cur_tilesize;
|
|
if(use_cpu)
|
|
{
|
|
pFilter = createCLAHE();
|
|
}
|
|
else
|
|
{
|
|
pFilter = ocl::createCLAHE();
|
|
}
|
|
cur_clip = (int)pFilter->getClipLimit();
|
|
cur_tilesize = pFilter->getTilesGridSize();
|
|
setTrackbarPos("Tile Size", "CLAHE", cur_tilesize.width);
|
|
setTrackbarPos("Clip Limit", "CLAHE", cur_clip);
|
|
if(infile != "")
|
|
{
|
|
frame = imread(infile);
|
|
if(frame.empty())
|
|
{
|
|
cout << "error read image: " << infile << endl;
|
|
return -1;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
capture.open(camid);
|
|
}
|
|
cout << "\nControls:\n"
|
|
<< "\to - save output image\n"
|
|
<< "\tESC - exit\n";
|
|
while(running)
|
|
{
|
|
if(capture.isOpened())
|
|
capture.read(frame);
|
|
else
|
|
frame = imread(infile);
|
|
if(frame.empty())
|
|
{
|
|
continue;
|
|
}
|
|
if(use_cpu)
|
|
{
|
|
cvtColor(frame, frame, COLOR_BGR2GRAY);
|
|
pFilter->apply(frame, outframe);
|
|
}
|
|
else
|
|
{
|
|
ocl::oclMat d_frame(frame);
|
|
ocl::cvtColor(d_frame, d_outframe, COLOR_BGR2GRAY);
|
|
pFilter->apply(d_outframe, d_outframe);
|
|
d_outframe.download(outframe);
|
|
}
|
|
imshow("CLAHE", outframe);
|
|
char key = (char)waitKey(3);
|
|
if(key == 'o') imwrite(outfile, outframe);
|
|
else if(key == 27) running = false;
|
|
}
|
|
return 0;
|
|
}
|