学的是遥感图像类,求大虾推荐一些对图像进行简单的放大缩小及位图分析等功能的介绍,目前就是先试试灰度bmp就可以了。还有一些对像素的分析的,比如统计不同颜色值数量,面积统计的功能,非常感谢!

解决方案 »

  1.   


     /// <summary>
            /// 将图片转换成黑白色效果
            /// </summary>
            /// <param name="bmp">Bitmap 对象</param>
            /// <param name="picBox">PictureBox 对象</param>
            public static void HeiBaiSeImage(Bitmap bmp, PictureBox picBox)
            {
                //以黑白效果显示图像
                Bitmap oldBitmap;
                Bitmap newBitmap=null;
                try
                {
                    int Height = bmp.Height;
                    int Width = bmp.Width;
                    newBitmap = new Bitmap(Width, Height);
                    oldBitmap = bmp;
                    Color pixel;
                    for (int x = 0; x < Width; x++)
                        for (int y = 0; y < Height; y++)
                        {
                            pixel = oldBitmap.GetPixel(x, y);
                            int r, g, b, Result = 0;
                            r = pixel.R;
                            g = pixel.G;
                            b = pixel.B;
                            //实例程序以加权平均值法产生黑白图像
                            int iType = 2;
                            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;
                            }
                            newBitmap.SetPixel(x, y, Color.FromArgb(Result, Result, Result));
                        }
                    
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message, "信息提示");
                }
                picBox.Image = newBitmap;
            }
            
            /// <summary>
            /// 雾化效果
            /// </summary>
            /// <param name="bmp"></param>
            /// <param name="picBox"></param>
            public static void WuHuaImage(Bitmap bmp, PictureBox picBox)
            {
                //雾化效果
                Bitmap oldBitmap;
                Bitmap newBitmap = null;
                try
                {
                    int Height = bmp.Height;
                    int Width = bmp.Width;
                    newBitmap = new Bitmap(Width, Height);
                    oldBitmap = bmp;
                    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 = oldBitmap.GetPixel(dx, dy);
                            newBitmap.SetPixel(x, y, pixel);
                        }
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message, "信息提示");
                }
                picBox.Image= newBitmap;
            }
            /// <summary>
            /// 锐化效果
            /// </summary>
            /// <param name="bmp"></param>
            /// <param name="picBox"></param>
            public static void RuiHuaImage(Bitmap bmp, PictureBox picBox)
            {
                Bitmap oldBitmap;
                Bitmap newBitmap = null;
                try
                {
                    int Height = bmp.Height;
                    int Width = bmp.Width;
                    newBitmap = new Bitmap(Width, Height);
                    oldBitmap = bmp;
                    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));
                        }
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message, "信息提示");
                }
                picBox.Image = newBitmap;
            }        /// <summary>
            ///底片效果
            /// </summary>
            /// <param name="bmp">Bitmap 对象</param>
            /// <param name="picBox">PictureBox 对象</param>
            public static void DiPianImage(Bitmap bmp, PictureBox picBox)
            {
                Bitmap oldBitmap;
                Bitmap newBitmap = null;
                try
                {
                    int Height = bmp.Height;
                    int Width = bmp.Width;
                    newBitmap = new Bitmap(Width, Height);
                    oldBitmap = bmp;
                    Color pixel;
                    for (int x = 1; x < Width; x++)
                    {
                        for (int y = 1; y < Height; y++)
                        {
                            int r, g, b;
                            pixel = oldBitmap.GetPixel(x, y);
                            r = 255 - pixel.R;
                            g = 255 - pixel.G;
                            b = 255 - pixel.B;
                            newBitmap.SetPixel(x, y, Color.FromArgb(r, g, b));
                        }
                    }
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message, "信息提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
                }
                picBox.Image = newBitmap;
            }
            /// <summary>
            ///浮雕效果
            /// </summary>
            /// <param name="bmp">Bitmap 对象</param>
            /// <param name="picBox">PictureBox 对象</param>
            public static void FuDiaoImage(Bitmap bmp, PictureBox picBox)
            {
                Bitmap oldBitmap;
                Bitmap newBitmap = null;
                try
                {
                    int Height = bmp.Height;
                    int Width = bmp.Width;
                    newBitmap = new Bitmap(Width, Height);
                    oldBitmap = bmp;
                    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));
                        }
                    }
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message, "信息提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
                }
                picBox.Image = newBitmap;
            }
      

  2.   

    http://www.cnblogs.com/ziyiFly/archive/2008/09/23/1296815.html