I am using opencv edge and contour detection to crop some objects. now thatt object contain two or more colors so I have to change that colors one by one, for ecample I want to change color of apple and add its background as image so how can I do that.
I am trying like referenve app , but I have no idea about this. I used the link for same but stuck in third or fourth steps as don't know how to mask color. one another link I used and write code as given below abut not find my solution. Any link or tutorials then please share.
IplImage *image=[self CreateIplImageFromUIImage:[UIImage imageNamed:@"mask.png"]];
IplImage *hsvImage = cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 3);
cvCvtColor(image,hsvImage,CV_RGB2HSV);
NSLog(@"size is %dx%d",cvGetSize(image).width,cvGetSize(image).height);
IplImage *hChannel = cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 1);
IplImage *sChannel = cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 1);
IplImage *vChannel = cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 1);
cvSplit(hsvImage, hChannel, sChannel, vChannel, NULL);
IplImage *cvinRangeOut=cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 1);
cvinRangeOut=[self inRangeImage:hsvImage];
IplImage *dest = cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 3);
IplImage *temp = cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 3);
cvMerge(hChannel, sChannel, NULL, NULL, temp);
cvSet(hsvImage, cv::Scalar(255,0,0),cvinRangeOut);// destination hue and sat
cvSplit(hsvImage, hChannel, sChannel, NULL, NULL);
cvMerge(hChannel, sChannel, vChannel, NULL, dest);
cvCvtColor(dest, dest, CV_HSV2BGR);
imageView2.image=[self UIImageFromIplImage:dest];
}
-(IplImage *)inRangeImage:(IplImage *)image
{
CvScalar source=CvScalar() ;//source color to replace
IplImage *cvInRange = cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 1);
CvScalar from=getScaler(source,false);
CvScalar to=getScaler(source, true);
cvInRangeS(image, from, to, cvInRange);
return cvInRange;
}
CvScalar getScaler(CvScalar seed,Boolean plus){
if(plus){
NSLog(@"rgb are %f, %f %f",seed.val[0],seed.val[1],seed.val[2]);
NSLog(@"seeds are %f %f %f",seed.val[0]+(seed.val[0]* (int)cv::threshold),seed.val[1]+(seed.val[1]*(int)cv::threshold),seed.val[2]+(seed.val[2]* (int)cv::threshold));
return CV_RGB(seed.val[0]+(seed.val[0]*(int)cv::threshold),seed.val[1]+(seed.val[1]*(int)cv::threshold),seed.val[2]+(seed.val[2]* (int)cv::threshold));
}else{
NSLog(@"seeds are %f %f %f",seed.val[0]-(seed.val[0]*(int)cv::threshold),seed.val[1]-(seed.val[1]*(int)cv::threshold),seed.val[2]-(seed.val[2]* (int)cv::threshold));
return CV_RGB(seed.val[0]-(seed.val[0]*(int)cv::threshold),seed.val[1]-(seed.val[1]*(int)cv::threshold),seed.val[2]-(seed.val[2]* (int)cv::threshold));
}
}