zoukankan      html  css  js  c++  java
  • c#的图像处理(直方图;反差,密度的四边圆补偿示例)

    模拟Photo的直方图,不过只是显示;
    有对图像四角的密度和反差进行补偿,这是现在LDD(LCD+LED)数码裁放机上常用的补偿方法!
    主要还是对GDI+的应用,大家不妨看看原码!

    http://www.nxxn.net/soft/dreign.rar
     //图像处理--------------------------------------------------------------------------------------

    using System;
    using System.Drawing;
    using System.Drawing.Imaging;

    namespace zft

     public class BitmapFilter
     {  
      public static bool modu1(Bitmap image,int r,int g,int b)
      { 
       if(r==0) r=1;
       if(g==0) g=1;
       if(b==0) b=1;
       BitmapData bmData =  image.LockBits(new Rectangle(0, 0,image.Width , image.Height), ImageLockMode.ReadWrite, PixelFormat.Format24bppRgb);
       unsafe
       {
        int stride = bmData.Stride;
        System.IntPtr Scan0 = bmData.Scan0;   
        byte * p = (byte *)(void *)Scan0;
        int nOffset = stride - image.Width*3;    
        
        int nWidth=image.Width;
        int nHeight=image.Height;
        int red,green,blue;

        int w0=(int)(nWidth/2);
        int h0=(int)(nHeight/2);
        int r0,t1,t2,kr=r,kg=g,kb=b;
        double z,z0;

        int k1r=r,k1g=g,k1b=b,
         k2r=r,k2g=g,k2b=b,
         k3r=r,k3g=g,k3b=b,
         k4r=r,k4g=g,k4b=b;
        
        if(w0>h0)
         r0=w0;
        else
         r0=h0;
        z0=Math.Sqrt(w0*w0+h0*h0);       
        z0=z0/1.5;

        for(int y=0;y<nHeight;++y)   
        {
         for(int x=0; x < nWidth; ++x )
         {
          red=p[2];
          green=p[1];
          blue=p[0];
          
          t1=x-w0;
          t2=y-h0;

          if(t1<0) t1=0-t1;      
          if(t2<0) t2=0-t2;
          
          z=Math.Sqrt(t1*t1+t2*t2);
          if(z<z0)
          {
           z=z0;
           kr=0;
           kg=0;
           kb=0;
          }
          else
          {
           double xx=(z-z0)/z;
           kr=(int)(15*r*xx*xx);
           kg=(int)(15*g*xx*xx);
           kb=(int)(15*b*xx*xx);
          } 
          red+=kr;
          green+=kg;
          blue+=kb; 

          if(red>255) red=255;
          if(red<0)   red=0;
          if(green>255) green=255;
          if(green<0)   green=0;
          if(blue>255) blue=255;
          if(blue<0)   blue=0;
          
          p[2]=(byte)red;
          p[1]=(byte)green;
          p[0]=(byte)blue;
          
          p+=3;      
         }
         p += nOffset; 
         
        }
       }   
       image.UnlockBits(bmData); 
       return true;
      }

      /// <summary>
      /// 反差圆补偿
      /// </summary>
      /// <param name="image">图像</param>
      /// <param name="con">反差系数</param>
      /// <param name="k">圆半径系数</param>
      /// <returns></returns>
      public static bool ccon(Bitmap image,float con,float k)
      {    
       BitmapData bmData =  image.LockBits(new Rectangle(0, 0,image.Width , image.Height), ImageLockMode.ReadWrite, PixelFormat.Format24bppRgb);
       unsafe
       {
        int stride = bmData.Stride;
        System.IntPtr Scan0 = bmData.Scan0;   
        byte * p = (byte *)(void *)Scan0;
        int nOffset = stride - image.Width*3;    
        
        int nWidth=image.Width;
        int nHeight=image.Height;
        int red,green,blue;

        int w0=(int)(nWidth/2);
        int h0=(int)(nHeight/2);
        int r0,t1,t2;
        double z,z0,pixel,contrast;
        
        if(w0>h0)
         r0=w0;
        else
         r0=h0;
        z0=Math.Sqrt(w0*w0+h0*h0);       
        z0=z0/k;

        for(int y=0;y<nHeight;++y)   
        {
         for(int x=0; x < nWidth; ++x )
         {
          red=p[2];
          green=p[1];
          blue=p[0];
          
          t1=x-w0;
          t2=y-h0;

          if(t1<0) t1=0-t1;      
          if(t2<0) t2=0-t2;
          
          z=Math.Sqrt(t1*t1+t2*t2);
          if(z>z0)
          {      
           contrast = (z-z0)/z * con ;

           pixel = red-(127-red) * contrast;
           if (pixel < 0) pixel = 0;
           if (pixel > 255) pixel = 255;
           p[2] = (byte) pixel;

           pixel = green-(127-green) * contrast;
           if (pixel < 0) pixel = 0;
           if (pixel > 255) pixel = 255;
           p[1] = (byte) pixel;

           pixel = blue-(127-blue) * contrast;
           if (pixel < 0) pixel = 0;
           if (pixel > 255) pixel = 255;
           p[0] = (byte) pixel;       
          }      
          p+=3;      
         }
         p += nOffset;     
        }
       }   
       image.UnlockBits(bmData); 
       return true;
      }
      /// <summary>
      /// 基本反差调整
      /// </summary>
      /// <param name="b"></param>
      /// <param name="nContrast"></param>
      /// <returns></returns>
      public static bool Contrast(Bitmap b, int nContrast)
      {
       if (nContrast < -100) return false;
       if (nContrast >  100) return false;

       double pixel = 0, contrast = (100.0+nContrast)/100.0;

       contrast *= contrast;

       int red, green, blue;
       
       // GDI+ still lies to us - the return format is BGR, NOT RGB.
       BitmapData bmData = b.LockBits(new Rectangle(0, 0, b.Width, b.Height), ImageLockMode.ReadWrite, PixelFormat.Format24bppRgb);

       int stride = bmData.Stride;
       System.IntPtr Scan0 = bmData.Scan0;
       int h=b.Height,w=b.Width;

       unsafe
       {
        byte * p = (byte *)(void *)Scan0;

        int nOffset = stride - b.Width*3;

        for(int y=0;y<h;++y)
        {
         for(int x=0; x < w; ++x )
         {
          blue = p[0];
          green = p[1];
          red = p[2];
        
          pixel = red/255.0;
          pixel -= 0.5;
          pixel *= contrast;
          pixel += 0.5;
          pixel *= 255;
          if (pixel < 0) pixel = 0;
          if (pixel > 255) pixel = 255;
          p[2] = (byte) pixel;

          pixel = green/255.0;
          pixel -= 0.5;
          pixel *= contrast;
          pixel += 0.5;
          pixel *= 255;
          if (pixel < 0) pixel = 0;
          if (pixel > 255) pixel = 255;
          p[1] = (byte) pixel;

          pixel = blue/255.0;
          pixel -= 0.5;
          pixel *= contrast;
          pixel += 0.5;
          pixel *= 255;
          if (pixel < 0) pixel = 0;
          if (pixel > 255) pixel = 255;
          p[0] = (byte) pixel;     

          p += 3;
         }
         p += nOffset;
        }
       }

       b.UnlockBits(bmData);

       return true;
      }
     
      public static bool zft(Bitmap b,out int[] all,out int[] rhow, out int[] ghow,out int[] bhow)
      {
       int [] gray=new int[256];
       int [] rr = new int[256];
       int [] gg = new int[256];
       int [] bb = new int[256];
       int tt=0;
       foreach(int i in gray)
       {
        gray[i]=0;
       }
       foreach(int i in rr)
       {
        rr[i]=0;
       }
       foreach(int i in gg)
       {
        gg[i]=0;
       }
       foreach(int i in bb)
       {
        bb[i]=0;
       }

       // GDI+ still lies to us - the return format is BGR, NOT RGB.
       BitmapData bmData = b.LockBits(new Rectangle(0, 0, b.Width, b.Height), ImageLockMode.ReadWrite, PixelFormat.Format24bppRgb);

       int stride = bmData.Stride;
       System.IntPtr Scan0 = bmData.Scan0;

       unsafe
       {
        byte * p = (byte *)(void *)Scan0;

        int nOffset = stride - b.Width*3;

        byte red, green, blue;
        int nWidth = b.Width;
        int nHeight= b.Height; 
     
        for(int y=0;y<nHeight;++y)
        {
         for(int x=0; x < nWidth; ++x )
         {
          blue = p[0];
          green = p[1];
          red = p[2];

          tt = (byte)(.299 * red + .587 * green + .114 * blue);
          rr[red]++;
          gg[green]++;
          bb[blue]++;
          gray[tt]++;     
          p += 3;
         }
         p += nOffset;
        }
       }
       all=gray;
       rhow=rr;
       ghow=gg;
       bhow=bb;

       b.UnlockBits(bmData);

       return true;
      }

     }
    }

    //直方图--------------------------------------------------------------------------

    using System;
    using System.Drawing;
    using System.Collections;
    using System.ComponentModel;
    using System.Windows.Forms;
    using System.Data;
    using System.Drawing.Imaging;
    using System.Drawing.Drawing2D;

    namespace zft
    {
     /// <summary>
     /// Form1 的摘要说明。
     /// </summary>
     public class Form1 : System.Windows.Forms.Form
     {
      /// <summary>
      /// 必需的设计器变量。
      /// </summary>
      private System.ComponentModel.Container components = null;
      private System.Windows.Forms.Button button1;

      int [] gray=new int[256];
      int [] rr = new int[256];
      int [] gg = new int[256];
      int [] bb = new int[256];
      public Bitmap a=new Bitmap(500,500);
      public Bitmap b=new Bitmap(500,500);
      Pen pen1=new Pen(Color.Black);
      int flag=0;    

      float count ;
      private System.Windows.Forms.Button button2;
      private System.Windows.Forms.Button button3;
      private System.Windows.Forms.Button button4;
      private System.Windows.Forms.Label label1;
      private System.Windows.Forms.GroupBox groupBox1;
      private System.Windows.Forms.Label label2;
      private System.Windows.Forms.Label label7;
      private System.Windows.Forms.Label label8;
      private System.Windows.Forms.Label label9;
      private System.Windows.Forms.Label label10;
      private System.Windows.Forms.Label l_sejie;
      private System.Windows.Forms.Label l_pinjun;
      private System.Windows.Forms.Label l_pixel;
      private System.Windows.Forms.Label label3;
      private System.Windows.Forms.TextBox textBox1;
      private System.Windows.Forms.TextBox textBox3;

      float [] gl=new float[256];
      private System.Windows.Forms.Label l_bfb;
      private System.Windows.Forms.Label l_how;

      private bool aline=false;
      private System.Windows.Forms.Label lcolor;
      private System.Windows.Forms.Label label5;
      private System.Windows.Forms.Label label6;
      private System.Windows.Forms.Label label11;
      private System.Windows.Forms.GroupBox groupBox2;
      private System.Windows.Forms.GroupBox groupBox4;
      private System.Windows.Forms.Button button5;
      private System.Windows.Forms.Button undo;
      private System.Windows.Forms.Button refresh;

      int xx=-1;

      public Form1()
      {
       //
       // Windows 窗体设计器支持所必需的
       //
       InitializeComponent();

       //
       // TODO: 在 InitializeComponent 调用后添加任何构造函数代码
       //
      }

      /// <summary>
      /// 清理所有正在使用的资源。
      /// </summary>
      protected override void Dispose( bool disposing )
      {
       if( disposing )
       {
        if (components != null)
        {
         components.Dispose();
        }
       }
       base.Dispose( disposing );
      }

      #region Windows 窗体设计器生成的代码
      /// <summary>
      /// 设计器支持所需的方法 - 不要使用代码编辑器修改
      /// 此方法的内容。
      /// </summary>
      private void InitializeComponent()
      {
       System.Resources.ResourceManager resources = new System.Resources.ResourceManager(typeof(Form1));
       this.button1 = new System.Windows.Forms.Button();
       this.button2 = new System.Windows.Forms.Button();
       this.button3 = new System.Windows.Forms.Button();
       this.button4 = new System.Windows.Forms.Button();
       this.label1 = new System.Windows.Forms.Label();
       this.groupBox1 = new System.Windows.Forms.GroupBox();
       this.button5 = new System.Windows.Forms.Button();
       this.l_pinjun = new System.Windows.Forms.Label();
       this.l_pixel = new System.Windows.Forms.Label();
       this.textBox1 = new System.Windows.Forms.TextBox();
       this.groupBox4 = new System.Windows.Forms.GroupBox();
       this.groupBox2 = new System.Windows.Forms.GroupBox();
       this.label11 = new System.Windows.Forms.Label();
       this.label6 = new System.Windows.Forms.Label();
       this.label5 = new System.Windows.Forms.Label();
       this.lcolor = new System.Windows.Forms.Label();
       this.textBox3 = new System.Windows.Forms.TextBox();
       this.l_how = new System.Windows.Forms.Label();
       this.l_bfb = new System.Windows.Forms.Label();
       this.label10 = new System.Windows.Forms.Label();
       this.label9 = new System.Windows.Forms.Label();
       this.label8 = new System.Windows.Forms.Label();
       this.label7 = new System.Windows.Forms.Label();
       this.l_sejie = new System.Windows.Forms.Label();
       this.label3 = new System.Windows.Forms.Label();
       this.label2 = new System.Windows.Forms.Label();
       this.undo = new System.Windows.Forms.Button();
       this.refresh = new System.Windows.Forms.Button();
       this.groupBox1.SuspendLayout();
       this.SuspendLayout();
       //
       // button1
       //
       this.button1.Location = new System.Drawing.Point(276, 56);
       this.button1.Name = "button1";
       this.button1.Size = new System.Drawing.Size(64, 28);
       this.button1.TabIndex = 0;
       this.button1.Text = "灰度";
       this.button1.TextAlign = System.Drawing.ContentAlignment.BottomCenter;
       this.button1.Click += new System.EventHandler(this.button1_Click);
       //
       // button2
       //
       this.button2.Location = new System.Drawing.Point(276, 92);
       this.button2.Name = "button2";
       this.button2.Size = new System.Drawing.Size(64, 28);
       this.button2.TabIndex = 1;
       this.button2.Text = "红";
       this.button2.TextAlign = System.Drawing.ContentAlignment.BottomCenter;
       this.button2.Click += new System.EventHandler(this.button2_Click);
       //
       // button3
       //
       this.button3.Location = new System.Drawing.Point(276, 124);
       this.button3.Name = "button3";
       this.button3.Size = new System.Drawing.Size(64, 28);
       this.button3.TabIndex = 2;
       this.button3.Text = "绿";
       this.button3.TextAlign = System.Drawing.ContentAlignment.BottomCenter;
       this.button3.Click += new System.EventHandler(this.button3_Click);
       //
       // button4
       //
       this.button4.Location = new System.Drawing.Point(276, 156);
       this.button4.Name = "button4";
       this.button4.Size = new System.Drawing.Size(64, 28);
       this.button4.TabIndex = 3;
       this.button4.Text = "蓝";
       this.button4.TextAlign = System.Drawing.ContentAlignment.BottomCenter;
       this.button4.Click += new System.EventHandler(this.button4_Click);
       //
       // label1
       //
       this.label1.BackColor = System.Drawing.Color.White;
       this.label1.BorderStyle = System.Windows.Forms.BorderStyle.Fixed3D;
       this.label1.Cursor = System.Windows.Forms.Cursors.Cross;
       this.label1.Location = new System.Drawing.Point(12, 56);
       this.label1.Name = "label1";
       this.label1.Size = new System.Drawing.Size(258, 129);
       this.label1.TabIndex = 4;
       this.label1.Paint += new System.Windows.Forms.PaintEventHandler(this.label1_Paint);
       this.label1.MouseUp += new System.Windows.Forms.MouseEventHandler(this.label1_MouseUp);
       this.label1.MouseMove += new System.Windows.Forms.MouseEventHandler(this.label1_MouseMove);
       this.label1.MouseDown += new System.Windows.Forms.MouseEventHandler(this.label1_MouseDown);
       //
       // groupBox1
       //
       this.groupBox1.Controls.Add(this.button5);
       this.groupBox1.Controls.Add(this.l_pinjun);
       this.groupBox1.Controls.Add(this.l_pixel);
       this.groupBox1.Controls.Add(this.textBox1);
       this.groupBox1.Controls.Add(this.groupBox4);
       this.groupBox1.Controls.Add(this.groupBox2);
       this.groupBox1.Controls.Add(this.label11);
       this.groupBox1.Controls.Add(this.label6);
       this.groupBox1.Controls.Add(this.label5);
       this.groupBox1.Controls.Add(this.lcolor);
       this.groupBox1.Controls.Add(this.textBox3);
       this.groupBox1.Controls.Add(this.l_how);
       this.groupBox1.Controls.Add(this.l_bfb);
       this.groupBox1.Controls.Add(this.label10);
       this.groupBox1.Controls.Add(this.label9);
       this.groupBox1.Controls.Add(this.label8);
       this.groupBox1.Controls.Add(this.label7);
       this.groupBox1.Controls.Add(this.l_sejie);
       this.groupBox1.Controls.Add(this.label3);
       this.groupBox1.Controls.Add(this.label1);
       this.groupBox1.Controls.Add(this.button2);
       this.groupBox1.Controls.Add(this.button3);
       this.groupBox1.Controls.Add(this.button1);
       this.groupBox1.Controls.Add(this.button4);
       this.groupBox1.Controls.Add(this.label2);
       this.groupBox1.Font = new System.Drawing.Font("宋体", 12F);
       this.groupBox1.Location = new System.Drawing.Point(8, 4);
       this.groupBox1.Name = "groupBox1";
       this.groupBox1.Size = new System.Drawing.Size(352, 340);
       this.groupBox1.TabIndex = 5;
       this.groupBox1.TabStop = false;
       this.groupBox1.Text = "直方图";
       this.groupBox1.Paint += new System.Windows.Forms.PaintEventHandler(this.groupBox1_Paint);
       //
       // button5
       //
       this.button5.Location = new System.Drawing.Point(276, 224);
       this.button5.Name = "button5";
       this.button5.Size = new System.Drawing.Size(64, 24);
       this.button5.TabIndex = 26;
       this.button5.Text = "ok";
       this.button5.Click += new System.EventHandler(this.button5_Click);
       //
       // l_pinjun
       //
       this.l_pinjun.Location = new System.Drawing.Point(76, 292);
       this.l_pinjun.Name = "l_pinjun";
       this.l_pinjun.Size = new System.Drawing.Size(88, 20);
       this.l_pinjun.TabIndex = 8;
       this.l_pinjun.Text = "0";
       this.l_pinjun.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
       //
       // l_pixel
       //
       this.l_pixel.Location = new System.Drawing.Point(76, 272);
       this.l_pixel.Name = "l_pixel";
       this.l_pixel.Size = new System.Drawing.Size(88, 20);
       this.l_pixel.TabIndex = 9;
       this.l_pixel.Text = "0";
       this.l_pixel.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
       //
       // textBox1
       //
       this.textBox1.Location = new System.Drawing.Point(124, 224);
       this.textBox1.Name = "textBox1";
       this.textBox1.Size = new System.Drawing.Size(48, 26);
       this.textBox1.TabIndex = 16;
       this.textBox1.Text = "0";
       //
       // groupBox4
       //
       this.groupBox4.Location = new System.Drawing.Point(176, 228);
       this.groupBox4.Name = "groupBox4";
       this.groupBox4.Size = new System.Drawing.Size(44, 8);
       this.groupBox4.TabIndex = 25;
       this.groupBox4.TabStop = false;
       //
       // groupBox2
       //
       this.groupBox2.Location = new System.Drawing.Point(176, 32);
       this.groupBox2.Name = "groupBox2";
       this.groupBox2.Size = new System.Drawing.Size(40, 8);
       this.groupBox2.TabIndex = 24;
       this.groupBox2.TabStop = false;
       //
       // label11
       //
       this.label11.BorderStyle = System.Windows.Forms.BorderStyle.Fixed3D;
       this.label11.Location = new System.Drawing.Point(220, 28);
       this.label11.Name = "label11";
       this.label11.Size = new System.Drawing.Size(52, 23);
       this.label11.TabIndex = 23;
       this.label11.Text = "255";
       this.label11.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
       //
       // label6
       //
       this.label6.BorderStyle = System.Windows.Forms.BorderStyle.Fixed3D;
       this.label6.Location = new System.Drawing.Point(124, 28);
       this.label6.Name = "label6";
       this.label6.Size = new System.Drawing.Size(48, 23);
       this.label6.TabIndex = 22;
       this.label6.Text = "0";
       this.label6.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
       //
       // label5
       //
       this.label5.Location = new System.Drawing.Point(8, 224);
       this.label5.Name = "label5";
       this.label5.Size = new System.Drawing.Size(116, 23);
       this.label5.TabIndex = 21;
       this.label5.Text = "输出色阶范围:";
       //
       // lcolor
       //
       this.lcolor.BorderStyle = System.Windows.Forms.BorderStyle.Fixed3D;
       this.lcolor.Location = new System.Drawing.Point(12, 192);
       this.lcolor.Name = "lcolor";
       this.lcolor.Size = new System.Drawing.Size(260, 12);
       this.lcolor.TabIndex = 19;
       this.lcolor.Paint += new System.Windows.Forms.PaintEventHandler(this.lcolor_Paint);
       //
       // textBox3
       //
       this.textBox3.Location = new System.Drawing.Point(224, 224);
       this.textBox3.Name = "textBox3";
       this.textBox3.Size = new System.Drawing.Size(48, 26);
       this.textBox3.TabIndex = 18;
       this.textBox3.Text = "255";
       //
       // l_how
       //
       this.l_how.Location = new System.Drawing.Point(212, 292);
       this.l_how.Name = "l_how";
       this.l_how.Size = new System.Drawing.Size(120, 20);
       this.l_how.TabIndex = 15;
       this.l_how.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
       //
       // l_bfb
       //
       this.l_bfb.Location = new System.Drawing.Point(208, 312);
       this.l_bfb.Name = "l_bfb";
       this.l_bfb.Size = new System.Drawing.Size(124, 20);
       this.l_bfb.TabIndex = 14;
       this.l_bfb.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
       //
       // label10
       //
       this.label10.Location = new System.Drawing.Point(144, 312);
       this.label10.Name = "label10";
       this.label10.Size = new System.Drawing.Size(68, 20);
       this.label10.TabIndex = 13;
       this.label10.Text = "百分比:";
       this.label10.TextAlign = System.Drawing.ContentAlignment.MiddleRight;
       //
       // label9
       //
       this.label9.Location = new System.Drawing.Point(16, 28);
       this.label9.Name = "label9";
       this.label9.Size = new System.Drawing.Size(84, 23);
       this.label9.TabIndex = 12;
       this.label9.Text = "色阶范围:";
       //
       // label8
       //
       this.label8.Location = new System.Drawing.Point(4, 292);
       this.label8.Name = "label8";
       this.label8.Size = new System.Drawing.Size(68, 20);
       this.label8.TabIndex = 11;
       this.label8.Text = "平均值:";
       this.label8.TextAlign = System.Drawing.ContentAlignment.MiddleRight;
       //
       // label7
       //
       this.label7.Location = new System.Drawing.Point(144, 272);
       this.label7.Name = "label7";
       this.label7.Size = new System.Drawing.Size(68, 20);
       this.label7.TabIndex = 10;
       this.label7.Text = "色阶:";
       this.label7.TextAlign = System.Drawing.ContentAlignment.MiddleRight;
       //
       // l_sejie
       //
       this.l_sejie.Location = new System.Drawing.Point(212, 272);
       this.l_sejie.Name = "l_sejie";
       this.l_sejie.Size = new System.Drawing.Size(120, 20);
       this.l_sejie.TabIndex = 7;
       this.l_sejie.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
       //
       // label3
       //
       this.label3.Location = new System.Drawing.Point(152, 292);
       this.label3.Name = "label3";
       this.label3.Size = new System.Drawing.Size(60, 20);
       this.label3.TabIndex = 6;
       this.label3.Text = "数量:";
       this.label3.TextAlign = System.Drawing.ContentAlignment.MiddleRight;
       //
       // label2
       //
       this.label2.Location = new System.Drawing.Point(16, 272);
       this.label2.Name = "label2";
       this.label2.Size = new System.Drawing.Size(56, 20);
       this.label2.TabIndex = 5;
       this.label2.Text = "像素:";
       this.label2.TextAlign = System.Drawing.ContentAlignment.MiddleRight;
       //
       // undo
       //
       this.undo.Location = new System.Drawing.Point(368, 16);
       this.undo.Name = "undo";
       this.undo.TabIndex = 6;
       this.undo.Text = "undo";
       this.undo.Click += new System.EventHandler(this.undo_Click);
       //
       // refresh
       //
       this.refresh.Location = new System.Drawing.Point(368, 48);
       this.refresh.Name = "refresh";
       this.refresh.TabIndex = 7;
       this.refresh.Text = "refresh";
       this.refresh.Click += new System.EventHandler(this.refresh_Click);
       //
       // Form1
       //
       this.AutoScaleBaseSize = new System.Drawing.Size(6, 14);
       this.ClientSize = new System.Drawing.Size(450, 350);
       this.Controls.Add(this.refresh);
       this.Controls.Add(this.undo);
       this.Controls.Add(this.groupBox1);
       this.FormBorderStyle = System.Windows.Forms.FormBorderStyle.FixedToolWindow;
       this.Icon = ((System.Drawing.Icon)(resources.GetObject("$this.Icon")));
       this.Name = "Form1";
       this.Text = "色阶和直方图";
       this.Load += new System.EventHandler(this.Form1_Load);
       this.groupBox1.ResumeLayout(false);
       this.ResumeLayout(false);

      }
      #endregion

      

      private void Form1_Load(object sender, System.EventArgs e)
      {
                this.TopMost=true;
       this.Left=800;
       BitmapFilter.zft(a,out gray,out rr,out gg, out bb); 
       graydo();
       this.Invalidate();
      }
      protected override void OnPaint(PaintEventArgs e)
      {
       base.OnPaint (e);
       Graphics g=e.Graphics;
      }

      private void button1_Click(object sender, System.EventArgs e)
      {
       graydo();
      }
      private void graydo()
      {
       this.flag=1;
       count = a.Width * a.Height;
       gl=new float[256];
       for(int i=0;i<256; i++)
        gl[i]= gray[i]/count *10000;
       pen1=Pens.Black;  
       this.label1.Invalidate();
       this.lcolor.Invalidate();
      }

      private void button2_Click(object sender, System.EventArgs e)
      {
       this.flag=2;
       count = a.Width * a.Height;
       gl=new float[256];
       for(int i=0;i<256; i++)
        gl[i]= rr[i]/count *10000;
       pen1=Pens.Red; 
       this.label1.Invalidate();
       this.lcolor.Invalidate();
      }

      private void button3_Click(object sender, System.EventArgs e)
      {
       this.flag=3;
       count = a.Width * a.Height;
       gl=new float[256];
       for(int i=0;i<256; i++)
        gl[i]= gg[i]/count *10000;
       pen1=Pens.Green; 
       this.label1.Invalidate();
       this.lcolor.Invalidate();
      }

      private void button4_Click(object sender, System.EventArgs e)
      {
       this.flag=4;
       count = a.Width * a.Height;
       gl=new float[256];
       for(int i=0;i<256; i++)
        gl[i]= bb[i]/count *10000;
       pen1=Pens.Blue; 
       this.label1.Invalidate();
       this.lcolor.Invalidate();
      }

      private void label1_Paint(object sender, System.Windows.Forms.PaintEventArgs e)
      {
       Graphics g=e.Graphics;
       int p;
       p= a.Width*a.Height;
       this.l_pixel.Text=p.ToString();

       int height =this.label1.Height;
       for(int j=0;j<256;j++)
       {
        if(gl[j]>height)
         gl[j]=height;
        g.DrawLine(pen1,j,height,j,height-gl[j]);
       }
       if(aline)
       {
        g.DrawLine(Pens.OrangeRed,xx,0,xx,height);   
       }
       if(xx!=-1)
       {
        this.l_sejie.Text =xx.ToString();
        this.l_how.Text =this.gray[xx].ToString();
        this.l_bfb.Text =this.gl[xx].ToString();
       }
       else
       {
        this.l_sejie.Text=" ";
        this.l_how.Text  =" ";
        this.l_bfb.Text  =" ";   
       }
      }

      private void label1_MouseDown(object sender, System.Windows.Forms.MouseEventArgs e)
      {
       xx=e.X; 
       if(xx>255)
        xx=255;
       if(xx<=0)
        xx=0;
       
       aline=true;
       this.label1.Invalidate();
      }

      private void label1_MouseMove(object sender, System.Windows.Forms.MouseEventArgs e)
      {
       /*
       if((e.X>255)&&(e.X<0)&&(e.Y<0)&&(e.Y>127))
       {
        this.xx=-1;
       }
       else
       {
        this.xx=e.X;
       }
       this.label4.Text=e.X.ToString()+" "+e.Y.ToString();
       */
       Point p=new Point(e.X,e.Y);
       if(new Rectangle(0,0,256,127).Contains(p))
       {
        this.xx=e.X;
       }
       else
       {
        this.xx=-1;
       }
       
       this.label1.Invalidate();
      }

      private void label1_MouseUp(object sender, System.Windows.Forms.MouseEventArgs e)
      {
       aline=false;
      }

      private void lcolor_Paint(object sender, System.Windows.Forms.PaintEventArgs e)
      {
       int width=this.lcolor.Width;
       int height=this.lcolor.Height;
       int j;
       Color c;
       Graphics g=e.Graphics;

       switch(flag)
       {
        case 1:
        {
         for(int i=width;i>=0;i--)
         {
          j=i;
          if(j>255) j=255;
          c=Color.FromArgb(j,j,j);
          Pen pen2=new Pen(c,1);   
          g.DrawLine(pen2,i,0,i,height);
         }
         break;
        }
        case 2:
        {
         for(int i=width;i>=0;i--)
         {
          j=i;
          if(j>255) j=255;
          c=Color.FromArgb(j,0,0);
          Pen pen2=new Pen(c,1);   
          g.DrawLine(pen2,i,0,i,height);
         }
         break;
        }
        case 3:
        {
         for(int i=width;i>=0;i--)
         {
          j=i;
          if(j>255) j=255;
          c=Color.FromArgb(0,j,0);
          Pen pen2=new Pen(c,1);   
          g.DrawLine(pen2,i,0,i,height);
         }
         break;
        }
        case 4:
        {
         for(int i=width;i>=0;i--)
         {
          j=i;
          if(j>255) j=255;
          c=Color.FromArgb(0,0,j);
          Pen pen2=new Pen(c,1);   
          g.DrawLine(pen2,i,0,i,height);
         }
         break;
        }
        default:
         break;

       }
      }

      private void groupBox1_Paint(object sender, System.Windows.Forms.PaintEventArgs e)
      {
       Graphics g=e.Graphics;
       int x=this.lcolor.Left;
       int y=this.lcolor.Top;
       int w=this.lcolor.Width;
       int h=this.lcolor.Height;

       PointF [] pp=new PointF [4];
       pp[0]=new PointF(x ,y+h+5);
       pp[1]=new PointF(x-5 ,y+h+15);
       pp[2]=new PointF(x+5 ,y+h+15);
       pp[3]=new PointF(x ,y+h+5);

       g.FillPolygon(Brushes.Black,pp);
       
       x+=w/2;

       pp[0]=new PointF(x ,y+h+5);
       pp[1]=new PointF(x-5 ,y+h+15);
       pp[2]=new PointF(x+5 ,y+h+15);
       pp[3]=new PointF(x ,y+h+5);

       g.FillPolygon(Brushes.Gray,pp);
      
       x+=w/2;

       pp[0]=new PointF(x ,y+h+5);
       pp[1]=new PointF(x-5 ,y+h+15);
       pp[2]=new PointF(x+5 ,y+h+15);
       pp[3]=new PointF(x ,y+h+5);

       g.FillPolygon(Brushes.Black,pp);
      }

      private void button5_Click(object sender, System.EventArgs e)
      {
       int a1=Convert.ToInt32(this.textBox1.Text);
       int a2=Convert.ToInt32(this.textBox3.Text);
         }

      private void undo_Click(object sender, System.EventArgs e)
      {
       this.a=(Bitmap)this.b.Clone();
      }

      private void refresh_Click(object sender, System.EventArgs e)
      {
       doing();
      }
      public void doing()
      {
       BitmapFilter.zft(a,out gray,out rr,out gg, out bb); 
       graydo();
       this.Invalidate();
      }
     }
    }
    //有点累,呵呵!

  • 相关阅读:
    协同旋转不变网格形变
    协同旋转不变网格形变
    协同旋转不变网格形变
    递归算法详细分析
    递归算法详细分析
    C#委托之个人理解
    xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!
    xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!
    xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!
    xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!
  • 原文地址:https://www.cnblogs.com/dreign/p/42908.html
Copyright © 2011-2022 走看看