C#实现图像处理源代码(锐化,灰度,浮雕等)

四.C#实现图像处理(锐化,灰度,浮雕等效果)

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;

namespace ImageProcessDamon
{
    public partial class Form1 : Form
    {
        //图像处理主界面
        public Form1()
        {
            InitializeComponent();
        }

        Image imgOriginal;
       
        //打开一张图片
        private void btnOpenimage_Click(object sender, EventArgs e)
        {
         
            OpenFileDialog ofd = new OpenFileDialog();
            ofd.ShowDialog(); 


            string strFileName = ofd.FileName;

            imgOriginal = Image.FromFile(strFileName);
            pictureBox1 .BackgroundImage = imgOriginal;
        }
        //底片处理
        private void button2_Click(object sender, EventArgs e)
        {
            Bitmap bmp = new Bitmap( imgOriginal);
           
            for (int i = 0; i < bmp.Width ; i++) 
            {
                for (int j = 0; j < bmp.Height ; j ++)
                {
                    //获得原来像素点颜色
                    Color c = bmp.GetPixel(i , j);
                    //改变
                    Color cAfter = Color.FromArgb(255 - c.R, 255 - c.G, 255 - c.B);
                    //设置回去
                    bmp.SetPixel(i, j, cAfter);
                }
            }
            picAfter.BackgroundImage = bmp;
        }
        //灰度化
        private void button2_Click_1(object sender, EventArgs e)
        {
            Bitmap bmp = new Bitmap(imgOriginal);

            for (int i = 0; i < bmp.Width; i++)
            {
                for (int j = 0; j < bmp.Height; j++)
                {
                    //获得原来像素点颜色
                    Color c = bmp.GetPixel(i, j);
                    //改变
                    int gray = (c.R + c.G + c.B) / 3;
                    Color cAfter = Color.FromArgb(gray ,gray ,gray );
                    //设置回去
                    bmp.SetPixel(i, j, cAfter);
                }
            }
            picAfter.BackgroundImage = bmp;
        }

        private void btnSave_Click(object sender, EventArgs e)
        {
            //保存图片
            SaveFileDialog sfd = new SaveFileDialog();
            sfd.ShowDialog();

            picAfter.BackgroundImage.Save (sfd .FileName +".bmp");
        }


        private void button3_Click(object sender, EventArgs e)
        {            //以浮雕效果显示图像
            try
            {
                int Height = this.pictureBox1.BackgroundImage.Height;
                int Width = this.pictureBox1.BackgroundImage.Width;
                Bitmap newBitmap = new Bitmap(Width, Height);
                Bitmap oldBitmap = (Bitmap)this.pictureBox1.BackgroundImage;
                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 = oldBitmap.GetPixel(x, y);
                        pixel2 = oldBitmap.GetPixel(x + 1, y + 1);
                        r = Math.Abs(pixel1.R - pixel2.R + 128);
                        g = Math.Abs(pixel1.G - pixel2.G + 128);
                        b = Math.Abs(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;
                        newBitmap.SetPixel(x, y, Color.FromArgb(r, g, b));
                    }
                }
                this.picAfter.BackgroundImage = newBitmap;
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message, "信息提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
            }

        }

        private void button4_Click(object sender, EventArgs e)
        {
            //以锐化效果显示图像
            try
            {
                int Height = this.pictureBox1.BackgroundImage.Height;
                int Width = this.pictureBox1.BackgroundImage.Width;
                Bitmap newBitmap = new Bitmap(Width, Height);
                Bitmap oldBitmap = (Bitmap)this.pictureBox1.BackgroundImage;
                Color pixel;
                //拉普拉斯模板
                int[] Laplacian = { -1, -1, -1, -1, 9, -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;
                        for (int col = -1; col <= 1; col++)
                            for (int row = -1; row <= 1; row++)
                            {
                                pixel = oldBitmap.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;
                        newBitmap.SetPixel(x - 1, y - 1, Color.FromArgb(r, g, b));
                    }
                this.picAfter.BackgroundImage = newBitmap;
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message, "信息提示");
            }
        }
    }
}
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值