JAVA凸变形画线,OpenCV绘制凸折线

本篇文章帮大家学习OpenCV绘制凸折线,包含了OpenCV绘制凸折线使用方法、操作技巧、实例演示和注意事项,有一定的学习价值,大家可以用来参考。

可以使用imgproc类的fillconvexPoly()方法在图像上绘制凸多段线。 以下是此方法的语法。

fillConvexPoly(Mat img, MatOfPoint points, Scalar color)

该方法接受以下参数 -

mat - 表示要在其上绘制矩形的图像的Mat对象。

points - 一个MatOfPoint对象,表示要在其间绘制凸多段线的点。

color - 表示矩形颜色的标量对象(BGR)。

MatOfPoint类的构造函数接受Point类的对象。

MatOfPoint(Point a)

示例

以下程序演示如何在图像上绘制凸多段线并使用javaFX窗口显示它。

package jikedaquan.com;

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;

import java.io.InputStream;

import javax.imageio.ImageIO;

import javafx.application.Application;

import javafx.embed.swing.SwingFXUtils;

import javafx.scene.Group;

import javafx.scene.Scene;

import javafx.scene.image.ImageView;

import javafx.scene.image.WritableImage;

import javafx.stage.Stage;

import org.opencv.core.Core;

import org.opencv.core.Mat;

import org.opencv.core.MatOfByte;

import org.opencv.core.MatOfPoint;

import org.opencv.core.Point;

import org.opencv.core.Scalar;

import org.opencv.imgcodecs.Imgcodecs;

import org.opencv.imgproc.Imgproc;

public class FillConvexPoly extends Application {

Mat matrix = null;

@Override

public void start(Stage stage) throws Exception {

// Capturing the snapshot from the camera

FillConvexPoly obj = new FillConvexPoly();

WritableImage writableImage = obj.LoadImage();

// Setting the image view

ImageView imageView = new ImageView(writableImage);

// setting the fit height and width of the image view

imageView.setFitHeight(600);

imageView.setFitWidth(600);

//Setting the preserve ratio of the image view

imageView.setPreserveRatio(true);

// Creating a Group object

Group root = new Group(imageView);

// Creating a scene object

Scene scene = new Scene(root, 600, 400);

// Setting title to the Stage

stage.setTitle("Drawing convex Polylines (fill) on the image");

// Adding scene to the stage

stage.setScene(scene);

// Displaying the contents of the stage

stage.show();

}

public WritableImage LoadImage() throws Exception {

// Loading the OpenCV core library

System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

// Reading the Image from the file and storing it in to a Matrix object

String file ="F:/worksp/opencv/images/sample2.jpg";

Mat matrix = Imgcodecs.imread(file);

MatOfPoint matOfPoint = new MatOfPoint (

new Point(75, 100), new Point(350, 100),

new Point(75, 150), new Point(350, 150),

new Point(75, 200), new Point(350, 200),

new Point(75, 250), new Point(350, 250)

);

// Drawing polylines

Imgproc.fillConvexPoly (

matrix, // Matrix obj of the image

matOfPoint, // java.util.List pts

new Scalar(0, 0, 255) // Scalar object for color

);

// Encoding the image

MatOfByte matOfByte = new MatOfByte();

Imgcodecs.imencode(".jpg", matrix, matOfByte);

// Storing the encoded Mat in a byte array

byte[] byteArray = matOfByte.toArray();

// Displaying the image

InputStream in = new ByteArrayInputStream(byteArray);

BufferedImage bufImage = ImageIO.read(in);

this.matrix = matrix;

// Creating the Writable Image

WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);

return writableImage;

}

public static void main(String args[]) {

launch(args);

}

}

在执行上述程序时,您将得到以下输出 -

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值