1

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));
    }
 }
Community
  • 1
  • 1
Kamal Bhardwaj
  • 948
  • 1
  • 10
  • 25
  • Why didn't you just edit the question you asked two days ago http://stackoverflow.com/questions/16918422/mask-color-and-replace-with-some-another-color-opencv-ios ? – Bull Jun 05 '13 at 13:26

1 Answers1

1

I done it in this way. Hope it would help someone:

imageView.image=[UIImage imageNamed:@"test.png"];
cv::Mat img=[self cvMatFromUIImage:imageView.image];
cv::Mat hsvImage=cvCreateImage(img.size(),8, 3);
cv::cvtColor(img, hsvImage, CV_BGR2HSV);

std::vector<cv::Mat>channels;

cv::split(hsvImage, channels);
cv::Mat hue = channels[0];
cv::Mat dest;
cv::Mat temp=cvCreateImage(img.size(), 8, 3);

cv::inRange(hsvImage, cv::Scalar(90,50,50), cv::Scalar(130,255,255), dest);
cv::merge(channels, temp);
temp.setTo(cv::Scalar(60,255,255),dest);
cv::split(temp, channels);
cv::merge(channels, dest);
cv::cvtColor(dest, hsvImage, CV_HSV2BGR);
imageView.image=[self UIImageFromCVMat:hsvImage];
Kamal Bhardwaj
  • 948
  • 1
  • 10
  • 25