1
0
Fork 0
mirror of https://github.com/ruby-opencv/ruby-opencv synced 2023-03-27 23:22:12 -04:00

added error handling to IplImage methods

This commit is contained in:
ser1zw 2011-07-21 23:06:40 +09:00
parent 92c0582580
commit 354d47830a

View file

@ -88,9 +88,9 @@ rb_initialize(int argc, VALUE *argv, VALUE self)
{ {
VALUE width, height, depth, channel; VALUE width, height, depth, channel;
rb_scan_args(argc, argv, "22", &width, &height, &depth, &channel); rb_scan_args(argc, argv, "22", &width, &height, &depth, &channel);
int _depth = argc < 3 ? CV_8U : FIX2INT(depth); int _depth = CVMETHOD("DEPTH", depth, CV_8U);
int _channel = argc < 4 ? 3 : FIX2INT(channel); int _channel = argc < 4 ? 3 : NUM2INT(channel);
DATA_PTR(self) = rb_cvCreateImage(cvSize(FIX2INT(width), FIX2INT(height)), cvIplDepth(_depth), _channel); DATA_PTR(self) = rb_cvCreateImage(cvSize(NUM2INT(width), NUM2INT(height)), cvIplDepth(_depth), _channel);
return self; return self;
} }
@ -139,7 +139,14 @@ rb_load_image(int argc, VALUE *argv, VALUE self)
VALUE VALUE
rb_get_roi(VALUE self) rb_get_roi(VALUE self)
{ {
return cCvRect::new_object(cvGetImageROI(IPLIMAGE(self))); CvRect rect;
try {
rect = cvGetImageROI(IPLIMAGE(self));
}
catch (cv::Exception& e) {
raise_cverror(e);
}
return cCvRect::new_object(rect);
} }
/* /*
@ -154,14 +161,20 @@ VALUE
rb_set_roi(VALUE self, VALUE roi) rb_set_roi(VALUE self, VALUE roi)
{ {
VALUE block = rb_block_given_p() ? rb_block_proc() : 0; VALUE block = rb_block_given_p() ? rb_block_proc() : 0;
try {
if (block) { if (block) {
CvRect prev_roi = cvGetImageROI(IPLIMAGE(self)); CvRect prev_roi = cvGetImageROI(IPLIMAGE(self));
cvSetImageROI(IPLIMAGE(self), VALUE_TO_CVRECT(roi)); cvSetImageROI(IPLIMAGE(self), VALUE_TO_CVRECT(roi));
rb_yield_values(1, self); rb_yield_values(1, self);
cvSetImageROI(IPLIMAGE(self), prev_roi); cvSetImageROI(IPLIMAGE(self), prev_roi);
} else { }
else {
cvSetImageROI(IPLIMAGE(self), VALUE_TO_CVRECT(roi)); cvSetImageROI(IPLIMAGE(self), VALUE_TO_CVRECT(roi));
} }
}
catch (cv::Exception& e) {
raise_cverror(e);
}
return self; return self;
} }
@ -172,7 +185,12 @@ rb_set_roi(VALUE self, VALUE roi)
VALUE VALUE
rb_reset_roi(VALUE self) rb_reset_roi(VALUE self)
{ {
try {
cvResetImageROI(IPLIMAGE(self)); cvResetImageROI(IPLIMAGE(self));
}
catch (cv::Exception& e) {
raise_cverror(e);
}
return self; return self;
} }
@ -182,7 +200,14 @@ rb_reset_roi(VALUE self)
VALUE VALUE
rb_get_coi(VALUE self) rb_get_coi(VALUE self)
{ {
return INT2FIX(cvGetImageCOI(IPLIMAGE(self))); int coi = 0;
try {
coi = cvGetImageCOI(IPLIMAGE(self));
}
catch (cv::Exception& e) {
raise_cverror(e);
}
return INT2FIX(coi);
} }
/* /*
@ -197,13 +222,19 @@ VALUE
rb_set_coi(VALUE self, VALUE coi) rb_set_coi(VALUE self, VALUE coi)
{ {
VALUE block = rb_block_given_p() ? rb_block_proc() : 0; VALUE block = rb_block_given_p() ? rb_block_proc() : 0;
try {
if (block) { if (block) {
int prev_coi = cvGetImageCOI(IPLIMAGE(self)); int prev_coi = cvGetImageCOI(IPLIMAGE(self));
cvSetImageCOI(IPLIMAGE(self), FIX2INT(coi)); cvSetImageCOI(IPLIMAGE(self), NUM2INT(coi));
rb_yield_values(1, self); rb_yield_values(1, self);
cvSetImageCOI(IPLIMAGE(self), prev_coi); cvSetImageCOI(IPLIMAGE(self), prev_coi);
} else { }
cvSetImageCOI(IPLIMAGE(self), FIX2INT(coi)); else {
cvSetImageCOI(IPLIMAGE(self), NUM2INT(coi));
}
}
catch (cv::Exception& e) {
raise_cverror(e);
} }
return self; return self;
} }
@ -214,7 +245,12 @@ rb_set_coi(VALUE self, VALUE coi)
VALUE VALUE
rb_reset_coi(VALUE self) rb_reset_coi(VALUE self)
{ {
try {
cvSetImageCOI(IPLIMAGE(self), 0); cvSetImageCOI(IPLIMAGE(self), 0);
}
catch (cv::Exception& e) {
raise_cverror(e);
}
return self; return self;
} }