mirror of
https://github.com/opencv/opencv.git
synced 2025-01-18 14:13:15 +08:00
4cf9990d4e
Conflicts: doc/tutorials/definitions/noContent.rst doc/tutorials/gpu/gpu-basics-similarity/gpu-basics-similarity.rst doc/tutorials/introduction/android_binary_package/dev_with_OCV_on_Android.rst doc/tutorials/introduction/how_to_write_a_tutorial/how_to_write_a_tutorial.rst modules/core/include/opencv2/core/core.hpp modules/core/include/opencv2/core/internal.hpp modules/core/include/opencv2/core/version.hpp modules/gpu/CMakeLists.txt modules/highgui/perf/perf_output.cpp modules/highgui/test/test_video_io.cpp modules/ocl/include/opencv2/ocl/ocl.hpp modules/ocl/perf/main.cpp modules/ocl/src/hog.cpp modules/ocl/src/initialization.cpp modules/ocl/src/moments.cpp modules/ocl/src/opencl/moments.cl modules/ocl/test/main.cpp modules/ocl/test/test_moments.cpp modules/python/test/test.py modules/ts/include/opencv2/ts/ts_perf.hpp modules/ts/src/precomp.hpp modules/ts/src/ts_perf.cpp
110 lines
2.8 KiB
C++
110 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;
|
|
}
|