mirror of
https://github.com/ruby-opencv/ruby-opencv
synced 2023-03-27 23:22:12 -04:00
286 lines
6.2 KiB
C++
286 lines
6.2 KiB
C++
/************************************************************
|
|
|
|
algorithm.cpp -
|
|
|
|
$Author: ser1zw $
|
|
|
|
Copyright (C) 2013 ser1zw
|
|
|
|
************************************************************/
|
|
#include <stdio.h>
|
|
#include "algorithm.h"
|
|
/*
|
|
* Document-class: OpenCV::Algorithm
|
|
*
|
|
*/
|
|
__NAMESPACE_BEGIN_OPENCV
|
|
__NAMESPACE_BEGIN_ALGORITHM
|
|
|
|
VALUE rb_klass;
|
|
|
|
VALUE
|
|
rb_class()
|
|
{
|
|
return rb_klass;
|
|
}
|
|
|
|
VALUE
|
|
rb_set_int(VALUE self, VALUE parameter, VALUE value)
|
|
{
|
|
Check_Type(T_STRING, parameter);
|
|
try {
|
|
ALGORITHM(self)->setInt(StringValueCStr(parameter), NUM2INT(value));
|
|
}
|
|
catch (cv::Exception& e) {
|
|
raise_cverror(e);
|
|
}
|
|
|
|
return Qnil;
|
|
}
|
|
|
|
VALUE
|
|
rb_set_double(VALUE self, VALUE parameter, VALUE value)
|
|
{
|
|
Check_Type(T_STRING, parameter);
|
|
try {
|
|
ALGORITHM(self)->setDouble(StringValueCStr(parameter), NUM2DBL(value));
|
|
}
|
|
catch (cv::Exception& e) {
|
|
raise_cverror(e);
|
|
}
|
|
|
|
return Qnil;
|
|
}
|
|
|
|
VALUE
|
|
rb_set_bool(VALUE self, VALUE parameter, VALUE value)
|
|
{
|
|
Check_Type(T_STRING, parameter);
|
|
try {
|
|
bool val = TRUE_OR_FALSE(value) ? true : false;
|
|
ALGORITHM(self)->setBool(StringValueCStr(parameter), val);
|
|
}
|
|
catch (cv::Exception& e) {
|
|
raise_cverror(e);
|
|
}
|
|
|
|
return Qnil;
|
|
}
|
|
|
|
VALUE
|
|
rb_set_string(VALUE self, VALUE parameter, VALUE value)
|
|
{
|
|
Check_Type(T_STRING, parameter);
|
|
Check_Type(T_STRING, value);
|
|
try {
|
|
ALGORITHM(self)->setString(StringValueCStr(parameter), StringValueCStr(value));
|
|
}
|
|
catch (cv::Exception& e) {
|
|
raise_cverror(e);
|
|
}
|
|
|
|
return Qnil;
|
|
}
|
|
|
|
VALUE
|
|
rb_set_mat(VALUE self, VALUE parameter, VALUE value)
|
|
{
|
|
Check_Type(T_STRING, parameter);
|
|
try {
|
|
CvMat* val = CVMAT_WITH_CHECK(value);
|
|
cv::Mat mat(val);
|
|
ALGORITHM(self)->setMat(StringValueCStr(parameter), mat);
|
|
}
|
|
catch (cv::Exception& e) {
|
|
raise_cverror(e);
|
|
}
|
|
|
|
return Qnil;
|
|
}
|
|
|
|
VALUE
|
|
rb_set_matvector(VALUE self, VALUE parameter, VALUE value)
|
|
{
|
|
Check_Type(T_STRING, parameter);
|
|
Check_Type(T_ARRAY, value);
|
|
try {
|
|
long len = RARRAY_LEN(value);
|
|
VALUE* value_ptr = RARRAY_PTR(value);
|
|
std::vector<cv::Mat> mat_vector;
|
|
for (int i = 0; i < len; i++) {
|
|
CvMat* val = CVMAT_WITH_CHECK(value_ptr[i]);
|
|
cv::Mat mat(val);
|
|
mat_vector.push_back(mat);
|
|
}
|
|
ALGORITHM(self)->setMatVector(StringValueCStr(parameter), mat_vector);
|
|
}
|
|
catch (cv::Exception& e) {
|
|
raise_cverror(e);
|
|
}
|
|
|
|
return Qnil;
|
|
}
|
|
|
|
VALUE
|
|
rb_set_algorithm(VALUE self, VALUE parameter, VALUE value)
|
|
{
|
|
Check_Type(T_STRING, parameter);
|
|
try {
|
|
ALGORITHM(self)->setAlgorithm(StringValueCStr(parameter), ALGORITHM(value));
|
|
}
|
|
catch (cv::Exception& e) {
|
|
raise_cverror(e);
|
|
}
|
|
|
|
return Qnil;
|
|
}
|
|
|
|
|
|
VALUE
|
|
rb_get_int(VALUE self, VALUE parameter)
|
|
{
|
|
Check_Type(T_STRING, parameter);
|
|
int value = 0;
|
|
try {
|
|
value = ALGORITHM(self)->getInt(StringValueCStr(parameter));
|
|
}
|
|
catch (cv::Exception& e) {
|
|
raise_cverror(e);
|
|
}
|
|
|
|
return INT2NUM(value);
|
|
}
|
|
|
|
VALUE
|
|
rb_get_double(VALUE self, VALUE parameter)
|
|
{
|
|
Check_Type(T_STRING, parameter);
|
|
double value = 0.0;
|
|
try {
|
|
value = ALGORITHM(self)->getDouble(StringValueCStr(parameter));
|
|
}
|
|
catch (cv::Exception& e) {
|
|
raise_cverror(e);
|
|
}
|
|
|
|
return NUM2DBL(value);
|
|
}
|
|
|
|
VALUE
|
|
rb_get_bool(VALUE self, VALUE parameter)
|
|
{
|
|
Check_Type(T_STRING, parameter);
|
|
bool value = false;
|
|
try {
|
|
value = ALGORITHM(self)->getBool(StringValueCStr(parameter));
|
|
}
|
|
catch (cv::Exception& e) {
|
|
raise_cverror(e);
|
|
}
|
|
|
|
return value ? Qtrue : Qfalse;
|
|
}
|
|
|
|
VALUE
|
|
rb_get_string(VALUE self, VALUE parameter)
|
|
{
|
|
Check_Type(T_STRING, parameter);
|
|
std::string value = "";
|
|
try {
|
|
value = ALGORITHM(self)->getString(StringValueCStr(parameter));
|
|
}
|
|
catch (cv::Exception& e) {
|
|
raise_cverror(e);
|
|
}
|
|
|
|
return rb_str_new_cstr(value.c_str());
|
|
}
|
|
|
|
VALUE
|
|
rb_get_mat(VALUE self, VALUE parameter)
|
|
{
|
|
Check_Type(parameter, T_STRING);
|
|
VALUE mat = Qnil;
|
|
try {
|
|
cv::Mat value = ALGORITHM(self)->getMat(StringValueCStr(parameter));
|
|
cv::Size size = value.size();
|
|
mat = cCvMat::new_object(size.height, size.width, value.type());
|
|
cv::Mat dst(CVMAT(mat));
|
|
value.copyTo(dst);
|
|
}
|
|
catch (cv::Exception& e) {
|
|
raise_cverror(e);
|
|
}
|
|
return mat;
|
|
}
|
|
|
|
VALUE
|
|
rb_get_matvector(VALUE self, VALUE parameter)
|
|
{
|
|
Check_Type(T_STRING, parameter);
|
|
VALUE array = Qnil;
|
|
try {
|
|
std::vector<cv::Mat> value = ALGORITHM(self)->getMatVector(StringValueCStr(parameter));
|
|
int len = value.size();
|
|
array = rb_ary_new2(len);
|
|
for (int i = 0; i < len; i++) {
|
|
cv::Mat m = value[i];
|
|
cv::Size size = m.size();
|
|
VALUE mat = cCvMat::new_object(size.height, size.width, m.type());
|
|
cv::Mat dst(CVMAT(mat));
|
|
m.copyTo(dst);
|
|
rb_ary_store(array, i, mat);
|
|
}
|
|
}
|
|
catch (cv::Exception& e) {
|
|
raise_cverror(e);
|
|
}
|
|
return array;
|
|
}
|
|
|
|
VALUE
|
|
rb_name(VALUE self)
|
|
{
|
|
VALUE name = Qnil;
|
|
try {
|
|
name = rb_str_new_cstr(ALGORITHM(self)->name().c_str());
|
|
}
|
|
catch (cv::Exception& e) {
|
|
raise_cverror(e);
|
|
}
|
|
return name;
|
|
}
|
|
|
|
void
|
|
define_ruby_class()
|
|
{
|
|
if (rb_klass)
|
|
return;
|
|
/*
|
|
* opencv = rb_define_module("OpenCV");
|
|
*
|
|
* note: this comment is used by rdoc.
|
|
*/
|
|
VALUE opencv = rb_module_opencv();
|
|
rb_klass = rb_define_class_under(opencv, "Algorithm", rb_cObject);
|
|
rb_define_method(rb_klass, "set_int", RUBY_METHOD_FUNC(rb_set_int), 2);
|
|
rb_define_method(rb_klass, "set_double", RUBY_METHOD_FUNC(rb_set_double), 2);
|
|
rb_define_method(rb_klass, "set_bool", RUBY_METHOD_FUNC(rb_set_bool), 2);
|
|
rb_define_method(rb_klass, "set_string", RUBY_METHOD_FUNC(rb_set_string), 2);
|
|
rb_define_method(rb_klass, "set_mat", RUBY_METHOD_FUNC(rb_set_mat), 2);
|
|
rb_define_method(rb_klass, "set_matvector", RUBY_METHOD_FUNC(rb_set_matvector), 2);
|
|
rb_define_method(rb_klass, "set_algorithm", RUBY_METHOD_FUNC(rb_set_algorithm), 2);
|
|
|
|
rb_define_method(rb_klass, "get_int", RUBY_METHOD_FUNC(rb_get_int), 1);
|
|
rb_define_method(rb_klass, "get_double", RUBY_METHOD_FUNC(rb_get_double), 1);
|
|
rb_define_method(rb_klass, "get_bool", RUBY_METHOD_FUNC(rb_get_bool), 1);
|
|
rb_define_method(rb_klass, "get_string", RUBY_METHOD_FUNC(rb_get_string), 1);
|
|
rb_define_method(rb_klass, "get_mat", RUBY_METHOD_FUNC(rb_get_mat), 1);
|
|
rb_define_method(rb_klass, "get_matvector", RUBY_METHOD_FUNC(rb_get_matvector), 1);
|
|
|
|
rb_define_method(rb_klass, "name", RUBY_METHOD_FUNC(rb_name), 0);
|
|
}
|
|
|
|
__NAMESPACE_END_ALGORITM
|
|
__NAMESPACE_END_OPENCV
|
|
|