Skip to content

Commit 9810fd3

Browse files
committed
Add CV\Mat->size() and opencv_size_update_property_by_c_size
1 parent 5c9393d commit 9810fd3

File tree

3 files changed

+52
-6
lines changed

3 files changed

+52
-6
lines changed

source/opencv2/core/opencv_mat.cc

Lines changed: 44 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -131,8 +131,8 @@ PHP_METHOD(opencv_mat, empty)
131131

132132
PHP_METHOD(opencv_mat, zeros)
133133
{
134-
long rows, cols, flags = IMREAD_COLOR;
135-
if (zend_parse_parameters(ZEND_NUM_ARGS(), "ll|l", &rows, &cols, &flags) == FAILURE) {
134+
long rows, cols, flags;
135+
if (zend_parse_parameters(ZEND_NUM_ARGS(), "lll", &rows, &cols, &flags) == FAILURE) {
136136
RETURN_NULL();
137137
}
138138
zval instance;
@@ -148,6 +148,27 @@ PHP_METHOD(opencv_mat, zeros)
148148
RETURN_ZVAL(&instance,0,0); //return php Mat object
149149
}
150150

151+
PHP_METHOD(opencv_mat, zeros_by_size)
152+
{
153+
zval *size_zval;
154+
long flags;
155+
if (zend_parse_parameters(ZEND_NUM_ARGS(), "Ol", &size_zval, opencv_size_ce, &flags) == FAILURE) {
156+
RETURN_NULL();
157+
}
158+
159+
opencv_size_object *size_object = Z_PHP_SIZE_OBJ_P(size_zval);
160+
zval instance;
161+
object_init_ex(&instance, opencv_mat_ce);
162+
opencv_mat_object *obj = Z_PHP_MAT_OBJ_P(&instance);
163+
164+
Mat im = Mat::zeros(*size_object->size, (int)flags);
165+
166+
obj->mat=new Mat(im);
167+
opencv_mat_update_property_by_c_mat(&instance, obj->mat);
168+
169+
RETURN_ZVAL(&instance,0,0);
170+
}
171+
151172

152173
/**
153174
* Mat->clone()
@@ -261,7 +282,7 @@ PHP_METHOD(opencv_mat, get_image_roi)
261282
opencv_mat_object *obj = Z_PHP_MAT_OBJ_P(getThis());
262283
try {
263284
Mat roi = (*obj->mat)(*rect_object->rect);
264-
new_obj->mat=new Mat(roi);
285+
new_obj->mat = new Mat(roi);
265286
}catch (Exception exception){
266287
const char* err_msg = exception.what();
267288
opencv_throw_exception(err_msg);//throw exception
@@ -393,6 +414,24 @@ PHP_METHOD(opencv_mat, convert_to){
393414
RETURN_NULL();
394415
}
395416

417+
PHP_METHOD(opencv_mat, size)
418+
{
419+
zval instance;
420+
object_init_ex(&instance, opencv_size_ce);
421+
opencv_size_object *size_object = Z_PHP_SIZE_OBJ_P(&instance);
422+
423+
opencv_mat_object *obj = Z_PHP_MAT_OBJ_P(getThis());
424+
try {
425+
Size size = obj->mat->size();
426+
size_object->size = new Size(size);
427+
}catch (Exception e){
428+
opencv_throw_exception(e.what());
429+
RETURN_NULL();
430+
}
431+
opencv_size_update_property_by_c_size(&instance, size_object->size);
432+
RETURN_ZVAL(&instance,0,0);
433+
}
434+
396435

397436
/**
398437
* opencv_mat_methods[]
@@ -404,7 +443,9 @@ const zend_function_entry opencv_mat_methods[] = {
404443
PHP_ME(opencv_mat, channels, NULL, ZEND_ACC_PUBLIC)
405444
PHP_ME(opencv_mat, empty, NULL, ZEND_ACC_PUBLIC)
406445
PHP_ME(opencv_mat, print, NULL, ZEND_ACC_PUBLIC)
446+
PHP_ME(opencv_mat, size, NULL, ZEND_ACC_PUBLIC)
407447
PHP_ME(opencv_mat, zeros, NULL, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
448+
PHP_MALIAS(opencv_mat, zerosBySize ,zeros_by_size, NULL, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
408449
PHP_MALIAS(opencv_mat, isContinuous ,is_continuous, NULL, ZEND_ACC_PUBLIC)
409450
PHP_MALIAS(opencv_mat, isSubmatrix ,is_submatrix, NULL, ZEND_ACC_PUBLIC)
410451
PHP_ME(opencv_mat, row, NULL, ZEND_ACC_PUBLIC)

source/opencv2/core/opencv_type.cc

Lines changed: 6 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -272,6 +272,11 @@ void opencv_size_free_obj(zend_object *object)
272272
zend_object_std_dtor(object);
273273
}
274274

275+
void opencv_size_update_property_by_c_size(zval *z, Size *size){
276+
zend_update_property_long(opencv_size_ce, z, "width", sizeof("width")-1, size->width);
277+
zend_update_property_long(opencv_size_ce, z, "height", sizeof("height")-1, size->height);
278+
}
279+
275280

276281
/**
277282
* Size __construct
@@ -287,9 +292,7 @@ PHP_METHOD(opencv_size, __construct)
287292
opencv_size_object *obj = Z_PHP_SIZE_OBJ_P(getThis());
288293
Size size = Size((int)width, (int)height);
289294
obj->size = new Size(size);
290-
291-
zend_update_property_long(opencv_size_ce, getThis(), "width", sizeof("width")-1, obj->size->width);
292-
zend_update_property_long(opencv_size_ce, getThis(), "height", sizeof("height")-1, obj->size->height);
295+
opencv_size_update_property_by_c_size(getThis(), obj->size);
293296
}
294297

295298

source/opencv2/core/opencv_type.h

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -75,6 +75,8 @@ static inline opencv_rect_object* get_rect_obj(zend_object *obj) {
7575
return (opencv_rect_object*)((char*)(obj) - XtOffsetOf(opencv_rect_object, std));
7676
}
7777

78+
void opencv_size_update_property_by_c_size(zval *z, Size *size);
79+
7880
void opencv_rect_update_property_by_c_rect(zval *z, Rect *rect);
7981

8082
void opencv_scalar_update_property_by_c_scalar(zval *z,Scalar *scalar);

0 commit comments

Comments
 (0)