使用 Android OpenCV 进行图像透视变换

发布于 2025-01-07 04:06:33 字数 3134 浏览 0 评论 0原文

我正在制作Android应用程序,它可以使透视变换图像。 我想做同样的事情,如下面的代码。

我试过了,但看不懂 C 代码。请告诉我!

谢谢,

Shoichi

示例代码(我想做)

#include <cv.h>
#include <highgui.h>

int
main (int argc, char **argv)
{
  IplImage *src_img = 0, *dst_img = 0;
  CvMat *map_matrix;
  CvPoint2D32f src_pnt[4], dst_pnt[4];

  if (argc >= 2)
    src_img = cvLoadImage (argv[1], CV_LOAD_IMAGE_ANYDEPTH | CV_LOAD_IMAGE_ANYCOLOR);
  if (src_img == 0)
    return -1;
  dst_img = cvCloneImage (src_img);

  src_pnt[0] = cvPoint2D32f (150.0, 150.0);
  src_pnt[1] = cvPoint2D32f (150.0, 300.0);
  src_pnt[2] = cvPoint2D32f (350.0, 300.0);
  src_pnt[3] = cvPoint2D32f (350.0, 150.0);

  dst_pnt[0] = cvPoint2D32f (200.0, 200.0);
  dst_pnt[1] = cvPoint2D32f (150.0, 300.0);
  dst_pnt[2] = cvPoint2D32f (350.0, 300.0);
  dst_pnt[3] = cvPoint2D32f (300.0, 200.0);

  map_matrix = cvCreateMat (3, 3, CV_32FC1);
  cvGetPerspectiveTransform (src_pnt, dst_pnt, map_matrix);

  cvWarpPerspective (src_img, dst_img, map_matrix, CV_INTER_LINEAR +     CV_WARP_FILL_OUTLIERS, cvScalarAll (100));


  cvNamedWindow ("src", CV_WINDOW_AUTOSIZE);
  cvNamedWindow ("dst", CV_WINDOW_AUTOSIZE);
  cvShowImage ("src", src_img);
  cvShowImage ("dst", dst_img);
  cvWaitKey (0);

  cvDestroyWindow ("src");
  cvDestroyWindow ("dst");
  cvReleaseImage (&src_img);
  cvReleaseImage (&dst_img);
  cvReleaseMat (&map_matrix);

  return 1;
}

我的代码

@Override
public void onCreate(Bundle savedInstanceState) {
    Log.i(TAG, "onCreate");
    super.onCreate(savedInstanceState);
    requestWindowFeature(Window.FEATURE_NO_TITLE);
    setContentView(R.layout.main);
    Resources r = getResources();
    Bitmap inputBitmap = BitmapFactory.decodeResource(r, R.drawable.icon);

    Mat inputMat = Utils.bitmapToMat(inputBitmap);
    Mat outputMat = inputMat.clone();

    List<Point> src_pnt = new ArrayList<Point>();
    Point p0 = new Point(75.0, 75.0);
    src_pnt.add(p0);
    Point p1 = new Point(75.0, 100.0);
    src_pnt.add(p1);
    Point p2 = new Point(100.0, 100.0);
    src_pnt.add(p2);
    Point p3 = new Point(100.0, 75.0);
    src_pnt.add(p3);
    Mat startM = Converters.vector_Point2f_to_Mat(src_pnt);

    List<Point> dst_pnt = new ArrayList<Point>();
    Point p4 = new Point(75.0, 75.0);
    dst_pnt.add(p4);
    Point p5 = new Point(75.0, 100.0);
    dst_pnt.add(p5);
    Point p6 = new Point(100.0, 100.0);
    dst_pnt.add(p6);
    Point p7 = new Point(100.0, 75.0);
    dst_pnt.add(p7);
    Mat endM = Converters.vector_Point2f_to_Mat(dst_pnt);

    Mat M = new Mat(3, 3, CvType.CV_32F);
    Core.perspectiveTransform(startM, endM, M);

    Size size = new Size(200.0, 200.0);
    Scalar scalar = new Scalar(50.0);

    Imgproc.warpPerspective(inputMat, outputMat, M, size, Imgproc.INTER_LINEAR + Imgproc.CV_WARP_FILL_OUTLIERS, Imgproc.BORDER_DEFAULT, scalar);

    Bitmap outputBitmap = inputBitmap;
    Utils.matToBitmap(outputMat, outputBitmap);
    ImageView imageView1 = (ImageView) findViewById(R.id.imageView1);
    imageView1.setImageBitmap(outputBitmap);

}

I am making Android App which can make Perspective Transform Image.
I want to do same thing like below code.

I tried but I cant read C code. Please advise me!

Thanks,

Shoichi

Sample Code(I want to do)

#include <cv.h>
#include <highgui.h>

int
main (int argc, char **argv)
{
  IplImage *src_img = 0, *dst_img = 0;
  CvMat *map_matrix;
  CvPoint2D32f src_pnt[4], dst_pnt[4];

  if (argc >= 2)
    src_img = cvLoadImage (argv[1], CV_LOAD_IMAGE_ANYDEPTH | CV_LOAD_IMAGE_ANYCOLOR);
  if (src_img == 0)
    return -1;
  dst_img = cvCloneImage (src_img);

  src_pnt[0] = cvPoint2D32f (150.0, 150.0);
  src_pnt[1] = cvPoint2D32f (150.0, 300.0);
  src_pnt[2] = cvPoint2D32f (350.0, 300.0);
  src_pnt[3] = cvPoint2D32f (350.0, 150.0);

  dst_pnt[0] = cvPoint2D32f (200.0, 200.0);
  dst_pnt[1] = cvPoint2D32f (150.0, 300.0);
  dst_pnt[2] = cvPoint2D32f (350.0, 300.0);
  dst_pnt[3] = cvPoint2D32f (300.0, 200.0);

  map_matrix = cvCreateMat (3, 3, CV_32FC1);
  cvGetPerspectiveTransform (src_pnt, dst_pnt, map_matrix);

  cvWarpPerspective (src_img, dst_img, map_matrix, CV_INTER_LINEAR +     CV_WARP_FILL_OUTLIERS, cvScalarAll (100));


  cvNamedWindow ("src", CV_WINDOW_AUTOSIZE);
  cvNamedWindow ("dst", CV_WINDOW_AUTOSIZE);
  cvShowImage ("src", src_img);
  cvShowImage ("dst", dst_img);
  cvWaitKey (0);

  cvDestroyWindow ("src");
  cvDestroyWindow ("dst");
  cvReleaseImage (&src_img);
  cvReleaseImage (&dst_img);
  cvReleaseMat (&map_matrix);

  return 1;
}

My Code

@Override
public void onCreate(Bundle savedInstanceState) {
    Log.i(TAG, "onCreate");
    super.onCreate(savedInstanceState);
    requestWindowFeature(Window.FEATURE_NO_TITLE);
    setContentView(R.layout.main);
    Resources r = getResources();
    Bitmap inputBitmap = BitmapFactory.decodeResource(r, R.drawable.icon);

    Mat inputMat = Utils.bitmapToMat(inputBitmap);
    Mat outputMat = inputMat.clone();

    List<Point> src_pnt = new ArrayList<Point>();
    Point p0 = new Point(75.0, 75.0);
    src_pnt.add(p0);
    Point p1 = new Point(75.0, 100.0);
    src_pnt.add(p1);
    Point p2 = new Point(100.0, 100.0);
    src_pnt.add(p2);
    Point p3 = new Point(100.0, 75.0);
    src_pnt.add(p3);
    Mat startM = Converters.vector_Point2f_to_Mat(src_pnt);

    List<Point> dst_pnt = new ArrayList<Point>();
    Point p4 = new Point(75.0, 75.0);
    dst_pnt.add(p4);
    Point p5 = new Point(75.0, 100.0);
    dst_pnt.add(p5);
    Point p6 = new Point(100.0, 100.0);
    dst_pnt.add(p6);
    Point p7 = new Point(100.0, 75.0);
    dst_pnt.add(p7);
    Mat endM = Converters.vector_Point2f_to_Mat(dst_pnt);

    Mat M = new Mat(3, 3, CvType.CV_32F);
    Core.perspectiveTransform(startM, endM, M);

    Size size = new Size(200.0, 200.0);
    Scalar scalar = new Scalar(50.0);

    Imgproc.warpPerspective(inputMat, outputMat, M, size, Imgproc.INTER_LINEAR + Imgproc.CV_WARP_FILL_OUTLIERS, Imgproc.BORDER_DEFAULT, scalar);

    Bitmap outputBitmap = inputBitmap;
    Utils.matToBitmap(outputMat, outputBitmap);
    ImageView imageView1 = (ImageView) findViewById(R.id.imageView1);
    imageView1.setImageBitmap(outputBitmap);

}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

临走之时 2025-01-14 04:06:34

您的 dst_pnt 点与 src_pnt 相同,因此变换矩阵将是恒等的,根本不会改变图像。使用其他一些点。

其次,我认为warPerspective(大小)的第四个参数应该是outputMap的大小,所以如果你想要一个200x200的图像,而不是

Mat outputMat = inputMat.clone();

使用

Mat outputMat = new Mat(200, 200);

Your dst_pnt points are same as src_pnt, so transformation matrix will be identity and will not change image at all. Use some other points.

Secondly, I think 4th argument to warPerspective (size) should be size of outputMap, so if you want a 200x200 image,instead of

Mat outputMat = inputMat.clone();

Use

Mat outputMat = new Mat(200, 200);
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文