gpt4 book ai didi

java - 无法在opencv android(Java)中应用掩码

转载 作者:行者123 更新时间:2023-12-02 13:37:18 25 4
gpt4 key购买 nike

我正在尝试在圆或点上应用蒙版。我在嘴唇上方画圈以涂抹 mustache 。但我无法用 mustache 的图像来代替它。我没有使用原生。请帮助我。

最佳答案

这是我的图像屏蔽的完整代码,请引用。这里可以使用相机作为黄色、绿色和棕色的遮蔽框。

public class MainActivity extends AppCompatActivity {

private static final String TAG = "MainActivity";
protected CameraBridgeViewBase cameraView;
protected TextView tvDistance;
private Mat mRgba;
private Mat mHSV;

private Mat red;
private Mat blue;
private Mat yellow;
private Mat green;
private Mat brown;
private Mat mask;

private MatOfPoint matOfPoint;
private Mat pts;
private Handler handler;

int height;
int width;

int camera_height;
int camera_width;

ArrayList<Float> averageList;
static int AVERAGE_FACTOR = 3;

private MenuItem mItemPreviewFeatures;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN);
getWindow().addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
setContentView(R.layout.activity_main);
initView();

averageList = new ArrayList<>();

DisplayMetrics displaymetrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(displaymetrics);
height = displaymetrics.heightPixels;
width = displaymetrics.widthPixels;

handler = new Handler(Looper.getMainLooper());

cameraView.post(new Runnable() {
@Override
public void run() {
camera_height = cameraView.getHeight();
camera_width = cameraView.getWidth();
}
});

cameraView.setVisibility(SurfaceView.VISIBLE);
cameraView.setCvCameraViewListener(new CameraBridgeViewBase.CvCameraViewListener2() {
@Override
public void onCameraViewStarted(int width, int height) {
mRgba = new Mat(height, width, CvType.CV_8UC4);
mHSV = new Mat(height, width, CvType.CV_8UC4);
mask = new Mat(height, width, CvType.CV_8UC4);

pts = new Mat(height, width, CvType.CV_8UC1);
yellow = new Mat(height, width, CvType.CV_8UC1);
green = new Mat(height, width, CvType.CV_8UC1);
brown = new Mat(height, width, CvType.CV_8UC1);
blue = new Mat(height, width, CvType.CV_8UC1);
red = new Mat(height, width, CvType.CV_8UC1);
}

@Override
public void onCameraViewStopped() {
mRgba.release();
mHSV.release();
mask.release();
pts.release();

blue.release();
yellow.release();
green.release();
brown.release();
red.release();
}

@Override
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
mRgba = inputFrame.rgba();

Imgproc.cvtColor(mRgba, mHSV, Imgproc.COLOR_BGR2HSV, 4);

//red
//Core.inRange(mHSV, new Scalar(234, 240, 199), new Scalar(234, 240, 104), red);
//blue
//Core.inRange(mHSV, new Scalar(110, 50, 50), new Scalar(130, 255, 255), blue);
//Yellow
Core.inRange(mHSV, new Scalar(25, 80, 80), new Scalar(36, 255, 255), yellow);
//Green
Core.inRange(mHSV, new Scalar(37, 80, 80), new Scalar(70, 255, 255), green);
//Brown
Core.inRange(mHSV, new Scalar(10, 80, 80), new Scalar(30, 200, 200), brown);

// logical OR mask
//Core.bitwise_or(red, blue, blue);
//Core.bitwise_or(blue, yellow, yellow);
Core.bitwise_or(yellow, green, green);
Core.bitwise_or(green, brown, mask);

//Imgproc.dilate(mask, mask, new Mat());

// Find non zero pixels
pts = Mat.zeros(mask.size(), mask.type());
Core.findNonZero(mask, pts);

// Compute bounding box
matOfPoint = new MatOfPoint(pts);

try {
if (matOfPoint.cols() > 0 && matOfPoint.rows() > 0) {
final Rect box = Imgproc.boundingRect(matOfPoint);
//Log.d(TAG, "Height : " + box.height + " :: Width : " + box.width);

handler.post(new Runnable() {
@Override
public void run() {

float focalLength = Util.getFocalLength(box.width, 1, 1);
float distance = Util.getDistance_2(focalLength / 3, camera_height, box.height);

if (averageList.size() > AVERAGE_FACTOR) {
float d = 0.0f;
for (int i = 0; i < AVERAGE_FACTOR; i++) {
d += averageList.get(i);
}
tvDistance.setText(String.valueOf(String.format(Locale.ENGLISH, "%.2f", (Math.abs(d / AVERAGE_FACTOR) / 304.8)) + " ft"));
averageList.clear();
} else {
averageList.add(distance);
}
}
});

//Core.rectangle(mask, box.tl(), box.br(), new Scalar(255, 0, 0), 5);
}

Core.rectangle(mRgba, new Point(350, 350), new Point(camera_width - 350, camera_height - 350), new Scalar(255, 0, 0), 2);

} catch (Exception e) {
e.printStackTrace();
}

return mRgba;
}
});
}

private void initView() {
cameraView = (JavaCameraView) findViewById(R.id.cameraView);
tvDistance = (TextView) findViewById(R.id.tvDistance);
}

private BaseLoaderCallback mLoaderCallback = new BaseLoaderCallback(this) {
@Override
public void onManagerConnected(int status) {
switch (status) {
case LoaderCallbackInterface.SUCCESS:
cameraView.enableView();
break;
default:
super.onManagerConnected(status);
break;
}
}
};

@Override
public boolean onCreateOptionsMenu(Menu menu) {
Log.i(TAG, "called onCreateOptionsMenu");
mItemPreviewFeatures = menu.add("Tracking");
return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
if (item == mItemPreviewFeatures) {
Toast.makeText(this, "Selected", Toast.LENGTH_SHORT).show();
}
return true;
}

@Override
protected void onPause() {
super.onPause();
if (cameraView != null)
cameraView.disableView();
}

@Override
protected void onResume() {
super.onResume();
if (OpenCVLoader.initDebug()) {
Log.d(TAG, "OpenCV loaded");
mLoaderCallback.onManagerConnected(LoaderCallbackInterface.SUCCESS);
} else {
Log.d(TAG, "OpenCV not loaded");
OpenCVLoader.initAsync(OpenCVLoader.OPENCV_VERSION_2_4_9, this, mLoaderCallback);
}
}

@Override
protected void onDestroy() {
super.onDestroy();
if (cameraView != null)
cameraView.disableView();
}
}

关于java - 无法在opencv android(Java)中应用掩码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42918495/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com