Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/55: Рейтинг темы: голосов - 55, средняя оценка - 4.64
0 / 0 / 0
Регистрация: 13.10.2015
Сообщений: 43

Изображение в оттенки серого

05.11.2016, 23:50. Показов 11624. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Помогите, пожалуйста.
Дело в том, что мне необходимо перевести изображение в оттенки серого, потом применять на него матричные фильтры.
Но после перевода и применения размытия изображение вновь становится цветным.
Кликните здесь для просмотра всего текста
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
public static UInt32[,] matrix_filtration(int W, int H, UInt32[,] pixel, int N, double[,] matryx)
            {
                int i, j, k, m, gap = (int)(N / 2);
                int tmpH = H + 2 * gap, tmpW = W + 2 * gap;
                UInt32[,] tmppixel = new UInt32[tmpH, tmpW];
                UInt32[,] newpixel = new UInt32[H, W];
                //заполнение временного расширенного изображения
                //углы
                for (i = 0; i < gap; i++)
                    for (j = 0; j < gap; j++)
                    {
                        tmppixel[i, j] = pixel[0, 0];
                        tmppixel[i, tmpW - 1 - j] = pixel[0, W - 1];
                        tmppixel[tmpH - 1 - i, j] = pixel[H - 1, 0];
                        tmppixel[tmpH - 1 - i, tmpW - 1 - j] = pixel[H - 1, W - 1];
                    }
                //крайние левая и правая стороны
                for (i = gap; i < tmpH - gap; i++)
                    for (j = 0; j < gap; j++)
                    {
                        tmppixel[i, j] = pixel[i - gap, j];
                        tmppixel[i, tmpW - 1 - j] = pixel[i - gap, W - 1 - j];
                    }
                //крайние верхняя и нижняя стороны
                for (i = 0; i < gap; i++)
                    for (j = gap; j < tmpW - gap; j++)
                    {
                        tmppixel[i, j] = pixel[i, j - gap];
                        tmppixel[tmpH - 1 - i, j] = pixel[H - 1 - i, j - gap];
                    }
                //центр
                for (i = 0; i < H; i++)
                    for (j = 0; j < W; j++)
                        tmppixel[i + gap, j + gap] = pixel[i, j];
                //применение ядра свертки
                RGB ColorOfPixel = new RGB();
                RGB ColorOfCell = new RGB();
                for (i = gap; i < tmpH - gap; i++)
                    for (j = gap; j < tmpW - gap; j++)
                    {
                        ColorOfPixel.R = 0;
                        ColorOfPixel.G = 0;
                        ColorOfPixel.B = 0;
                        for (k = 0; k < N; k++)
                            for (m = 0; m < N; m++)
                            {
                                ColorOfCell = calculationOfColor(tmppixel[i - gap + k, j - gap + m], matryx[k, m]);
                                ColorOfPixel.R += ColorOfCell.R;
                                ColorOfPixel.G += ColorOfCell.G;
                                ColorOfPixel.B += ColorOfCell.B;
                            }
                        //контролируем переполнение переменных
                        if (ColorOfPixel.R < 0) ColorOfPixel.R = 0;
                        if (ColorOfPixel.R > 255) ColorOfPixel.R = 255;
                        if (ColorOfPixel.G < 0) ColorOfPixel.G = 0;
                        if (ColorOfPixel.G > 255) ColorOfPixel.G = 255;
                        if (ColorOfPixel.B < 0) ColorOfPixel.B = 0;
                        if (ColorOfPixel.B > 255) ColorOfPixel.B = 255;
 
                        newpixel[i - gap, j - gap] = build(ColorOfPixel);
                    }
 
                return newpixel;
            }
 
            //вычисление нового цвета
            public static RGB calculationOfColor(UInt32 pixel, double coefficient)
            {
                RGB Color = new RGB();
                Color.R = (float)(coefficient * ((pixel & 0x00FF0000)>>16)); //>>16
                Color.G = (float)(coefficient * ((pixel & 0x0000FF00) >>8));//>>8
            Color.B = (float)(coefficient * ((pixel & 0x000000FF)));
                return Color;
            }
 
            //сборка каналов
            public static UInt32 build(RGB ColorOfPixel)
            {
                UInt32 Color;
                Color = ((UInt32)ColorOfPixel.R << 16) | ((UInt32)ColorOfPixel.G << 8) | ((UInt32)ColorOfPixel.B);
                return Color;
            }
 
            public const int N = 3;
            public static double[,] blur = new double[N, N] {{0.111,0.111,0.111},
                                                          { 0.111,0.111,0.111},
                                                          { 0.111,0.111,0.111}};
        public void Gray(PictureBox pb)
        {
            int brg;
            Bitmap bmp = new Bitmap(pb.Image);
            for (int i = 1; i < bmp.Width; i++)
            {
                for (int j = 1; j < bmp.Height; j++)
                {
                    brg = (int)(0.3 * bmp.GetPixel(i, j).R + 0.59 * bmp.GetPixel(i, j).G + 0.11 * bmp.GetPixel(i, j).B);
                    bmp.SetPixel(i, j, Color.FromArgb(brg, brg, brg));
                }
            }
            pb.Image = bmp;
            
        }
        private void размытиеToolStripMenuItem_Click(object sender, EventArgs e)
        {
            if (nameofimage!="/0")
            {
                pixel = Filter.matrix_filtration(image.Width, image.Height, pixel, Filter.N, Filter.blur);
                FromPixelToBitmap();
                FromBitmapToScreen();
            }
        }
 
        private void матричныйФильтрToolStripMenuItem_Click(object sender, EventArgs e)
        {
            W W = new W();
            W.Show();
        }
 
        private void menuStrip1_ItemClicked(object sender, ToolStripItemClickedEventArgs e)
        {
 
        }
 
        private void оттенкиСерогоToolStripMenuItem_Click(object sender, EventArgs e)
        {
           obj.Gray(pictureBox1);
            FromPixelToBitmap();
        }
        public static void FromPixelToBitmap()
        {
            for (int y = 0; y < image.Height; y++)
                for (int x = 0; x < image.Width; x++)
                    image.SetPixel(x, y, Color.FromArgb((int)pixel[y, x]));
        }
 
        //вывод на экран
        public void FromBitmapToScreen()
        {
            pictureBox1.Image = image;
        }

Прикрепил саму программу
Помогите, пожалуйста, совсем не понимаю, что не так.
Вложения
Тип файла: rar Laba4.rar (66.1 Кб, 50 просмотров)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
05.11.2016, 23:50
Ответы с готовыми решениями:

Преобразовать BMP в оттенки серого
Подскажите пожалуйста, мне нужно преобразовать цветной BMP (фактически это скриншот) файл в оттенки серого. В 256 оттенков серого или...

Как массив байтов (1 байт на пиксель (изображение в оттенках серого) запихнуть в Bitmap и отобразить в PicterBox?
Здравствуйте! Мне понадобилось каждое входящее изображение переводить в изображение в градациях серого (256 цветов). В Bitmap, я так понял,...

Преобразование изображения к оттенкам серого
Здравствуйте! Очень нужна помощь) Пишу приложение, которое делает выделение контуров на изображении методом Робертса. Для начала нужно...

1
1498 / 1213 / 821
Регистрация: 29.02.2016
Сообщений: 3,631
06.11.2016, 08:16
http://www.codeproject.com/Art... ng-using-C
http://www.codeproject.com/Art... g-Lab-in-C
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
06.11.2016, 08:16
Помогаю со студенческими работами здесь

Как нарисовать 20 кружочков серого цвета?
Нужно создать цикл который нарисует 20 серых кружочков в ряд и каждый из них в нутри себя содержал число 1-2-3-4..20. возможно такое...

Сохранение изображения 16-бит оттенков серого
Получаю массив цвета пикселей. Необходимо сохранить его в .tiff На экран вывести 16 бит проблематично, поэтому достаточно будет и 8...

Создать 256 оттенков серого из любой картинки
Доброго времени суток. Существует задача зашифровки небольшого изображения. Для этого нужно знать значение градации серого...

Сортировка рисунков: черно-белые, с градацией серого и цветные
У меня задача написать программу для сортировки рисунков на три вида: черно-белые, с градацией серого и цветные. Может кто знает как...

Как сделать, чтобы каждому значению Х соответсвовал оттенок серого
Добрый день! Задача: значение переменной Х находится в диапазоне . При Х=0 Сolor Y=Сolor.black При Х=300 Сolor Y=Сolor.white ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru