In the context of CV2 in Python, when you read an image, it is stored as a 2D or 3D array of Y and X coordinates with uint8 values indicating the color and brightness of the image. The term uint8 refers to an 8-bit unsigned integer data type that ranges from 0 to 255. This, combined with 3 channels for Red, Green, and Blue (RGB), forms a color image.
If you start altering parts of the image like a normal array (e.g., dividing it by 3), you may lose this format. For instance, pixel values may fall outside the range of 0 to 255, causing the image to become unusable. Understanding this structure is crucial for manipulating images correctly.
In the CV2 Python library, you can easily view an image using the following code snippet:
#pip install opencv-python # if not already installed import cv2 # Load an image image = cv2.imread('./test.png') # Display the image in a window cv2.imshow('Image', image) cv2.waitKey(0) cv2.destroyAllWindows()
The code above will open a popup window displaying the image on your computer. Feel free to add a url to your own image to test. You can then zoom in to observe the pixel-level RGB values of the image. This basic functionality is a great starting point for exploring image processing.
Mathematically, brightness and contrast can be adjusted using the formula:
new_image=contrast×image brightness
The cv2.convertScaleAbs() function in OpenCV automates this process. It applies the formula above while ensuring that pixel values remain within the range of 0 to 255.
Here’s how it works:
Example Usage:
new_image = cv2.convertScaleAbs(image, alpha=contrast, beta=brightness)
This allows us to easily modify brightness and contrast without manually clipping pixel values.
image = cv2.imread('./test.png') cv2.namedWindow('Adjustments') contrast=0.8 brightness=89 image=cv2.convertScaleAbs(image, alpha=contrast, beta=brightness) cv2.imshow('Adjustments', image) cv2.waitKey(0) cv2.destroyAllWindows()
While a one-time adjustment is useful, most of the time, we want to tweak brightness and contrast interactively. OpenCV allows us to achieve this using trackbar.
Trackbars can be created with cv2.createTrackbar(), which lets us adjust values dynamically. The general syntax is:
cv2.createTrackbar(trackbarname, winname, value, count, onChange_function)
These trackbar then can be called in the onChange_function with;
cv2.getTrackbarPos(trackbarname, winname)
・trackbarname: The name of the trackbar
・ winname: The name of the OpenCV window where the trackbar will be displayed.
To adjust both brightness and contrast, we will need two trackbars.
#pip install opencv-python # if not already installed import cv2 # Load an image image = cv2.imread('./test.png') # Display the image in a window cv2.imshow('Image', image) cv2.waitKey(0) cv2.destroyAllWindows()
Adjusting the contrast and brightness sliders triggers the on_change function, which reads the values from the trackbars using cv2.getTrackbarPos(). These values are then applied to the image using the cv2.convertScaleAbs function, and the updated image is displayed in real-time.
To make the app more user-friendly, I added a simple snippet at the end to allow users to exit by pressing the x key. This addresses a common issue with OpenCV, where closing the window doesn’t always stop the code from running. By implementing this, the app ensures a clean exit without lingering processes.
The above is the detailed content of CVWhat is an Image?, Lets adjust the Brightness and Contrast of an image. For more information, please follow other related articles on the PHP Chinese website!