當前位置: 首頁>>代碼示例>>C#>>正文


C# Bitmap.GetPixel方法代碼示例

本文整理匯總了C#中System.Drawing.Bitmap.GetPixel方法的典型用法代碼示例。如果您正苦於以下問題:C# Bitmap.GetPixel方法的具體用法?C# Bitmap.GetPixel怎麽用?C# Bitmap.GetPixel使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在System.Drawing.Bitmap的用法示例。


在下文中一共展示了Bitmap.GetPixel方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: Remove

        public static void Remove(int colour, ref Bitmap bp)
        {
            Color c;
              switch (colour)
              {
            case BLUE:
              for (int i = 1; i < bp.Width; i++)
            for (int j = 1; j < bp.Height; j++)
            {
              c = bp.GetPixel(i, j);
              bp.SetPixel(i, j, Color.FromArgb(c.R, c.G, 0));
            }
              break;

            case RED:
              for (int i = 1; i < bp.Width; i++)
            for (int j = 1; j < bp.Height; j++)
            {
              c = bp.GetPixel(i, j);
              bp.SetPixel(i, j, Color.FromArgb(0, c.G, c.B));
            }
              break;

            case GREEN:
              for (int i = 1; i < bp.Width; i++)
            for (int j = 1; j < bp.Height; j++)
            {
              c = bp.GetPixel(i, j);
              bp.SetPixel(i, j, Color.FromArgb(c.R, 0, c.B));
            }
              break;
              }
        }
開發者ID:Theta-Z,項目名稱:Basic-Stuff,代碼行數:33,代碼來源:RemoveColour.cs

示例2: Binariz

        public Bitmap Binariz(Bitmap bm)
        {
            int x = bm.Width;
            int y = bm.Height;

            Bitmap result = new Bitmap(x, y);

            for (int pixX = 0; pixX < x; pixX++)
                for (int pixY = 0; pixY < y; pixY++)
                {

                    int rd, gr, bl;

                    if (bm.GetPixel(pixX, pixY).R  < 100)
                        rd = 0;
                    else
                        rd = 255;

                    if (bm.GetPixel(pixX, pixY).G  < 100)
                        gr = 0;
                    else
                        gr = 255;

                    if (bm.GetPixel(pixX, pixY).B  < 100)
                        bl = 0;
                    else
                        bl = 255;

                    result.SetPixel(pixX, pixY, Color.FromArgb((byte)rd, (byte)gr, (byte)bl));
                }

            return result;
        }
開發者ID:core0,項目名稱:Image-Proccessing,代碼行數:33,代碼來源:Form1.cs

示例3: CalculateGraphicsPathFromBitmap

		// From http://edu.cnzz.cn/show_3281.html
		public static GraphicsPath CalculateGraphicsPathFromBitmap(Bitmap bitmap, Color colorTransparent) 
		{ 
			GraphicsPath graphicsPath = new GraphicsPath(); 
			if (colorTransparent == Color.Empty)
				colorTransparent = bitmap.GetPixel(0, 0); 

			for(int row = 0; row < bitmap.Height; row ++) 
			{ 
				int colOpaquePixel = 0;
				for(int col = 0; col < bitmap.Width; col ++) 
				{ 
					if(bitmap.GetPixel(col, row) != colorTransparent) 
					{ 
						colOpaquePixel = col; 
						int colNext = col; 
						for(colNext = colOpaquePixel; colNext < bitmap.Width; colNext ++) 
							if(bitmap.GetPixel(colNext, row) == colorTransparent) 
								break;
 
						graphicsPath.AddRectangle(new Rectangle(colOpaquePixel, row, colNext - colOpaquePixel, 1)); 
						col = colNext; 
					} 
				} 
			} 
			return graphicsPath; 
		} 
開發者ID:hanistory,項目名稱:hasuite,代碼行數:27,代碼來源:DrawHelper.cs

示例4: IsEmptyBitmap

		private bool IsEmptyBitmap (Bitmap bitmap, out int x, out int y)
		{
			bool result = true;
			int empty = Color.Empty.ToArgb ();
#if false
			for (y = 0; y < bitmap.Height; y++) {
				for (x = 0; x < bitmap.Width; x++) {
					if (bitmap.GetPixel (x, y).ToArgb () != empty) {
						Console.Write ("X");
						result = false;
					} else
						Console.Write (" ");
				}
				Console.WriteLine ();
			}
#else
			for (y = 0; y < bitmap.Height; y++) {
				for (x = 0; x < bitmap.Width; x++) {
					if (bitmap.GetPixel (x, y).ToArgb () != empty)
						return false;
				}
			}
#endif
			x = -1;
			y = -1;
			return result;
		}
開發者ID:Profit0004,項目名稱:mono,代碼行數:27,代碼來源:TestGraphics.cs

示例5: Filter

        //метод простой бинаризации, пока не используется, в дальнейшем - с помощью него будет происходить бинар-я с заданным порогом
        public Bitmap Filter(Bitmap originalBitmap)
        {
            int treshold = 0; // порог
            Color color; // цвет - будет разбиваться на RGB
            int average = 0;  // средний цвет = яркость
            Bitmap resultBitmap = new Bitmap(originalBitmap.Width, originalBitmap.Height);

            for (int i = 0; i < originalBitmap.Width; i++)
            {
                for (int j = 0; j < originalBitmap.Height; j++)
                {
                    color = originalBitmap.GetPixel(i, j);
                    average = (int)(color.R + color.G + color.B) / 3;
                    treshold = treshold + average;
                }
            }

            treshold = treshold / (originalBitmap.Width * originalBitmap.Height);

            for (int i = 0; i < originalBitmap.Width; i++)
            {
                for (int j = 0; j < originalBitmap.Height; j++)
                {
                    color = originalBitmap.GetPixel(i, j);
                    average = (int)(color.R + color.G + color.B) / 3;
                    resultBitmap.SetPixel(i, j, average < treshold ? Color.Black : Color.White);
                }
            }
            return resultBitmap;
        }
開發者ID:Aleksey993,項目名稱:Misoi,代碼行數:31,代碼來源:SimpleBinarizationFilter.cs

示例6: Filter

 public Bitmap Filter(Bitmap originalBitmap)
 {
     Bitmap resultBitmap = new Bitmap(originalBitmap);
     Color color;
     for (int i = SIZE; i < originalBitmap.Width - SIZE; i++)
     {
         for (int j = SIZE; j < originalBitmap.Height - SIZE; j++)
         {
             List<int> redList = new List<int>();
             List<int> greenList = new List<int>();
             List<int> blueList = new List<int>();
             int red = 0, green = 0, blue = 0;
             for (int ii = -SIZE; ii < SIZE + 1; ii++)
             {
                 for (int jj = -SIZE; jj < SIZE + 1; jj++)
                 {
                     color = originalBitmap.GetPixel(i + ii, j + jj);
                     redList.Add(color.R);
                     greenList.Add(color.G);
                     blueList.Add(color.B);
                 }
             }
             redList.Sort();
             greenList.Sort();
             blueList.Sort();
             red = redList.ElementAt(SIZE);
             green = greenList.ElementAt(SIZE);
             blue = blueList.ElementAt(SIZE);
             color = originalBitmap.GetPixel(i, j);
             color = Color.FromArgb(color.A, FilterService.SetColor(red), FilterService.SetColor(green), FilterService.SetColor(blue));
             resultBitmap.SetPixel(i, j, color);
         }
     }
     return resultBitmap;
 }
開發者ID:Aleksey993,項目名稱:Misoi,代碼行數:35,代碼來源:MedialFilter.cs

示例7: binarize

 private void binarize(Bitmap bittt, ref int[,] massss, ToolStripProgressBar progress)
 {
     massss = new int[bittt.Width, bittt.Height];
     progress.Minimum = 0;
     progress.Maximum = bittt.Height;
     for (int i = 0; i < bittt.Height; i++)
     {
         for (int j = 0; j < bittt.Width; j++)
         {
             if (bittt.GetPixel(j, i).R > 200 || bittt.GetPixel(j, i).B > 200 || bittt.GetPixel(j, i).G > 200)
             {
                 bittt.SetPixel(j, i, Color.White);
                 massss[j, i] = 0;
             }
             else
             {
                 bittt.SetPixel(j, i, Color.Black);
                 massss[j, i] = 1;
             }
             /*      if (j == (int)(bittt.Height / 6))
                    {
                        bittt.SetPixel(j, i, Color.Teal);
                    }*/
         }
         if (progress.Value < bittt.Height)
         {
             progress.Value++;
         }
     }
     progress.Value = 0;
 }
開發者ID:RomanBoychuk,項目名稱:MiSOI,代碼行數:31,代碼來源:Form1.cs

示例8: testEdgeDetection

 public void testEdgeDetection()
 {
     String testPath = "testEdge/";
     String[] pictures = Directory.GetFiles(testPath);
     EdgeDetector eD = new EdgeDetector(testPath);
     eD.execute();
     String directory = "Edged/";
     String[] edgedPictures = Directory.GetFiles(directory);
     Assert.AreEqual(edgedPictures.Length, pictures.Length, "Some images were not preccessed in Edge Detection");
     int edgedCount = 0;
     for (int i = 0; i < edgedPictures.Length; i++)
     {
         bool isBlackOrWhite = true;
         Bitmap finalImages = new Bitmap(edgedPictures[i]);
         for (int j = 0; j < finalImages.Width; j++)
         {
             for (int k = 0; k < finalImages.Height; k++)
             {
                 if(finalImages.GetPixel(j,k).R > 0 && finalImages.GetPixel(j,k).R < 255)
                 {
                     isBlackOrWhite = false;
                     break;
                 }
             }
             if(!isBlackOrWhite)
                 break;
         }
         if (isBlackOrWhite)
             edgedCount++;
         Assert.AreEqual(true, isBlackOrWhite, "Image is not an edged image");
     }
     Assert.AreEqual(edgedPictures.Length, edgedCount, "Not all images were Edged");
 }
開發者ID:robinschnetler,項目名稱:COS301_AutoMart,代碼行數:33,代碼來源:imageProcessingTests.cs

示例9: button2_Click

        private void button2_Click(object sender, EventArgs e)
        {
            diff = (int)this.numericUpDown1.Value;
            Bitmap sourceBmp = new Bitmap(this.pictureBox1.Image);
            Bitmap targetBmp = new Bitmap(sourceWidth, sourceHeight);
            for (int x = 0; x < sourceWidth; x++)
            {
                for (int y = 0; y < sourceHeight; y++)
                {
                    Color curColor = sourceBmp.GetPixel(x, y);

                    List<Point> testPoints = new List<Point>(8);
                    //testPoints.Add(new Point(x - 1, y - 1));
                    //testPoints.Add(new Point(x, y - 1));
                    testPoints.Add(new Point(x + 1, y - 1));
                    //testPoints.Add(new Point(x, y));
                    testPoints.Add(new Point(x + 1, y));
                    //testPoints.Add(new Point(x - 1, y + 1));
                    testPoints.Add(new Point(x, y + 1));
                    testPoints.Add(new Point(x + 1, y + 1));

                    foreach (Point p in testPoints)
                    {
                        if (InsideImg(p))
                            if (IsBeyondDiff(sourceBmp.GetPixel(p.X, p.Y), curColor))
                            {
                                targetBmp.SetPixel(x, y, Color.Black);
                                break;
                            }
                    }

                }
            }
            this.pictureBox2.Image = targetBmp;
        }
開發者ID:kai-liki,項目名稱:Study,代碼行數:35,代碼來源:Form1.cs

示例10: LoadFavs

 private Task LoadFavs()
 {
     return Task.Factory.StartNew(() =>
     {
         Dispatcher.BeginInvoke((Action) (async () =>
         {
             try
             {
                 var request =
                     (HttpWebRequest) WebRequest.Create("http://www.google.com/s2/favicons?domain=" + _url);
                 var response = await request.GetResponseAsync();
                 var responseStream = response.GetResponseStream();
                 var bmp = new Bitmap(responseStream);
                 var brush = new SolidColorBrush(StaticFunctions.ToMediaColor(bmp.GetPixel(11, 11)));
                 Grid.Background = brush;
                 image.Source = BitmapToImageSource(bmp);
                 var foreColor = PerceivedBrightness(StaticFunctions.ToMediaColor(bmp.GetPixel(11, 11))) > 130
                     ? Brushes.Black
                     : Brushes.White;
                 label.Foreground = foreColor;
             }
             catch
             {
                 
             }
         }));
     });
 }
開發者ID:Sential,項目名稱:WebExpress-beta,代碼行數:28,代碼來源:BookmarkPanelItem.xaml.cs

示例11: BitmapToDoubleArray

        public static int[][] BitmapToDoubleArray(Bitmap fileBitmap, string extension)
        {
            int[][] uploadedDocument;
            int width = fileBitmap.Width;
            int height = fileBitmap.Height;
            uploadedDocument = new int[width][];
            for (int i = 0; i < width; i++)
                uploadedDocument[i] = new int[height];

            Color pixelColor;
            for (int i = 0; i < width; i++) {
                for (int j = 0; j < height; j++) {
                    switch(extension){
                        case ".bmp":
                        pixelColor = fileBitmap.GetPixel(i, j);
                        uploadedDocument[i][j] = (int)(pixelColor.R * 0.3 + pixelColor.G * 0.59 + pixelColor.B * 0.11);
                            break;
                        case ".png":
                            uploadedDocument[i][j] = (255 - (int)fileBitmap.GetPixel(i,j).A);
                            break;
                    }
                }
            }
            return uploadedDocument;
        }
開發者ID:Amichai,項目名稱:Prax,代碼行數:25,代碼來源:GraphicsHelper.cs

示例12: encode

 public static Bitmap encode(Bitmap img, int offSet)
 {
     Bitmap newImage = new Bitmap(img.Width * offSet, img.Height * offSet);
     List<List<Color>> pixelMap = new List<List<Color>>();
     for (int y = 0; y < img.Height; y++)
     {
         List<Color> row = new List<Color>();
         for (int x = 0; x < img.Width; x++)
         {
             row.Add(img.GetPixel(x, y));
         }
         pixelMap.Add(row);
     }
     Random r = new Random();
     for (int y = 0; y < newImage.Height; y++)
     {
         for (int x = 0; x < newImage.Width; x++)
         {
             if (x % offSet == 0 && y % offSet == 0)
             {
                 newImage.SetPixel(x, y, pixelMap[y / offSet][x / offSet]);
             }
             else
             {
                 newImage.SetPixel(x, y, img.GetPixel(r.Next(0, img.Width - 1), r.Next(0, img.Height - 1)));
             }
         }
     }
     return newImage;
 }
開發者ID:AgentEnder,項目名稱:ImageEncoder,代碼行數:30,代碼來源:encryption.cs

示例13: UniformQuantization

        public static Bitmap UniformQuantization(Bitmap bmp, int kR, int kG, int kB)
        {
            int[] red, green, blue;
            int r, g, b;
            Bitmap res = new Bitmap(bmp.Width, bmp.Height);

            //podziel red
            red = DividePalette(kR);

            //podziel green
            green = DividePalette(kG);

            //podziel blue
            blue = DividePalette(kB);

            for (int i = 0; i < bmp.Width; ++i)
                for (int j = 0; j < bmp.Height; ++j)
                {
                    r = FindClosest(red, bmp.GetPixel(i, j).R);
                    g = FindClosest(green, bmp.GetPixel(i, j).G);
                    b = FindClosest(blue, bmp.GetPixel(i, j).B);

                    res.SetPixel(i, j, Color.FromArgb(r, g, b));
                }

            return res;
        }
開發者ID:padzikm,項目名稱:ComputerGraphics,代碼行數:27,代碼來源:UniformAlgorithm.cs

示例14: write_Bmp_To_RGB_Number

        /// <summary>
        /// Save source bitmap image as text which contains all positions' pixel value
        /// random position value = {R, G, B}
        /// </summary>
        /// <param name="sourceImage"></param>
        /// <param name="path"></param>
        public static void write_Bmp_To_RGB_Number(Bitmap sourceImage, string path)
        {
            try
            {
                int i = 0, j = 0;
                StreamWriter sw = new StreamWriter(path);

                for (j = 0; j < sourceImage.Height; j++)
                {
                    for (i = 0; i < sourceImage.Width; i++)
                    {

                        sw.Write("({0},{1},{2}) ",
                            sourceImage.GetPixel(i, j).R.ToString().PadLeft(3, '0').Replace("255", "   "),
                            sourceImage.GetPixel(i, j).G.ToString().PadLeft(3, '0').Replace("255", "   "),
                            sourceImage.GetPixel(i, j).B.ToString().PadLeft(3, '0').Replace("255", "   "));
                    }
                    sw.WriteLine();
                }
                sw.Flush();
                sw.Close();
            }
            catch (Exception ex)
            {
                throw new Exception(ex.Message);
            }
        }
開發者ID:jiabailie,項目名稱:Digital-Image-Processing,代碼行數:33,代碼來源:FileOperation.cs

示例15: convertToTXT

        public static int[] convertToTXT(Bitmap img)
        {
            double averageBrightness = 0;

            for (int y = 0; y < img.Height; y++)
            {
                for (int x = 0; x < img.Width; x++)
                {
                    averageBrightness += img.GetPixel(x, y).R;
                }
            }
            averageBrightness /= (img.Width * img.Height);
            int[] result = new int[img.Width * img.Height];
            for (int y = 0; y < img.Height; y++)
            {
                for (int x = 0; x < img.Width; x++)
                {
                    if (img.GetPixel(x, y).R < averageBrightness)
                        result[img.Width * y + x] = 0;
                    else
                        result[img.Width * y + x] = 1;
                }
            }
            return result;
        }
開發者ID:NARF-V,項目名稱:controlPrg,代碼行數:25,代碼來源:OCR_System.cs


注:本文中的System.Drawing.Bitmap.GetPixel方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。