图形处理特效

一、反色:

图像反色实际上就是取没一个像素点的相对颜色值
比如图像某点像素RGB(128,52,38),则它的反色值为RGB(127,203,217)

单击在新窗口中打开图片,Ctrl+滚轮缩放图片

/// <summary>
/// 以反色方式显示图像    
/// </summary>
/// <param name="SImage">源图像</param>
/// <returns>反色处理后的图像</returns>

public  Bitmap fanSe(Image SImage)
{
    
int Height = SImage.Height;
    
int Width = SImage.Width;
    Bitmap bitmap 
= new Bitmap(Width, Height);
    Bitmap MyBitmap 
= (Bitmap) SImage;
    Color pixel;
    
for (int x = 1; x < Width; x++)
    
{
        
for (int y = 1; y < Height; y++)
        
{
            
int r, g, b;
            pixel 
= MyBitmap.GetPixel(x, y);
            r 
= 255 - pixel.R;
            g 
= 255 - pixel.G;
            b 
= 255 - pixel.B;
            bitmap.SetPixel(x, y, Color.FromArgb(r, g, b));
        }

    }

    
return bitmap;
}


二、浮雕:

通过对图像相邻像素点的像素值分别与相邻像素点的像素值相减之后加上一个常量128,然后作为新的像素点值(为防止颜色值溢出,需处理值小于0和大于255的情况颜色值),可以使图像产生 浮雕效果

单击在新窗口中打开图片,Ctrl+滚轮缩放图片 
二、浮雕:

通过对图像相邻像素点的像素值分别与相邻像素点的像素值相减之后加上一个常量128,然后作为新的像素点值(为防止颜色值溢出,需处理值小于0和大于255的情况颜色值),可以使图像产生 浮雕效果

单击在新窗口中打开图片,Ctrl+滚轮缩放图片 
/// <summary> 
///以浮雕方式显示图像        
/// </summary>
/// <param name="SImage">源图像</param>
/// <returns>浮雕效果处理后的图像</returns>

public  Bitmap fuDiao(Image SImage)
{
    
int Height = SImage.Height;
    
int Width = SImage.Width;
    Bitmap bitmap 
= new Bitmap(Width, Height);
    Bitmap MyBitmap 
= (Bitmap) SImage;
    Color pixel1, pixel2;
    
for (int x = 0; x < Width - 1; x++)
    
{
        
for (int y = 0; y < Height - 1; y++)
        
{
            
int r = 0, g = 0, b = 0;
            pixel1 
= MyBitmap.GetPixel(x, y);
            pixel2 
= MyBitmap.GetPixel(x + 1, y + 1);
            r 
= pixel1.R - pixel2.R + 128;
            g 
= pixel1.G - pixel2.G + 128;
            b 
= pixel1.B - pixel2.B + 128;
            
if (r > 255)
                r 
= 255;
            
if (r < 0)
                r 
= 0;
            
if (g > 255)
                g 
= 255;
            
if (g < 0)
                g 
= 0;
            
if (b > 255)
                b 
= 255;
            
if (b < 0)
                b 
= 0;
            bitmap.SetPixel(x, y, Color.FromArgb(r, g, b));
        }

    }

    
return bitmap;
}
三、黑白化处理:

彩色图像 黑白化处理通常有三种方法:最大值法、平均值法、加权平均值法
三种方法的原理

最大值法:最大值法是每个像素点的RGB值等于原像素点的RGB值中最大的一个,

即R=G=B=MAX( R,G,B ); 效果,最大值发产生亮度很高的黑白图像

平均值法:平均值法使每个像素点的RGB值等于原像素点的RGB值的平均值,即R=G=B=(R+G+B)/3 

加权平均法:加权平均法根据需要指定每个像素点RGB的权数,并取其加权平均值,

即R=G=B=(Wr*R+Wg*G+Wb*B )/3 

Wr、Wg、Wb表示RGB的权数,均大于零,通过取不同的权数可实现不同的效果 

单击在新窗口中打开图片,Ctrl+滚轮缩放图片 
/// <summary>
/// 以黑白方式显示图像
/// </summary>
/// <param name="SImage">源图像</param>
/// <param name="iType">黑白处理的方法参数,0-平均值法;1-最大值法;2-加权平均值法</param>
/// <returns></returns>

public  Bitmap heiBai(Image SImage,  int  iType)
{
    
int Height = SImage.Height;
    
int Width = SImage.Width;
    Bitmap bitmap 
= new Bitmap(Width, Height);
    Bitmap MyBitmap 
= (Bitmap) SImage;
    Color pixel;
    
for (int x = 0; x < Width; x++)
        
for (int y = 0; y < Height; y++)
        
{
            pixel 
= MyBitmap.GetPixel(x, y);
            
int r, g, b, Result = 0;
            r 
= pixel.R;
            g 
= pixel.G;
            b 
= pixel.B;

            
switch (iType)
            
{
            
case 0://平均值法
                Result = ((r + g + b) / 3);
                
break;
            
case 1://最大值法
                Result = r > g ? r : g;
                Result 
= Result > b ? Result : b;
                
break;
            
case 2://加权平均值法
                Result = ((int) (0.7 * r) + (int) (0.2 * g) + (int) (0.1 * b));
                
break;
            }

            bitmap.SetPixel(x, y, Color.FromArgb(Result, Result, Result));
        }

    
return bitmap;
}
四、柔化:

柔化显示图像和 锐化显示图像的操作刚好相反,但在算法上不是它的逆过程。它的主要思想是减少图像边缘值之间的剧烈变化。

当将当前像素点的颜色值设为以该像素为中心的像素块中所有像素的平均值时,如果当前像素点的颜色值和周围相邻像素点的颜色值差别不大时,则取平均值不会产生显著影响;如果差别较大时,取平均值后,就会使当前像素点的颜色趋于一致,这样就达到了 柔化图像的目的。也称这种方法为高斯模板

单击在新窗口中打开图片,Ctrl+滚轮缩放图片 
/// <summary>
/// 以柔化方式显示图像    
/// </summary>
/// <Note>高斯模板法</Note>
/// <param name="SImage">源图像</param>
/// <returns>柔化处理后的图像</returns>

public  Bitmap rouHua(Image SImage)
{
    
int Height = SImage.Height;
    
int Width = SImage.Width;
    Bitmap bitmap 
= new Bitmap(Width, Height);
    Bitmap MyBitmap 
= (Bitmap) SImage;
    Color pixel;
    
//高斯模板
    int[] Gauss =121242121 };
    
for (int x = 1; x < Width - 1; x++)
        
for (int y = 1; y < Height - 1; y++)
        
{
            
int r = 0, g = 0, b = 0;
            
int Index = 0;
            
//int a=0;
            for (int col = -1; col <= 1; col++)
                
for (int row = -1; row <= 1; row++)
                
{
                    pixel 
= MyBitmap.GetPixel(x + row, y + col);
                    r 
+= pixel.R * Gauss[Index];
                    g 
+= pixel.G * Gauss[Index];
                    b 
+= pixel.B * Gauss[Index];
                    Index
++;
                }

            r 
/= 16;
            g 
/= 16;
            b 
/= 16;
            
//处理颜色值溢出
            r = r > 255 ? 255 : r;
            r 
= r < 0 ? 0 : r;
            g 
= g > 255 ? 255 : g;
            g 
= g < 0 ? 0 : g;
            b 
= b > 255 ? 255 : b;
            b 
= b < 0 ? 0 : b;
            bitmap.SetPixel(x 
- 1, y - 1, Color.FromArgb(r, g, b));
        }

    
return bitmap;
}
五、锐化:

图像的 锐化就是要显示图像中有关形体的边缘。所谓形体的边缘就是图像像素点的颜色值发生显著变化的地方,在图像的平淡区,这种颜色值的变化比较平缓,而在图像的边缘区域这种变化相当明显。
也就是说在平缓区,相邻两像素的颜色值的差值较小,而在边缘区域,相邻两像素的颜色值变化抖得多,因而在边缘区域处理这个数值可以使突出效果更加突出,而在非边缘区域而使图像变得较暗,即图像的 锐化。拉普拉斯模块法

单击在新窗口中打开图片,Ctrl+滚轮缩放图片 
/// <summary>
/// 以锐化方式显示图像        
/// </summary>
/// <Note>拉普拉斯模板法</Note>
/// <param name="SImage">源图像</param>
/// <returns>锐化处理后的图像</returns>

public  Bitmap ruiHua(Image SImage)
{
    
int Height = SImage.Height;
    
int Width = SImage.Width;
    Bitmap bitmap 
= new Bitmap(Width, Height);
    Bitmap MyBitmap 
= (Bitmap) SImage;
    Color pixel;
    
//拉普拉斯模板
    int[] Laplacian =-1-1-1-19-1-1-1-1 };
    
for (int x = 1; x < Width - 1; x++)
        
for (int y = 1; y < Height - 1; y++)
        
{
            
int r = 0, g = 0, b = 0;
            
int Index = 0;
            
int a = 0;
            
for (int col = -1; col <= 1; col++)
                
for (int row = -1; row <= 1; row++)
                
{
                    pixel 
= MyBitmap.GetPixel(x + row, y + col);
                    r 
+= pixel.R * Laplacian[Index];
                    g 
+= pixel.G * Laplacian[Index];
                    b 
+= pixel.B * Laplacian[Index];
                    Index
++;
                }

            
//处理颜色值溢出
            r = r > 255 ? 255 : r;
            r 
= r < 0 ? 0 : r;
            g 
= g > 255 ? 255 : g;
            g 
= g < 0 ? 0 : g;
            b 
= b > 255 ? 255 : b;
            b 
= b < 0 ? 0 : b;
            bitmap.SetPixel(x 
- 1, y - 1, Color.FromArgb(r, g, b));
        }

    
return bitmap;
}
六、雾化:

图像 雾化处理不是基于图像中像素点的运算,而是在图像中引入一定的随机性,使图像带有毛玻璃带水雾般的效果。

影响图像 雾化效果的一个重要因素是图像中像素块的确定,所选区的像素块越大,产生的效果越明显。

单击在新窗口中打开图片,Ctrl+滚轮缩放图片 
/// <summary>
/// 以雾化方式显示图像
/// </summary>
/// <param name="SImage"></param>
/// <returns></returns>

public  Bitmap wuHua(Image SImage)
{
    
int Height = SImage.Height;
    
int Width = SImage.Width;
    Bitmap bitmap 
= new Bitmap(Width, Height);
    Bitmap MyBitmap 
= (Bitmap) SImage;
    Color pixel;
    
for (int x = 1; x < Width - 1; x++)
        
for (int y = 1; y < Height - 1; y++)
        
{
            System.Random MyRandom 
= new Random();
            
int k = MyRandom.Next(123456);
            
//像素块大小
            int dx = x + k % 19;
            
int dy = y + k % 19;
            
if (dx >= Width)
                dx 
= Width - 1;
            
if (dy >= Height)
                dy 
= Height - 1;
            pixel 
= MyBitmap.GetPixel(dx, dy);
            bitmap.SetPixel(x, y, pixel);
        }

    
return bitmap;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值