Thresholding Operations using inRange {#tutorial_threshold_inRange}
=============================

Goal
----

In this tutorial you will learn how to:

-   Perform basic thresholding operations using OpenCV function @ref cv::inRange
-   Detect an object based on the range of pixel values it has

Theory
-----------
-   In the previous tutorial, we learnt how perform thresholding using @ref cv::threshold function.
-   In this tutorial, we will learn how to do it using @ref cv::inRange function.
-   The concept remains same, but now we add a range of pixel values we need.

Code
----

The tutorial code's is shown lines below. You can also download it from
[here](https://github.com/opencv/opencv/tree/master/samples/cpp/tutorial_code/ImgProc/Threshold_inRange.cpp)
@include samples/cpp/tutorial_code/ImgProc/Threshold_inRange.cpp

Explanation
-----------

-#  Let's check the general structure of the program:
    -   Create two Matrix elements to store the frames
        @snippet samples/cpp/tutorial_code/ImgProc/Threshold_inRange.cpp mat
    -   Capture the video stream from default capturing device.
        @snippet samples/cpp/tutorial_code/ImgProc/Threshold_inRange.cpp cap
    -   Create a window to display the default frame and the threshold frame.
        @snippet samples/cpp/tutorial_code/ImgProc/Threshold_inRange.cpp window
    -   Create trackbars to set the range of RGB values
        @snippet samples/cpp/tutorial_code/ImgProc/Threshold_inRange.cpp trackbar
    -   Until the user want the program to exit do the following
        @snippet samples/cpp/tutorial_code/ImgProc/Threshold_inRange.cpp while
    -   Show the images
        @snippet samples/cpp/tutorial_code/ImgProc/Threshold_inRange.cpp show
    -   For a trackbar which controls the lower range, say for example Red value:
        @snippet samples/cpp/tutorial_code/ImgProc/Threshold_inRange.cpp low
    -   For a trackbar which controls the upper range, say for example Red value:
        @snippet samples/cpp/tutorial_code/ImgProc/Threshold_inRange.cpp high
    -   It is necessary to find the maximum and minimum value to avoid discrepancies such as
        the high value of threshold becoming less the low value.

Results
-------

-#  After compiling this program, run it. The program will open two windows

-#  As you set the RGB range values from the trackbar, the resulting frame will be visible in the other window.

    ![](images/Threshold_inRange_Tutorial_Result_input.jpeg)
    ![](images/Threshold_inRange_Tutorial_Result_output.jpeg)