mirror of https://github.com/opencv/opencv.git
Open Source Computer Vision Library
https://opencv.org/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
35 lines
1.1 KiB
35 lines
1.1 KiB
#include <jni.h> |
|
#include <opencv2/core/core.hpp> |
|
#include <opencv2/imgproc/imgproc.hpp> |
|
#include <opencv2/features2d/features2d.hpp> |
|
#include <vector> |
|
|
|
using namespace std; |
|
using namespace cv; |
|
|
|
extern "C" { |
|
JNIEXPORT void JNICALL Java_org_opencv_samples_tutorial3_Sample3View_FindFeatures(JNIEnv* env, jobject thiz, jint width, jint height, jbyteArray yuv, jintArray bgra) |
|
{ |
|
jbyte* _yuv = env->GetByteArrayElements(yuv, 0); |
|
jint* _bgra = env->GetIntArrayElements(bgra, 0); |
|
|
|
Mat myuv(height + height/2, width, CV_8UC1, (unsigned char *)_yuv); |
|
Mat mbgra(height, width, CV_8UC4, (unsigned char *)_bgra); |
|
Mat mgray(height, width, CV_8UC1, (unsigned char *)_yuv); |
|
|
|
//Please make attention about BGRA byte order |
|
//ARGB stored in java as int array becomes BGRA at native level |
|
cvtColor(myuv, mbgra, CV_YUV420sp2BGR, 4); |
|
|
|
vector<KeyPoint> v; |
|
|
|
FastFeatureDetector detector(50); |
|
detector.detect(mgray, v); |
|
for( size_t i = 0; i < v.size(); i++ ) |
|
circle(mbgra, Point(v[i].pt.x, v[i].pt.y), 10, Scalar(0,0,255,255)); |
|
|
|
env->ReleaseIntArrayElements(bgra, _bgra, 0); |
|
env->ReleaseByteArrayElements(yuv, _yuv, 0); |
|
} |
|
|
|
}
|
|
|