17.3.1.4 浮雕

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

浮雕的算法主要有以下两种:

1、相邻两个像素的红绿蓝颜色分量值差再加上一个常数。例如:从第二列像素开始,下一列的红绿蓝颜色分量值等于该列红绿蓝颜色分量值减去上一列的红绿蓝颜色分量,再加上128。如果小于0,那么等于0,如果大于255,那么等于255。

原图像:颜色值color=(R,G,B)

RNew=R(i,j)-R(i-1,j)+128

GNew=G(i,j)-G(i-1,j)+128

BNew=B(i,j)-B(i-1,j)+128

第一列像素值不会有变化。

2、相邻两个像素的红绿蓝颜色分量值差的绝对值再加上一个常数。例如:从第二列像素开始,下一列的红绿蓝颜色分量值等于该行红绿蓝颜色分量减去上一列的红绿蓝颜色分量的绝对值,再加上128。如果小于0,那么等于0,如果大于255,那么等于255。

RNew=Abs(R(i,j)-R(i-1,j))+128

GNew=Abs(G(i,j)-G(i-1,j))+128

BNew=Abs(B(i,j)-B(i-1,j))+128

第一列像素值不会有变化。

【例 17.36 **】**浮雕算法一。

cs 复制代码
       //浮雕1
        private void btnEmboss1_Click(object sender, EventArgs e)
        {
            Color pSourceColor1;
            Color pSourceColor2;
            Color pDestColor;

            Bitmap destImg = new Bitmap(sourceImg.Width, sourceImg.Height);
            int R, G, B;
            int R1, G1, B1;
            int R2, G2, B2;

            for (int i = 0; i < sourceImg.Width; i++)
            {
                for (int j = 0; j < sourceImg.Height; j++)
                {
                    //如果是图像第一列像素数据,那么使用灰度均值
                    if (i == 0)
                    {

                        pSourceColor1 = sourceImg.GetPixel(i, j);
                        R1 = pSourceColor1.R;
                        G1 = pSourceColor1.G;
                        B1 = pSourceColor1.B;

                        B = (R1 + G1 + B1) / 3;
                        pDestColor = Color.FromArgb(B, B, B);
                        destImg.SetPixel(i, j, pDestColor);
                    }
                    else
                    {
                        pSourceColor1 = sourceImg.GetPixel(i, j);
                        R1 = pSourceColor1.R;
                        G1 = pSourceColor1.G;
                        B1 = pSourceColor1.B;

                        pSourceColor2 = sourceImg.GetPixel(i - 1, j);
                        R2 = pSourceColor2.R;
                        G2 = pSourceColor2.G;
                        B2 = pSourceColor2.B;

                        R = R2 - R1 + 128;
                        G = G2 - G1 + 128;
                        B = B2 - B1 + 128;

                        if( R < 0)
                            R = 0;
                        if( R > 255)
                            R = 255;
                        if( G < 0 )
                            G = 0;
                        if( G > 255)
                            G = 255;
                        if( B < 0)
                            B = 0;
                        if( B > 255)
                            B = 255;
                        pDestColor = Color.FromArgb(R, G, B);
                        destImg.SetPixel(i, j, pDestColor);
                    }
                }
            }
            picDest.Image = destImg;
        }

运行结果如下图所示:

图17-40 浮雕处理一

【例 17.37 **】**浮雕算法二。

cs 复制代码
       //浮雕2
        private void btnEmboss2_Click(object sender, EventArgs e)
        {
            Color pSourceColor1;
            Color pSourceColor2;
            Color pDestColor;

            Bitmap destImg = new Bitmap(sourceImg.Width, sourceImg.Height);
            int R, G, B;
            int R1, G1, B1;
            int R2, G2, B2;

            for (int i = 0; i < sourceImg.Width; i++)
            {
                for (int j = 0; j < sourceImg.Height; j++)
                {
                    //如果是图像第一列像素数据,那么使用灰度均值
                    if (i == 0)
                    {
                        pSourceColor1 = sourceImg.GetPixel(i, j);
                        R1 = pSourceColor1.R;
                        G1 = pSourceColor1.G;
                        B1 = pSourceColor1.B;

                        B = (R1 + G1 + B1) / 3;
                        pDestColor = Color.FromArgb(B, B, B);
                        destImg.SetPixel(i, j, pDestColor);
                    }
                    else
                    {
                        pSourceColor1 = sourceImg.GetPixel(i, j);
                        R1 = pSourceColor1.R;
                        G1 = pSourceColor1.G;
                        B1 = pSourceColor1.B;

                        pSourceColor2 = sourceImg.GetPixel(i - 1, j);
                        R2 = pSourceColor2.R;
                        G2 = pSourceColor2.G;
                        B2 = pSourceColor2.B;

                        R = Math.Min(Math.Abs(R1 - R2) + 128, 255);
                        G = Math.Min(Math.Abs(G1 - G2) + 128, 255);
                        B = Math.Min(Math.Abs(B1 - B2) + 128, 255);

                        pDestColor = Color.FromArgb(R, G, B);
                        destImg.SetPixel(i, j, pDestColor);
                    }
                }
            }
            picDest.Image = destImg;
        }

运行结果如下图所示:

图17-41 浮雕处理二

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

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

相关推荐
ZZZ_O^O17 分钟前
二分查找算法——寻找旋转排序数组中的最小值&点名
数据结构·c++·学习·算法·二叉树
CV-King40 分钟前
opencv实战项目(三十):使用傅里叶变换进行图像边缘检测
人工智能·opencv·算法·计算机视觉
代码雕刻家1 小时前
数据结构-3.9.栈在递归中的应用
c语言·数据结构·算法
雨中rain1 小时前
算法 | 位运算(哈希思想)
算法
IT良2 小时前
c#增删改查 (数据操作的基础)
开发语言·c#
yufei-coder2 小时前
掌握 C# 中的 LINQ(语言集成查询)
windows·vscode·c#·visual studio
Kalika0-03 小时前
猴子吃桃-C语言
c语言·开发语言·数据结构·算法
sp_fyf_20243 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-02
人工智能·神经网络·算法·计算机视觉·语言模型·自然语言处理·数据挖掘
我是哈哈hh5 小时前
专题十_穷举vs暴搜vs深搜vs回溯vs剪枝_二叉树的深度优先搜索_算法专题详细总结
服务器·数据结构·c++·算法·机器学习·深度优先·剪枝
Tisfy5 小时前
LeetCode 2187.完成旅途的最少时间:二分查找
算法·leetcode·二分查找·题解·二分