C#灰度化图片
acmilan2016/06/25软件综合 IP:四川

C#中可以用ColorMatrix进行颜色变换。ColorMatrix由一个float[][]交错数组组成,5行5列。

横行表示5个颜色源:源R、源G、源B、源Alpha、源1

纵列表示5个颜色目标:目标R、目标G、目标B、目标Alpha、目标1(忽略)

灰度化公式:light = 0.299 * r + 0.587 * g + 0.114 * b

grayscale.png

源代码如下:

<code class="language-cs">using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Drawing.Imaging;
using System.Text;
using System.Windows.Forms;

namespace grayscale
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        Bitmap colorBmp;
        Bitmap grayBmp;

        Bitmap GetGrayScale(Bitmap src)
        {
            // 灰度化公式:
            // light = 0.299 * r + 0.587 * g + 0.114 * b
            float[][] cmatdata =
                    {
                        new float[] {0.299f, 0.299f, 0.299f, 0, 0},
                        new float[] {0.587f, 0.587f, 0.587f, 0, 0},
                        new float[] {0.114f, 0.114f, 0.114f, 0, 0},
                        new float[] {0, 0, 0, 1, 0},
                        new float[] {0, 0, 0, 0, 1},
                    };

            ColorMatrix cmat = new ColorMatrix(cmatdata);

            ImageAttributes imageattr = new ImageAttributes();

            imageattr.SetColorMatrix(cmat);

            Bitmap graybmp = new Bitmap(src.Width, src.Height);

            Graphics.FromImage(graybmp).DrawImage(
                src,
                new Rectangle(0, 0, src.Width, src.Height),
                0, 0, src.Width, src.Height,
                GraphicsUnit.Pixel,
                imageattr
                );

            return graybmp;
        }
        
        private void button1_Click(object sender, EventArgs e)
        {
            OpenFileDialog ofd = new OpenFileDialog();
            ofd.Title = "打开图片";
            if (ofd.ShowDialog() == DialogResult.OK)
            {
                try
                {
                    colorBmp = new Bitmap(ofd.FileName);

                    grayBmp = GetGrayScale(colorBmp);

                    Invalidate();
                }
                catch (Exception err)
                {
                    MessageBox.Show(err.ToString() + "\r\n" + err.StackTrace);
                }
            }
        }

        private void Form_Paint(object sender, PaintEventArgs e)
        {
            if (grayBmp != null)
            {
                e.Graphics.DrawImage(grayBmp, 0, 0, grayBmp.Width, grayBmp.Height);
            }
        }
    }
}
</code>

[修改于 8年6个月前 - 2016/06/25 12:14:04]

来自:计算机科学 / 软件综合
3
已屏蔽 原因:{{ notice.reason }}已屏蔽
{{notice.noticeContent}}
~~空空如也
acmilan 作者
8年6个月前 IP:四川
822024

引用 celeron533 : 我比较好奇的是公式里的这些系数是怎么确定下来的

据传是人眼对各种颜色的敏感度不同。。。

引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论
acmilan作者
8年6个月前 修改于 8年6个月前 IP:四川
822042

灰度化除了使用ColorMatrix以外,也可以自己逐个处理像素颜色,就是比较麻烦一点。除了这个公式以外,还有两个整数运算公式,分别适用于16位机和32位机:

  • light = (r * 30 + g * 59 + b * 11 + 50) / 100
  • light = (r * 299 + g * 587 + b * 114 + 500) / 1000

上述整数运算适用于浮点运算能力差的处理器,实际上在现代Intel计算机上性能提升不明显。

还有一种据传是Adobe中的灰度化算法:

Adobe RGB (1998) [gamma=2.20]

light = (r ^ 2.2 * 0.2973 + g ^ 2.2 * 0.6274 + b ^ 2.2 * 0.0753) ^ (1 / 2.2)

速度慢,但是效果较好。

还有就是最简单的平均值算法,这个最原始,效果也较差。

  • light = (r + g + b) / 3

最暴力的算法是直接拿绿色值作灰度,因为绿色最亮。

  • light = g
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论

想参与大家的讨论?现在就 登录 或者 注册

所属专业
所属分类
上级专业
同级专业
acmilan
进士 学者 笔友
文章
461
回复
2934
学术分
4
2009/05/30注册,5年10个月前活动
暂无简介
主体类型:个人
所属领域:无
认证方式:邮箱
IP归属地:未同步
文件下载
加载中...
{{errorInfo}}
{{downloadWarning}}
你在 {{downloadTime}} 下载过当前文件。
文件名称:{{resource.defaultFile.name}}
下载次数:{{resource.hits}}
上传用户:{{uploader.username}}
所需积分:{{costScores}},{{holdScores}}下载当前附件免费{{description}}
积分不足,去充值
文件已丢失

当前账号的附件下载数量限制如下:
时段 个数
{{f.startingTime}}点 - {{f.endTime}}点 {{f.fileCount}}
视频暂不能访问,请登录试试
仅供内部学术交流或培训使用,请先保存到本地。本内容不代表科创观点,未经原作者同意,请勿转载。
音频暂不能访问,请登录试试
支持的图片格式:jpg, jpeg, png
插入公式
评论控制
加载中...
文号:{{pid}}
投诉或举报
加载中...
{{tip}}
请选择违规类型:
{{reason.type}}

空空如也

加载中...
详情
详情
推送到专栏从专栏移除
设为匿名取消匿名
查看作者
回复
只看作者
加入收藏取消收藏
收藏
取消收藏
折叠回复
置顶取消置顶
评学术分
鼓励
设为精选取消精选
管理提醒
编辑
通过审核
评论控制
退修或删除
历史版本
违规记录
投诉或举报
加入黑名单移除黑名单
查看IP
{{format('YYYY/MM/DD HH:mm:ss', toc)}}