a*P(i-1,j-1)+b*P(i,j-1)+c*P(i+1,j-1)+
+ d*P(i-1,j) + e*P(i,j) + f*P(i+1,j) +
+ g*P(i-1,j+1)+h*P(i,j+1)+k*P(i+1,j+1) ) / (a+b+c+d+e+f+g+h+k) где a b c d e f g h k - элементы матрицы фильтра а P-пикскль изображения так вот как ее применить если bmp храниться как одномерный массив?...
А пока я сделал самый простой фильтр негатив)
DWORD WINAPI InvertPicture(LPVOID lpParameter)
{
int i,j;
HWND parent=(HWND)lpParameter;
for(i=0;i<Picture.bmpih.biHeight;++i){
for(j=0;j<Picture.bmpih.biWidth;++j)
{
Picture.bmp[i*Picture.bmpih.biWidth+j].rgbtBlue=~Picture.bmp[i*Picture.bmpih.biWidth+j].rgbtBlue;
Picture.bmp[i*Picture.bmpih.biWidth+j].rgbtGreen=~Picture.bmp[i*Picture.bmpih.biWidth+j].rgbtGreen;
Picture.bmp[i*Picture.bmpih.biWidth+j].rgbtRed=~Picture.bmp[i*Picture.bmpih.biWidth+j].rgbtRed;
}
InvalidateRect(parent,0,TRUE);
if(i%9==0)Sleep(50);
}
return 0;
}