1 所用到的OpenCv API:
/** @brief Applies a GNU Octave/MATLAB equivalent colormap on a given image.
@param src The source image, grayscale or colored of type CV_8UC1 or CV_8UC3.
@param dst The result is the colormapped source image. Note: Mat::create is called on dst.
@param colormap The colormap to apply, see #ColormapTypes
*/
CV_EXPORTS_W void applyColorMap(InputArray src, OutputArray dst, int colormap);
#ColormapTypes
COLORMAP_AUTUMN = 0, //!< data:image/s3,"s3://crabby-images/e8e8a/e8e8a577efdbd2ba790e272e89fd142beecb2d92" alt="autumn"
COLORMAP_BONE = 1, //!< data:image/s3,"s3://crabby-images/23d38/23d38daec4d86929920f75173a3860141221aee8" alt="bone"
COLORMAP_JET = 2, //!< data:image/s3,"s3://crabby-images/44e23/44e23e897dbc0cb6ae702ea7f17340feb02a370a" alt="jet"
COLORMAP_WINTER = 3, //!< data:image/s3,"s3://crabby-images/ae45a/ae45a121e7f42b87bd4b4c8b1c1132c655ab8672" alt="winter"
COLORMAP_RAINBOW = 4, //!< data:image/s3,"s3://crabby-images/53b6b/53b6b15eae9643ae251268caf4acff1d938ff727" alt="rainbow"
COLORMAP_OCEAN = 5, //!< data:image/s3,"s3://crabby-images/d5c58/d5c5817e33d53b8ca25a9d665fff5b85666171ca" alt="ocean"
COLORMAP_SUMMER = 6, //!< data:image/s3,"s3://crabby-images/e6839/e6839ee5eba57e79ed74d6fdd599852594fba067" alt="summer"
COLORMAP_SPRING = 7, //!< data:image/s3,"s3://crabby-images/efdde/efdde761f0ae169b30d168bc56db80cafacd5d32" alt="spring"
COLORMAP_COOL = 8, //!< data:image/s3,"s3://crabby-images/4bd0b/4bd0b1e7384af04adf714dc6e2a645b7f8323d59" alt="cool"
COLORMAP_HSV = 9, //!< data:image/s3,"s3://crabby-images/7410d/7410d6263273d08519225ea02944ee9f3aa6b0bb" alt="HSV"
COLORMAP_PINK = 10, //!< data:image/s3,"s3://crabby-images/c8872/c8872a852f5901d50a1b050af6f264359b1c9e8e" alt="pink"
COLORMAP_HOT = 11, //!< data:image/s3,"s3://crabby-images/187e1/187e17939006e5805f316a7a26e487d277d83231" alt="hot"
COLORMAP_PARULA = 12 //!< data:image/s3,"s3://crabby-images/79b14/79b14f4221bccfa264dd536211a10a6e266238a9" alt="parula"
2 测试代码
#include "opencv2opencv.hpp" #include <iostream> using namespace std; using namespace cv; void myColorMap(Mat &grayImg); int main(int argc, char**argv) { Mat src = imread("G:\CVworkstudy\program_wwx\研习社140课时\ZhaiZhigang140\Blender_Suzanne1.jpg"); if (src.empty()) { printf("Could not load image... "); return -1; } imshow("sourceImg", src); Mat grayLutDemo, dst; // 使用LUT applyColorMap(src, dst, COLORMAP_HSV); // 显示结果 imshow("ColorMap", dst); cvtColor(src, grayLutDemo, COLOR_BGR2GRAY); myColorMap(grayLutDemo); imshow("GrayLutDemo", grayLutDemo); waitKey(0); return 0; } void myColorMap(Mat &grayImg) { int lut[256]; //这个for循环中可以进行其他的操作 使相应的像素值 改变为 指定的像素值 //这里相当于对单通道图像的像素进行二值化处理 for (int i = 0; i < 256; i++) { if (i < 127) { lut[i] = 0; } else lut[i] = 255; } int hight = grayImg.rows; int width = grayImg.cols; for (int row = 0; row < hight; row++) { for (int col = 0; col < width; col++) { uchar pv = grayImg.at<uchar>(row, col); grayImg.at<uchar>(row, col) = lut[pv]; } } }
3 代码运行结果