Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/13: Рейтинг темы: голосов - 13, средняя оценка - 4.69
0 / 0 / 2
Регистрация: 10.09.2012
Сообщений: 40
1

Матричная фильтрация изображения C++ Builder

28.10.2012, 12:40. Показов 2563. Ответов 5
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Доброго дня! Дали задание сделать матричную фильтрацию по красному каналу изображения. Беру соответственно каждый пиксель исходного выдераю красный канал из его окружающих. Значение красного каждого умножаю на матрицу весов, при этом каждое произведение на матричный элемент делится на сумму всех элементов матрицы весов (автоделение), все это складывается и в пиксель уже другого Image ложу цвет с новым красным (R,g,b). Он мне осуществляет как будто небольшое затемнение, ну вот оно не значительно, пробую делать побольше, подругому всяко матрицу весов, деля на сумму элементов матрицы, изображение не меняется...Хотел в связи с этим узнать:
1. Матрица весов может быть какой угодно?
2. Правильно ли все делаю?
3. Как сделать эффект сильнее?
Но при этом задание у меня фильтровать только по красному.

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
//---------------------------------------------------------------------------
 
#include <vcl.h>
#pragma hdrstop
 
#include "Unit1.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
int i=0,j=0,r,g,b,k,l; float **A=new float*[3]; COLORREF pixel_color; float R=0;;
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
        : TForm(Owner)
{
}
//---------------------------------------------------------------------------
 
void __fastcall TForm1::Button2Click(TObject *Sender)
{
 int a; int b;
  //вызов окна диалога ОТКРЫТИЕ ГРАФИЧЕСКОГО ФАЙЛА
 
OpenPictureDialog1->Execute();
 
if (OpenPictureDialog1->FileName != "")     //если в окне диалога есть файл
 {
 
//загрузка файла в поле Image1 с диска
 
Image1->Picture->LoadFromFile(OpenPictureDialog1->FileName);
 /*if ((Image1->Picture->Width>Image1->Width)||(Image1->Picture->Height>Image1->Height))
  {
   Image1->Stretch=true;
  }
  else
  Image1->Stretch=false;*/
      //ширину Image1 сравнять с шириной загружаемого изображения
  Image1->Width = Image1->Picture->Width;
      //высоту Image1 сравнять с высотой загружаемого изображения
  Image1->Height = Image1->Picture->Height;
  Panel2->Width = Image1->Picture->Width;
  Panel2->Height = Image1->Picture->Height;
  Image2->Width = Image1->Picture->Width;
  Image2->Height = Image1->Picture->Height;
  Panel3->Width = Image1->Picture->Width;
  Panel3->Height = Image1->Picture->Height;
  Edit1->Text=IntToStr(Image2->Width);
  Edit2->Text=IntToStr(Image2->Height);
 
 }
}
//---------------------------------------------------------------------------
 
void __fastcall TForm1::Button1Click(TObject *Sender)
{ for(i=0;i<=Image1->Picture->Width;i++)
  for(j=0;j<=Image1->Picture->Height;j++)
 
  {pixel_color = GetPixel(Image1->Picture->Bitmap->Canvas->Handle,i,j);
   r= GetRValue(pixel_color);
   g= GetGValue(pixel_color);
   b= GetBValue(pixel_color);
  /*Edit3->Text=IntToStr(r);
  Edit4->Text=IntToStr(g);
  Edit5->Text=IntToStr(b);*/
   Image2->Canvas->Pixels[i][j]= RGB(r,g,b);
  }
}
//---------------------------------------------------------------------------
void __fastcall TForm1::FormCreate(TObject *Sender)
{
 for(i=0;i<3;i++)
 A[i]= new float[3];
 A[0][0]=0.5;
 A[0][1]=0.75;
 A[0][2]=0.5;
 A[1][0]=0,75;
 A[1][1]=1;
 A[1][2]=0.75;
 A[2][0]=0.5;
 A[2][1]=0.75;
 A[2][2]=0.5;
}
//---------------------------------------------------------------------------
void __fastcall TForm1::Button3Click(TObject *Sender)
{
 for(i=1;i<Image1->Picture->Width;i++){
 for(j=1;j<Image1->Picture->Height;j++){
 pixel_color = GetPixel(Image1->Picture->Bitmap->Canvas->Handle,i,j);
 g= GetGValue(pixel_color);
 b= GetBValue(pixel_color);
 for(l=-1;l<=1;l++){
 for(k=-1;k<=1;k++){
     pixel_color = GetPixel(Image1->Picture->Bitmap->Canvas->Handle,i+l,j+k);
     r= GetRValue(pixel_color);
     R=R+(r*A[l+1][k+1])/6;
    }
   }
  Image2->Canvas->Pixels[i][j]= RGB(R,g,b);
  R=0;
  }
 }
}
//---------------------------------------------------------------------------
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
28.10.2012, 12:40
Ответы с готовыми решениями:

Поиск, фильтрация на С++ Builder
Подскажите как сделать полнотекстовый поиск:Form1-&gt;QueryBook-&gt;Active = false; AnsiString str1 =...

Фильтрация по ФИО в БД на C Builder
Имеется БД написанная на C++ Builder 2006, необходимо сделать фильтацию по ФИО, пользоваетель...

Фильтрация данных (Delphi -> Builder)
Добрый день, помогите переименовать этот код в С++ Builder. with ADOTable1 do begin ...

Фильтрация подставных полей в Builder
Проблема с фильтром для подставного поля Table3-&gt;Filtered=false; Table3-&gt;Filter=Edit2-&gt;Text;...

5
Эксперт С++
8482 / 6149 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
28.10.2012, 13:58 2
C++
1
 pixel_color = GetPixel(Image1->Picture->Bitmap->Canvas-> // ...
C++
1
pixel_color = Image1->Picture->Bitmap->Canvas->Pixels[x][y]
;
0
0 / 0 / 2
Регистрация: 10.09.2012
Сообщений: 40
29.10.2012, 05:05  [ТС] 3
Цитата Сообщение от Avazart Посмотреть сообщение
C++
1
 pixel_color = GetPixel(Image1->Picture->Bitmap->Canvas-> // ...
C++
1
pixel_color = Image1->Picture->Bitmap->Canvas->Pixels[x][y]
;
Благодарю, стала быстрей работать! но суть отработки осталась той же, поэтому вопросы все те же, спасибо
0
Эксперт С++
8482 / 6149 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
29.10.2012, 13:21 4
1. Матрица весов может быть какой угодно?
Ну об этом читать надо, и вам наверное должно быть лучше известно задание.

Добавлено через 39 секунд
В место COLORREF класс TColor
1
0 / 0 / 2
Регистрация: 10.09.2012
Сообщений: 40
30.10.2012, 07:58  [ТС] 5
Цитата Сообщение от Avazart Посмотреть сообщение
Ну об этом читать надо, и вам наверное должно быть лучше известно задание.

Добавлено через 39 секунд
В место COLORREF класс TColor
А как реализовать с Tcolor не подскажите? как тогда выдирать цвет пикселя? и в чем отличие будет если вместо colorref использовать TColor?
0
Эксперт С++
8482 / 6149 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
30.10.2012, 13:26 6
C++
1
2
3
TColor pixel_color;
//...
pixel_color = Image1->Picture->Bitmap->Canvas->Pixels[x][y];
Все остальное также.

Отличие в том что TColor тип данных VCL, а не WinApi его возвращает
C++
1
Image1->Picture->Bitmap->Canvas->Pixels[x][y]
1
30.10.2012, 13:26
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
30.10.2012, 13:26
Помогаю со студенческими работами здесь

Поиск и фильтрация данных в БД Access через C++ Builder
Помогите пожалуйста. Нужно реализовать поиск и фильтрацию данных в C++ Builder из БД Access....

Преобразование Фурье. Фильтрация изображения
Имеется программа, выполняющая фильтрацию видео с помощью фурье преобразования на с++ с...

Фильтрация изображения линейным оконным фильтром
Люди будьте добры, мне нужна ваша помощь, мне дали задание, а я даже не могу сути его понять. Вот...

Изображения, c++ builder и ms sql
Приветствую, столкнулся с такой ситуацией что не могу считать изображение из поля в БД. На форме...

Виннеровская фильтрация изображения
Нужно исказить изображение аддитивным гауссовским шумом, при этом отношение сигнал/шум q^2=2 ....

Графика: Фильтрация изображения
1) Фильтрация изображения произвольным фильтром 2) Зеркальное отображение пикселей относительно...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru