二值化是逐像素处理,而逐像素处理会有很多效果,这主要是给人眼看的,因为像素值的变化,直观的就是图像变化,比如颜色。
颜色变幻处理
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++];
这个整明白后,那就可以自己设计一个图片作为查表输入,当然有一点点的美工基础更好。
API函数
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/30edd/30edd41012183ae7be2f900d6e75e90c79a1a84c" alt="autumn"
COLORMAP_BONE = 1, //!< data:image/s3,"s3://crabby-images/86bdb/86bdb952af10737abede86b53bc9229636b24743" alt="bone"
COLORMAP_JET = 2, //!< data:image/s3,"s3://crabby-images/894e1/894e16a572fa92c45b65dbae7b01534a2b4a2b0d" alt="jet"
COLORMAP_WINTER = 3, //!< data:image/s3,"s3://crabby-images/0244b/0244b31a2d94051e2adb85ea20d2717c9536d813" alt="winter"
COLORMAP_RAINBOW = 4, //!< data:image/s3,"s3://crabby-images/7fb28/7fb2807916a96c2bcaa09bb550da9a3153011748" alt="rainbow"
COLORMAP_OCEAN = 5, //!< data:image/s3,"s3://crabby-images/142fa/142fa831124eb3901c847fade2d7a23264e6e7fa" alt="ocean"
COLORMAP_SUMMER = 6, //!< data:image/s3,"s3://crabby-images/cb303/cb303263196cb00d4b676bda3a69a357b7cdd9b9" alt="summer"
COLORMAP_SPRING = 7, //!< data:image/s3,"s3://crabby-images/b016c/b016c1629bd850655cb4541ca84168d3edea3111" alt="spring"
COLORMAP_COOL = 8, //!< data:image/s3,"s3://crabby-images/2ba20/2ba2044d280ae14b6c599d84ae444f84f5a60841" alt="cool"
COLORMAP_HSV = 9, //!< data:image/s3,"s3://crabby-images/dfa6e/dfa6e05d3ba691b6706813aa5b970ab9fa58dcc3" alt="HSV"
COLORMAP_PINK = 10, //!< data:image/s3,"s3://crabby-images/eb43c/eb43c82f6c1a91fb8a5d6c5d6bf2a396cb71383d" alt="pink"
COLORMAP_HOT = 11, //!< data:image/s3,"s3://crabby-images/e8c7f/e8c7f79203275ce1f3aa7352fcf81ceec3656bca" alt="hot"
COLORMAP_PARULA = 12, //!< data:image/s3,"s3://crabby-images/2a714/2a71478b18c550ffc6d329f5348c5659705c1ab8" alt="parula"
COLORMAP_MAGMA = 13, //!< data:image/s3,"s3://crabby-images/847c8/847c8e5ee408b5f234a9fddd5ce36c892a3195b2" alt="magma"
COLORMAP_INFERNO = 14, //!< data:image/s3,"s3://crabby-images/226ba/226bac4f22ba608561dab61f0f0f401a988b3270" alt="inferno"
COLORMAP_PLASMA = 15, //!< data:image/s3,"s3://crabby-images/8be00/8be008cbd07350fbf07198dfdb087914627f7553" alt="plasma"
COLORMAP_VIRIDIS = 16, //!< data:image/s3,"s3://crabby-images/227ac/227acc93efeb246ca36493e1388001e94ce3559b" alt="viridis"
COLORMAP_CIVIDIS = 17, //!< data:image/s3,"s3://crabby-images/e8aef/e8aef9cc2a7352e9c8c1d7c68a869b553a92862c" alt="cividis"
COLORMAP_TWILIGHT = 18, //!< data:image/s3,"s3://crabby-images/61fea/61fea51dd531ea99ccceb2fff786e64b65fa1618" alt="twilight"
COLORMAP_TWILIGHT_SHIFTED = 19, //!< data:image/s3,"s3://crabby-images/7b8f2/7b8f299848b86092c56d849491311f90d06a68e5" alt="twilight shifted"
COLORMAP_TURBO = 20, //!< data:image/s3,"s3://crabby-images/951b2/951b2da95cec56b153dacbe1a77a4890601c9006" alt="turbo"
COLORMAP_DEEPGREEN = 21 //!< data:image/s3,"s3://crabby-images/3766d/3766d15e6ea9b37047e3b9c2bc783e1532ff8982" alt="deepgreen"
};
运行效果
OpenCV 4 功能 - 颜色变幻
不过,用applyColorMap的话,受到的制约就是只有这22种效果。也许OpenCV 5会更多一些。要想自由的话,还是直接查表处理,那里啥都有。