Android OpenCV(四十七):脱色

脱色

脱色是将彩色图像转换为灰度图像的过程。同时,它也是数字打印,风格化的黑白照片渲染以及许多单通道图像处理应用程序中的基本工具。Imgproc.cvtColor(rgb, gray, Imgproc.COLOR_RGB2GRAY)可以快速的实现图片脱色,其通过简单的计算将三通道图像转换成单通道图像,经典的灰度转换公式如下:
G R A Y = 0.299 ∗ R + 0.587 ∗ G + 0.114 ∗ B GRAY=0.299*R+0.587*G+0.114*B GRAY=0.299R+0.587G+0.114B
但是转换过的图像存在对比度丢失,无法区分颜色的问题。OpenCV给我们提供另外一种脱色方法Photo.decolor,旨在最大限度的保留图片对比度。

image-20201205213737621

原理

论文详情:http://www.cse.cuhk.edu.hk/~leojia/projects/color2gray/

论文PDF:https://www.computer.org/csdl/pds/api/csdl/proceedings/download-article/12OmNrJiCLp/pdf

相比于简单的使用R/G/B线性组合,作者构造了更为复杂的多项式拟合,向量空间的基底为:[r,g,b,rg,rb,gb,r2,g2,b2],核心就是求取灰度化函数:
f ( r , g , b ; w ) = ∑ i ( w i m i ) m i 是 向 量 空 间 的 第 i 个 基 底 , 于 是 灰 度 化 问 题 就 转 化 为 求 解 9 个 w 系 数 f(r,g,b;w) = \sum_i(w_im_i)\\ m_i是向量空间的第i个基底,于是灰度化问题就转化为求解9个{w}系数 f(r,g,b;w)=i(wimi)mii9w

API

public static void decolor(Mat src, Mat grayscale, Mat color_boost) 
  • 参数一:src,输入8位三通道图像。
  • 参数二:grayscale,输出8位单通道灰度图。
  • 参数三:color_boost,输出8位三通道图像。对比度增强后的图像。

操作

/**
 * 脱色
 * author: yidong
 * 2020/12/5
 */
class DecolorActivity : AppCompatActivity() {

    private val mBinding: ActivityDecolorBinding by lazy {
        ActivityDecolorBinding.inflate(layoutInflater)
    }

    private val mList = mutableListOf<ImageTextObject>()
    private lateinit var mAdapter: ImageTextAdapter

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(mBinding.root)
        mAdapter = ImageTextAdapter(this, mList)
        mBinding.container.adapter = mAdapter
        val bgr = Utils.loadResource(this, R.drawable.ceil)
        val rgb = Mat()
        Imgproc.cvtColor(bgr, rgb, Imgproc.COLOR_BGR2RGB)
        val gray = Mat()
        val dst = Mat()
        val boost = Mat()
        mBinding.isLoading = true
        GlobalScope.launch(Dispatchers.IO) {
            Imgproc.cvtColor(rgb, gray, Imgproc.COLOR_RGB2GRAY)
            Photo.decolor(rgb, dst, boost)
            launch(Dispatchers.Main) {
                mList.add(ImageTextObject(rgb, "原图"))
                mList.add(ImageTextObject(gray, "RGB2GRAY"))
                mList.add(ImageTextObject(dst, "DeColor"))
                mList.add(ImageTextObject(boost, "ColorBoosting"))
                mAdapter.notifyItemRangeInserted(0, 4)
                mBinding.isLoading = false
            }
        }
    }
}

效果

分别采用decolorRGB2GRAY实现的脱色效果图,在对比度和颜色保留上效果相差很大。

保留对比度脱色

源码

https://github.com/onlyloveyd/LearningAndroidOpenCV

onlyloveyd CSDN认证博客专家 Android Kotlin OpenCV
个人公众号【OpenCV or Android】,热爱Android、Kotlin、Flutter和OpenCV。毕业于华中科技大学计算机专业,曾就职于华为武汉研究所。目前在三线小城市生活,专注Android、OpenCV、Kotlin、Flutter等有趣的技术。
已标记关键词 清除标记
©️2020 CSDN 皮肤主题: 博客之星2020 设计师:CY__ 返回首页