rgb 이미지를 ycbcr 이미지로 변환하고 그 반대로 수동으로 변환하려고합니다. 그러나 실수가 있으며 찾을 수 없습니다.OpenCV에서 RGB로 YCbCr로 또는 그 반대로 손으로 (Visual C++)
내 이미지가 제대로 보이지 않습니다. http://paste2.org/p/1569904
내가 생각하는이 같은 자사의 캐스팅 오류 또는 뭔가 :
여기void YCbCrToRGB(IplImage* ScrY, IplImage* ScrCb, IplImage* ScrCr, IplImage* DesR, IplImage* DesG, IplImage* DesB){
for(int i=0; i < ScrY->height; i++){
for(int j=0; j < ScrY->width; j++){
double Y = (double)(ScrY->imageData + ScrY->widthStep*i)[j];
double Cb = (double)(ScrCb->imageData + ScrCb->widthStep*i)[j];
double Cr = (double)(ScrCr->imageData + ScrCr->widthStep*i)[j];
Cb = Cb -128;
Cr = Cr -128;
int r;
int g;
int b;
(DesR->imageData + DesR->widthStep*i)[j] = (int)(1 * Y + 0 * Cb + 1.4 * Cr);
(DesG->imageData + DesG->widthStep*i)[j] = (int)(1 * Y - 0.343 * Cb - 0.711 *Cr);
(DesB->imageData + DesB->widthStep*i)[j] = (int)(1* Y + 1.765 * Cb + 0* Cr);
}}
void RGBtoYCbCr(IplImage* ScrR, IplImage* ScrG, IplImage* ScrB, IplImage* DesY, IplImage* DesCb, IplImage* DesCr){
for(int i=0; i < ScrR->height; i++){
for(int j=0; j < ScrR->width; j++){
double R = (double)(ScrR->imageData + ScrR->widthStep*i)[j];
double G = (double)(ScrG->imageData + ScrG->widthStep*i)[j];
double B = (double)(ScrB->imageData + ScrB->widthStep*i)[j];
(DesY->imageData + DesY->widthStep*i)[j] = 0.299 *R + 0.587 *G + 0.114 *B;
(DesCb->imageData + DesCb->widthStep*i)[j] = -0.1687 *R - 0.3313 *G + 0.5 *B + 128;
(DesCr->imageData + DesCr->widthStep*i)[j] = 0.5 *R - 0.4187 *G - 0.0813 *B + 128;
}
}}
int _tmain(int argc, _TCHAR* argv[])
{
try {
IplImage* img = cvLoadImage("C:\\sad-cat.jpg",1);
cvNamedWindow("Example1", CV_WINDOW_AUTOSIZE);
cvShowImage("Example1", img);
IplImage *r = cvCreateImage(cvGetSize(img), img->depth, 1);
IplImage *g = cvCreateImage(cvGetSize(img), img->depth, 1);
IplImage *b = cvCreateImage(cvGetSize(img), img->depth, 1);
cvSplit(img, b, g, r, NULL);
IplImage *y = cvCreateImage(cvGetSize(img), img->depth, 1);
IplImage *cb = cvCreateImage(cvGetSize(img), img->depth, 1);
IplImage *cr = cvCreateImage(cvGetSize(img), img->depth, 1);
RGBtoYCbCr(r,g,b,y,cb,cr);
IplImage *ycbcr = cvCreateImage(cvGetSize(img), img->depth, 3);
cvMerge(y,cb,cr,NULL,ycbcr);
cvNamedWindow("YCbCr from RGB", CV_WINDOW_AUTOSIZE);
cvShowImage("YCbCr from RGB", ycbcr);
YCbCrToRGB(y,cb,cr,r,g,b);
IplImage *RGBfromYCbCr = cvCreateImage(cvGetSize(img), img->depth, 3);
cvMerge(r,g,b,NULL,RGBfromYCbCr);
cvNamedWindow("RGB from YCbCr", CV_WINDOW_AUTOSIZE);
cvShowImage("RGB from YCbCr", RGBfromYCbCr);
cvWaitKey(0);
return 0;
}
catch(exception& e){
std::cout<<("An error occurred.") << std::endl;
std::cout << e.what() <<std::endl; // Print the error message.
cvWaitKey(0);
}
}
구문 강조와 함께 링크입니다 : 다음은 내 코드입니다.
, 내 대답은 어쩌면 바보
이미지 http://i.stack.imgur.com/eos3m.jpg – vo1d
나는 공식을 http://www.equasys.de/colorconversion.html 및 http://opencv.willowgarage.com/에서 시험해 보았습니다. documentation/c/miscellaneous_image_transformations.html – vo1d