17.3.1.6 自定义处理

news2024/12/24 20:35:16

版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。

模拟某款图像处理软件的处理,它只留下红色、绿色或者蓝色这样的单一颜色。

首先按照颜色划分了6个色系,分别是 红R、绿G、蓝B、紫P、黄Y、青A,其他N(也就是需要处理为灰度的颜色)。红、绿、蓝三原色分别对应颜色(R=255;G=0;B=0)、(R=0;G=255;B=0)和(R=0;G=0;B=255);紫色对应的是(R=255;G=0;B=255)、黄色对应的是(R=255;G=255;B=0);青色对应的是(R=0;G=255;B=255),其它颜色按照灰度处理用来衬托前面的6个色系颜色。

如果只是按照绝对的RGB颜色值来划分,例如单纯的取红色(R=255,G=0,B=0),其实在图像中是比较少见的,而且和红色接近的颜色(R=236,G=0,B=0),肉眼所见也属于红色范畴。考虑到某个色系颜色其实也是在三原色分量上交错分布(比如红色系并不只是在R分量上线性分布的),如果单纯的将R、G、B值记录到数据库来作为划分的依据,工作量比较大。因此使用以下简单的算法对几种颜色分布进行划分:

1、红色系分布:

R > 128,并且 R - G > 30,并且 R - B > 30。

2、绿色系分布:

G > 80,并且G - R > 5,并且(G - B > 20) 或 (B - G) < 10。

3、蓝色系分布:

B > 80,并且B - R > 50,并且B - G > 30。

4、紫色系分布:

R > 128,并且B > 128,并且R - G > 30,并且B - G > 30。

5、黄色系分布:

R > 140,并且G > 120,并且Math.Abs(G - R) < 40,并且R - B > 80,并且G - B > 80。

6、青色系分布:

G > 180,并且B > 180,并且(B >= G) 或 (G - B) < 10) ,并且B - R > 40,并且G - R > 40。

7、其它颜色:

处理成灰度。

【例 17.40自定义图像处理,保留图像上的单一色系或者多个色系。

       //自定义图像处理
        private void btnCustom_Click(object sender, EventArgs e)
        {
            Color pSourceColor;
            Color pDestColor;

            Bitmap destImg = new Bitmap(sourceImg.Width, sourceImg.Height);

            for (int i = 0; i < sourceImg.Width; i++)
            {
                for (int j = 0; j < sourceImg.Height; j++)
                {
                    pSourceColor = sourceImg.GetPixel(i, j);
                    //根据选择情况,保留选定的色系,其它颜色处理成灰度
                    switch( getSingleColor(pSourceColor))
                    {
                        case "R":
                            if (cbR.Checked == true)
                                pDestColor = pSourceColor;
                            else
                                pDestColor = getAverage(pSourceColor);
                        break;
                        case "G":
                            if (cBG.Checked == true)
                            pDestColor = pSourceColor;
                            else
                                pDestColor = getAverage(pSourceColor);
                            break;
                        case "B":
                            if (cbB.Checked == true)
                                pDestColor = pSourceColor;
                            else
                                pDestColor = getAverage(pSourceColor);
                            break;
                        case "P":
                            if (cbP.Checked == true)
                                pDestColor = pSourceColor;
                            else
                                pDestColor = getAverage(pSourceColor);
                            break;
                        case "Y":
                            if (cbY.Checked == true)
                                pDestColor = pSourceColor;
                            else
                                pDestColor = getAverage(pSourceColor);
                            break;
                        case "A":
                            if (cbA.Checked == true)
                                    pDestColor = pSourceColor;
                                else
                                    pDestColor = getAverage(pSourceColor);
                            break;
                    default:
                            pDestColor = getAverage(pSourceColor);
                            break;
                    }
                    
                destImg.SetPixel(i, j, pDestColor);
                }
            }
            picDest.Image = destImg;
        }

         //计算所属色系,并返回色系缩写字母
        private string getSingleColor(Color rgb)
        {
            byte R, G, B;
            R = rgb.R;
            G = rgb.G;
            B = rgb.B;
            if((R > 128) && (R - G > 30) && (R - B > 30))
                    return "R";
            if ((G > 80) && (G - R > 5) && ((G - B > 20) | (B - G) < 10))
                return "G";
            if ((B > 80) && (B - R > 50) && (B - G > 30))
                return "B";
            if ((R > 128) && (B > 128) && (R - G > 30) && (B - G > 30))
                return "P";
            if ((R > 140) && (G > 120) && (Math.Abs(G - R) < 40) && (R - B > 80) && (G - B > 80))
                return "Y";
            if((G > 180) &&(B > 180) &&((B >= G) | (G - B) < 10) &&(B - R > 40) &&(G - R > 40))
                return "A";
            return "N";
        }


        //计算灰度均值,返回灰度颜色
        private Color getAverage(Color rgb)
        {
            byte R, G, B;
            byte gray;

            R = rgb.R;
            G = rgb.G;
            B = rgb.B;
            gray = (byte)((R + G + B) / 3);
            Color newColor = Color.FromArgb(gray, gray, gray);
            return newColor;
        }

运行结果如下图所示:

图17-44 自定义处理

学习更多vb.net知识,请参看vb.net 教程 目录

学习更多C#知识,请参看 C# 教程 目录

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1460612.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

集成使用 GitHub Copilot 提升 IDEA 开发效率

集成使用 GitHub Copilot 提升 IDEA 开发效率 在现代软件开发中&#xff0c;集成开发环境&#xff08;IDE&#xff09;如IntelliJ IDEA已经成为开发人员不可或缺的工具。它们提供了代码编辑、调试、版本控制等一系列功能&#xff0c;极大地提高了开发效率。而GitHub Copilot作…

【云原生】Docker consul的容器服务更新与发现

目录 什么是服务注册与发现 什么是consul consul提供的一些关键特性&#xff1a; consul 部署 consul服务器 1. 建立 Consul 服务 设置代理&#xff0c;在后台启动 consul 服务端 2. 查看集群信息 查看members状态 查看集群状态 3. 通过 http api 获取集群信息 regi…

kali linux出现添加源无法更新的问题:更新时显示签名无效和没有数字签名

kali linux更新源时显示签名无效和没有数字签名 一、出现显示签名无效和没有数字签名二、 解决办法三、几种开源镜像站 一、出现显示签名无效和没有数字签名 原因&#xff1a;因为没有下载签名&#xff0c;所以显示签名无效和没有数字签名 二、 解决办法 wget archive.kali.o…

mysql online ddl更改varchar长度的锁表情况

我们只看5.7及其之后的版本&#xff0c;官方文档&#xff1a;https://dev.mysql.com/doc/refman/5.7/en/innodb-online-ddl.html https://dev.mysql.com/doc/refman/8.0/en/innodb-online-ddl.html mysql online ddl的特性是指&#xff0c;支持以instant&#xff08;8.0版本开…

线性筛法与欧拉函数

文章目录 筛法求质数欧拉函数基本模板筛法求欧拉函数 每次从最小质数开始遍历&#xff0c;可以保证n只会被最小质数筛到&#xff0c; 避免多次筛到&#xff0c; 每个数只会被筛一次&#xff0c; 即时间复杂度为 O ( n ) O(n) O(n)&#xff0c; 线性筛法 筛法求质数 原题链接&a…

3、windows环境下vscode开发c/c++环境配置(二)

前言&#xff1a;上一篇文章写了windows环境下&#xff0c;配置vscode的c/c开发环境&#xff0c;这一篇讲vscode开发c/c的配置文件&#xff0c;包括c_cpp_propertues.json&#xff0c;task.json及launch.json。 一、总体流程 通过c/c插件我们就可以来编写c/c程序了&#xff0c…

77、Spring、Spring Boot和Spring Cloud的关系

77、Spring、Spring Boot和Spring Cloud的关系 随着 Spring、Spring Boot 和 Spring Cloud 的不断发展&#xff0c;越来越多的开发者加入 Spring 的大军中。对于初学者而言&#xff0c;可能不太了解 Spring、Spring Boot 和 Spring Cloud 这些概念以及它们之间的关系&#xff…

强化学习入门(Matlab2021b)-创建环境【2】

目录 1 前言2 利用step和reset函数创建自定义环境2.1 对象描述2.2 reset函数2.3 step函数2.3 构建自定义环境3 使用匿名函数传递额外的参数4 可视化检查自定义函数的输出参考链接1 前言 本文介绍如何基于MATLAB编写step、reset函数,创建自己的强化学习环境(Environment)。 使…

ThreadLocal(5):ThreadLocalMap源码分析

在分析ThreadLocal方法的时候&#xff0c;我们了解到ThreadLocal的操作实际上是围绕ThreadLocalMap展开的。ThreadLocalMap的源码相对比较复杂, 我们从以下三个方面进行讨论。 1 基本结构 ​ ThreadLocalMap是ThreadLocal的内部类&#xff0c;没有实现Map接口&#xff0c;用独…

Vue2路由组件练习

Vue2路由组件练习 1. 演示效果 2. 代码分析 2.1. 安装 vue-router 命令&#xff1a;npm i vue-router 应用插件&#xff1a;Vue.use(VueRouter) 2.2. 创建路由文件 在 src 文件夹下&#xff0c;创建router文件夹&#xff0c;并在该文件夹创建index.js文件 2.3. 导入依赖…

SpringBootWeb学习笔记——12万字详细总结!

0. 写在前面 注:这套笔记是根据黑马程序员B站2023-3-21的视频学习的成果,其中省略了前端基础部分、Maven部分和数据库基础部分,详情可见目录。 注注:目前文章内结尾处多幅图片加载不出来,因为图片还存在本地没被传上来,过段时间再改~ 所有的Spring项目都基于Spring Fra…

linux 修改开发板网卡eth0的ip地址

win10如何新增电脑ip地址&#xff1a; https://blog.csdn.net/linxinfa/article/details/105817473 ifconfig # 可设置网络设备的状态&#xff0c;或是显示目前的设置。 命令详解&#xff1a;https://www.runoob.com/linux/linux-comm-ifconfig.html 一、临时修改 ifconfig e…

「Qt Widget中文示例指南」如何实现文档查看器?(一)

Qt 是目前最先进、最完整的跨平台C开发工具。它不仅完全实现了一次编写&#xff0c;所有平台无差别运行&#xff0c;更提供了几乎所有开发过程中需要用到的工具。如今&#xff0c;Qt已被运用于超过70个行业、数千家企业&#xff0c;支持数百万设备及应用。 文档查看器是一个显…

基于springboot+vue的洗衣店订单管理系统(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战&#xff0c;欢迎高校老师\讲师\同行交流合作 ​主要内容&#xff1a;毕业设计(Javaweb项目|小程序|Pyt…

【水处理】水环境治理综合服务,污水一体化管控平台

水是人类生活中不可或缺的资源之一。然而&#xff0c;随着人口的增长和工业化的进程&#xff0c;水资源的压力日益增大。由于污染和过度开采&#xff0c;全球许多地区面临水资源短缺的问题。因此&#xff0c;水处理成为了一个至关重要的问题&#xff0c;旨在净化和保护重要的水…

【Python笔记-设计模式】适配器模式

一、说明 适配器模式是一种结构型模式&#xff0c;它使接口不兼容的对象能够相互合作 (一) 解决问题 主要解决接口不兼容问题 (二) 使用场景 当系统需要使用现有的类&#xff0c;但类的接口不符合需求时当需要一个统一的输出接口&#xff0c;但输入类型不可预知时当需要创…

Nginx 反向代理配置

Nginx就不废话了&#xff0c;web服务器。 最近在备案一个域名&#xff0c;想要备案&#xff0c;部署一个服务器&#xff0c;平常很少自己配置Nginx&#xff0c;今天记录下。 1、反向代理 正向代理 指 客户端通过代理访问后端服务 反向代理 指 服务器推出一个客户&#xff0…

最优二叉搜索树 C#实现

最优二叉搜索树 C#实现 介绍一下 上一篇博文搞半天挺烧脑&#xff0c;没搞清楚继续… 主要是练习动态规划算法。最关键的一个是这个最优二叉搜索树能干啥。我认为如果数据稳定&#xff0c;统计出概率来&#xff0c;用最优二叉树保存&#xff0c;以后搜索应该是效率比较高的。…

五种多目标优化算法(MOJS、MOGWO、NSWOA、MOPSO、NSGA2)性能对比,包含6种评价指标,9个测试函数(提供MATLAB代码)

一、5种多目标优化算法简介 1.1MOJS 1.2MOGWO 1.3NSWOA 1.4MOPSO 1.5NSGA2 二、5种多目标优化算法性能对比 为了测试5种算法的性能将其求解9个多目标测试函数&#xff08;zdt1、zdt2 、zdt3、 zdt4、 zdt6 、Schaffer、 Kursawe 、Viennet2、 Viennet3&#xff09;&#xff0…

计算机设计大赛 深度学习人脸表情识别算法 - opencv python 机器视觉

文章目录 0 前言1 技术介绍1.1 技术概括1.2 目前表情识别实现技术 2 实现效果3 深度学习表情识别实现过程3.1 网络架构3.2 数据3.3 实现流程3.4 部分实现代码 4 最后 0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 深度学习人脸表情识别系…