- 'c_string' support added to Java API
- improved CV_IN_OUT/CV_OUT handling for generated Python/Java wrappers
This commit is contained in:
parent
9aa5e5b000
commit
fbfddbd3ea
@ -2031,7 +2031,7 @@ CV_EXPORTS_W void merge(const vector<Mat>& mv, OutputArray dst);
|
|||||||
//! copies each plane of a multi-channel array to a dedicated array
|
//! copies each plane of a multi-channel array to a dedicated array
|
||||||
CV_EXPORTS void split(const Mat& src, Mat* mvbegin);
|
CV_EXPORTS void split(const Mat& src, Mat* mvbegin);
|
||||||
//! copies each plane of a multi-channel array to a dedicated array
|
//! copies each plane of a multi-channel array to a dedicated array
|
||||||
CV_EXPORTS_W void split(const Mat& m, vector<Mat>& mv);
|
CV_EXPORTS_W void split(const Mat& m, CV_OUT vector<Mat>& mv);
|
||||||
|
|
||||||
//! copies selected channels from the input arrays to the selected channels of the output arrays
|
//! copies selected channels from the input arrays to the selected channels of the output arrays
|
||||||
CV_EXPORTS void mixChannels(const Mat* src, size_t nsrcs, Mat* dst, size_t ndsts,
|
CV_EXPORTS void mixChannels(const Mat* src, size_t nsrcs, Mat* dst, size_t ndsts,
|
||||||
|
@ -66,6 +66,10 @@ type_dict = {
|
|||||||
"jni_type" : "jstring", "jni_name" : "n_%(n)s",
|
"jni_type" : "jstring", "jni_name" : "n_%(n)s",
|
||||||
"jni_var" : 'const char* utf_%(n)s = env->GetStringUTFChars(%(n)s, 0); String n_%(n)s( utf_%(n)s ? utf_%(n)s : "" ); env->ReleaseStringUTFChars(%(n)s, utf_%(n)s)',
|
"jni_var" : 'const char* utf_%(n)s = env->GetStringUTFChars(%(n)s, 0); String n_%(n)s( utf_%(n)s ? utf_%(n)s : "" ); env->ReleaseStringUTFChars(%(n)s, utf_%(n)s)',
|
||||||
"suffix" : "Ljava_lang_String_2"},
|
"suffix" : "Ljava_lang_String_2"},
|
||||||
|
"c_string": { "j_type" : "java.lang.String", "jn_type" : "java.lang.String",
|
||||||
|
"jni_type" : "jstring", "jni_name" : "n_%(n)s.c_str()",
|
||||||
|
"jni_var" : 'const char* utf_%(n)s = env->GetStringUTFChars(%(n)s, 0); std::string n_%(n)s( utf_%(n)s ? utf_%(n)s : "" ); env->ReleaseStringUTFChars(%(n)s, utf_%(n)s)',
|
||||||
|
"suffix" : "Ljava_lang_String_2"},
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -98,10 +102,11 @@ class ArgInfo(object):
|
|||||||
self.ctype = arg_tuple[0]
|
self.ctype = arg_tuple[0]
|
||||||
self.name = arg_tuple[1]
|
self.name = arg_tuple[1]
|
||||||
self.defval = arg_tuple[2]
|
self.defval = arg_tuple[2]
|
||||||
self.out = "/O" in arg_tuple[3] or "/IO" in arg_tuple[3]
|
self.out = ""
|
||||||
|
if "/O" in arg_tuple[3]:
|
||||||
## def isbig(self):
|
self.out = "O"
|
||||||
## return self.ctype == "Mat" or self.ctype == "vector_Mat"
|
if "/IO" in arg_tuple[3]:
|
||||||
|
self.out = "IO"
|
||||||
|
|
||||||
|
|
||||||
class FuncInfo(object):
|
class FuncInfo(object):
|
||||||
@ -407,14 +412,14 @@ class JavaWrapperGenerator(object):
|
|||||||
self.skipped_func_list.append(c_decl + "\n" + msg)
|
self.skipped_func_list.append(c_decl + "\n" + msg)
|
||||||
self.java_code.write( indent + msg )
|
self.java_code.write( indent + msg )
|
||||||
#self.cpp_code.write( msg )
|
#self.cpp_code.write( msg )
|
||||||
print "SKIP:", c_decl, "\n\tdue to ARG type", a.ctype
|
print "SKIP:", c_decl, "\n\tdue to ARG type", a.ctype, a.out
|
||||||
return
|
return
|
||||||
if a.ctype != "Mat" and "jn_args" in type_dict[a.ctype] and a.out: # complex out args not yet supported
|
if a.ctype != "Mat" and "jn_args" in type_dict[a.ctype] and a.out: # complex out args not yet supported
|
||||||
msg = "// Unsupported type '%s&', skipping the function\n\n" % a.ctype
|
msg = "// Unsupported type '%s&', skipping the function\n\n" % a.ctype
|
||||||
self.skipped_func_list.append(c_decl + "\n" + msg)
|
self.skipped_func_list.append(c_decl + "\n" + msg)
|
||||||
self.java_code.write( indent + msg )
|
self.java_code.write( indent + msg )
|
||||||
#self.cpp_code.write( msg )
|
#self.cpp_code.write( msg )
|
||||||
print "SKIP:", c_decl, "\n\tdue to OUT ARG of type", a.ctype
|
print "SKIP:", c_decl, "\n\tdue to OUT ARG of type", a.ctype, a.out
|
||||||
return
|
return
|
||||||
|
|
||||||
self.ported_func_counter += 1
|
self.ported_func_counter += 1
|
||||||
|
@ -286,8 +286,8 @@ namespace cv
|
|||||||
|
|
||||||
///////////////////////////// Object Detection ////////////////////////////
|
///////////////////////////// Object Detection ////////////////////////////
|
||||||
|
|
||||||
CV_EXPORTS_W void groupRectangles(vector<Rect>& rectList, int groupThreshold, double eps=0.2);
|
CV_EXPORTS_W void groupRectangles(CV_IN_OUT vector<Rect>& rectList, int groupThreshold, double eps=0.2);
|
||||||
CV_EXPORTS_W void groupRectangles(vector<Rect>& rectList, CV_OUT vector<int>& weights, int groupThreshold, double eps=0.2);
|
CV_EXPORTS_W void groupRectangles(CV_IN_OUT vector<Rect>& rectList, CV_OUT vector<int>& weights, int groupThreshold, double eps=0.2);
|
||||||
CV_EXPORTS void groupRectangles(vector<Rect>& rectList, vector<int>& rejectLevels,
|
CV_EXPORTS void groupRectangles(vector<Rect>& rectList, vector<int>& rejectLevels,
|
||||||
vector<double>& levelWeights, int groupThreshold, double eps=0.2);
|
vector<double>& levelWeights, int groupThreshold, double eps=0.2);
|
||||||
CV_EXPORTS void groupRectangles_meanshift(vector<Rect>& rectList, vector<double>& foundWeights, vector<double>& foundScales,
|
CV_EXPORTS void groupRectangles_meanshift(vector<Rect>& rectList, vector<double>& foundWeights, vector<double>& foundScales,
|
||||||
|
@ -454,13 +454,19 @@ class CppHeaderParser(object):
|
|||||||
a = a[:eqpos].strip()
|
a = a[:eqpos].strip()
|
||||||
arg_type, arg_name, modlist, argno = self.parse_arg(a, argno)
|
arg_type, arg_name, modlist, argno = self.parse_arg(a, argno)
|
||||||
if self.wrap_mode:
|
if self.wrap_mode:
|
||||||
if arg_type == "InputArray" or arg_type == "InputOutputArray":
|
if arg_type == "InputArray":
|
||||||
arg_type = "Mat"
|
arg_type = "Mat"
|
||||||
|
elif arg_type == "InputOutputArray":
|
||||||
|
arg_type = "Mat"
|
||||||
|
modlist.append("/IO")
|
||||||
elif arg_type == "OutputArray":
|
elif arg_type == "OutputArray":
|
||||||
arg_type = "Mat"
|
arg_type = "Mat"
|
||||||
modlist.append("/O")
|
modlist.append("/O")
|
||||||
elif arg_type == "InputArrayOfArrays" or arg_type == "InputOutputArrayOfArrays":
|
elif arg_type == "InputArrayOfArrays":
|
||||||
arg_type = "vector_Mat"
|
arg_type = "vector_Mat"
|
||||||
|
elif arg_type == "InputOutputArrayOfArrays":
|
||||||
|
arg_type = "vector_Mat"
|
||||||
|
modlist.append("/IO")
|
||||||
elif arg_type == "OutputArrayOfArrays":
|
elif arg_type == "OutputArrayOfArrays":
|
||||||
arg_type = "vector_Mat"
|
arg_type = "vector_Mat"
|
||||||
modlist.append("/O")
|
modlist.append("/O")
|
||||||
|
Loading…
x
Reference in New Issue
Block a user