- '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
|
||||
CV_EXPORTS void split(const Mat& src, Mat* mvbegin);
|
||||
//! 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
|
||||
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_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"},
|
||||
"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.name = arg_tuple[1]
|
||||
self.defval = arg_tuple[2]
|
||||
self.out = "/O" in arg_tuple[3] or "/IO" in arg_tuple[3]
|
||||
|
||||
## def isbig(self):
|
||||
## return self.ctype == "Mat" or self.ctype == "vector_Mat"
|
||||
self.out = ""
|
||||
if "/O" in arg_tuple[3]:
|
||||
self.out = "O"
|
||||
if "/IO" in arg_tuple[3]:
|
||||
self.out = "IO"
|
||||
|
||||
|
||||
class FuncInfo(object):
|
||||
@ -407,14 +412,14 @@ class JavaWrapperGenerator(object):
|
||||
self.skipped_func_list.append(c_decl + "\n" + msg)
|
||||
self.java_code.write( indent + 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
|
||||
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
|
||||
self.skipped_func_list.append(c_decl + "\n" + msg)
|
||||
self.java_code.write( indent + 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
|
||||
|
||||
self.ported_func_counter += 1
|
||||
|
@ -286,8 +286,8 @@ namespace cv
|
||||
|
||||
///////////////////////////// Object Detection ////////////////////////////
|
||||
|
||||
CV_EXPORTS_W void groupRectangles(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, 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,
|
||||
vector<double>& levelWeights, int groupThreshold, double eps=0.2);
|
||||
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()
|
||||
arg_type, arg_name, modlist, argno = self.parse_arg(a, argno)
|
||||
if self.wrap_mode:
|
||||
if arg_type == "InputArray" or arg_type == "InputOutputArray":
|
||||
if arg_type == "InputArray":
|
||||
arg_type = "Mat"
|
||||
elif arg_type == "InputOutputArray":
|
||||
arg_type = "Mat"
|
||||
modlist.append("/IO")
|
||||
elif arg_type == "OutputArray":
|
||||
arg_type = "Mat"
|
||||
modlist.append("/O")
|
||||
elif arg_type == "InputArrayOfArrays" or arg_type == "InputOutputArrayOfArrays":
|
||||
elif arg_type == "InputArrayOfArrays":
|
||||
arg_type = "vector_Mat"
|
||||
elif arg_type == "InputOutputArrayOfArrays":
|
||||
arg_type = "vector_Mat"
|
||||
modlist.append("/IO")
|
||||
elif arg_type == "OutputArrayOfArrays":
|
||||
arg_type = "vector_Mat"
|
||||
modlist.append("/O")
|
||||
|
Loading…
x
Reference in New Issue
Block a user