二值化是逐像素处理,而逐像素处理会有很多效果,这主要是给人眼看的,因为像素值的变化,直观的就是图像变化,比如颜色。
OpenCV提供了一些图片,如下:
粗看是一些风格,细看一下,其实是各行颜色一致,看属性知道图像尺寸为256 * 30。
256是字节宽度,也是各通道取值范围。
所以,可以用查表法直接替代处理,即将上面一张图片作为输入,则各行就将原值的0-255映射成为图片相应列的值。图像尺寸设置为30,其实也无所谓多少行,至少一行就行,不过行数太少了,人看起来就感觉,行数多了,读到计算机内存里面处理也浪费。那就折衷选个30吧。
代码处理,这就看水平了,可以一次性全读入,也可以只读取需要的图片。
QString colorMapPath = THelper::File::GetPath_Resource() + "colorMap/";
QStringList fileNames;
THelper::File::BrowseDir(fileNames, colorMapPath, "*.*");
if (!COLORMAP_TABLE) {
if(fileNames.count() > 0) {
COLORMAP_TABLE = new cv::Vec3b[256 * fileNames.count()];
BYTE * pDst = (BYTE*)COLORMAP_TABLE;
foreach(QString fileName, fileNames) {
cv::Mat mat = CvHelper::MatFromFile(fileName);
if(mat.cols * mat.channels() == 256 * 3) {
memcpy(pDst, mat.data, 256 * 3);
pDst += 256 * 3;
}
}
}
}
最终的颜色变幻处理逻辑:
// 其它-颜色变幻
int paramIndex = 0;
FMapIndex = GetParamValue_Int(paramIndex++); // 0: 变幻颜色
Mat tempMat;
cvtColor(dstMat, tempMat, COLOR_BGR2GRAY);
dstMat = cv::Mat(tempMat.rows, tempMat.cols, CV_8UC3);
cv::Vec3b * table = COLORMAP_TABLE + 256 * FMapIndex;
BYTE * pTemp = tempMat.data;
cv::Vec3b * pDst = (cv::Vec3b*)dstMat.data;
for (int row = 0; row < tempMat.rows; ++row)
for (int col = 0; col < tempMat.cols; ++col)
* pDst++ = table[*pTemp++];
本质上还是逐像素处理,这里是查表法,核心逻辑就是* pDst++ = table[*pTemp++];
这个整明白后,那就可以自己设计一个图片作为查表输入,当然有一点点的美工基础更好。
OpenCV中,提供了一个applyColorMap函数,具体文档说明:
/** @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定义,可知其系统提供了22种颜色风格。
//! GNU Octave/MATLAB equivalent colormaps
enum ColormapTypes
{
COLORMAP_AUTUMN = 0, //!< data:image/s3,"s3://crabby-images/a5f27/a5f27a3de1eb146b008fb2485c5c113a09789cc1" alt="autumn"
COLORMAP_BONE = 1, //!< data:image/s3,"s3://crabby-images/8515c/8515c3a47679dfcb08308f9878aa406ca1f67e6c" alt="bone"
COLORMAP_JET = 2, //!< data:image/s3,"s3://crabby-images/3b20f/3b20faf11e4f57f4f814eb526bd392cdd7380a3e" alt="jet"
COLORMAP_WINTER = 3, //!< data:image/s3,"s3://crabby-images/fa8ea/fa8ea9464e280672cca138aeeb8eea2e8ea32789" alt="winter"
COLORMAP_RAINBOW = 4, //!< data:image/s3,"s3://crabby-images/751b7/751b7b3db06f7a9c39ed4fb4c8457161e3a3a46c" alt="rainbow"
COLORMAP_OCEAN = 5, //!< data:image/s3,"s3://crabby-images/b69e4/b69e459d49622d5f8bd7453b65a624ea1edb2cf6" alt="ocean"
COLORMAP_SUMMER = 6, //!< data:image/s3,"s3://crabby-images/41e05/41e050f47b53b9c6f429ba575d3e709fd66715b1" alt="summer"
COLORMAP_SPRING = 7, //!< data:image/s3,"s3://crabby-images/8b9b0/8b9b0a47cc4b7ded4a0ea4991278b58f49a3eab5" alt="spring"
COLORMAP_COOL = 8, //!< data:image/s3,"s3://crabby-images/0dced/0dced982e081725eb7d12c113379be21acb481b7" alt="cool"
COLORMAP_HSV = 9, //!< data:image/s3,"s3://crabby-images/f8b2d/f8b2dfb448572791b7cbf47be4a27e6589b071e0" alt="HSV"
COLORMAP_PINK = 10, //!< data:image/s3,"s3://crabby-images/81969/8196934deeaafa399e28e4711b59de2422cba7a8" alt="pink"
COLORMAP_HOT = 11, //!< data:image/s3,"s3://crabby-images/475bc/475bcef9a1964fdbb44cc3e27cde91badeff7849" alt="hot"
COLORMAP_PARULA = 12, //!< data:image/s3,"s3://crabby-images/6af45/6af4593d9c2b451713b0590b65ecfe8f973ad6dc" alt="parula"
COLORMAP_MAGMA = 13, //!< data:image/s3,"s3://crabby-images/96701/9670159d69fac4806c7987beddf988d025e32ac6" alt="magma"
COLORMAP_INFERNO = 14, //!< data:image/s3,"s3://crabby-images/a37e8/a37e88b313b76c787875707f66c58b535474a746" alt="inferno"
COLORMAP_PLASMA = 15, //!< data:image/s3,"s3://crabby-images/475a9/475a93e757c9105dd87458a032e3b57a3c728719" alt="plasma"
COLORMAP_VIRIDIS = 16, //!< data:image/s3,"s3://crabby-images/73b6b/73b6bf927c2ae74f23ff7d874e86a7c42f898114" alt="viridis"
COLORMAP_CIVIDIS = 17, //!< data:image/s3,"s3://crabby-images/0f278/0f278983725e6dd07931a2dad6ee87d11a0017cd" alt="cividis"
COLORMAP_TWILIGHT = 18, //!< data:image/s3,"s3://crabby-images/4026d/4026d30a1be79f1dcbf93a1b3dec2d88337a49c2" alt="twilight"
COLORMAP_TWILIGHT_SHIFTED = 19, //!< data:image/s3,"s3://crabby-images/9962b/9962bdade95fd0a2ac3bc04718ee8c7d7c880c60" alt="twilight shifted"
COLORMAP_TURBO = 20, //!< data:image/s3,"s3://crabby-images/36df2/36df21921e8cee339a8d5f39fedd6a5a12153918" alt="turbo"
COLORMAP_DEEPGREEN = 21 //!< data:image/s3,"s3://crabby-images/70343/70343c37eeb3348ca1ea0f596305800d24d88a5c" alt="deepgreen"
};
运行效果
OpenCV 4 功能 - 颜色变幻
不过,用applyColorMap的话,受到的制约就是只有这22种效果。也许OpenCV 5会更多一些。要想自由的话,还是直接查表处理,那里啥都有。