diff --git a/pom.xml b/pom.xml
new file mode 100644
index 0000000..87e439a
--- /dev/null
+++ b/pom.xml
@@ -0,0 +1,119 @@
+
+
+ 4.0.0
+ com.example
+ TestOpenCV
+ 0.0.1-SNAPSHOT
+ jar
+
+ example-web
+ project for Spring Boot
+
+
+ UTF-8
+ UTF-8
+ 1.8
+ true
+ 2.3.7.RELEASE
+ Hoxton.SR8
+
+
+
+
+
+ central
+ Central Repository
+ default
+ https://maven.aliyun.com/repository/public
+
+
+
+
+
+ central
+ Central Repository
+ https://maven.aliyun.com/repository/public
+ default
+
+
+
+
+
+ com.opencv
+ opencv
+ 0.0.1
+ system
+ ${project.basedir}/src/main/resources/lib/opencv-460.jar
+
+
+
+
+
+
+ ${artifactId}-${version}
+
+ src/main/java
+
+ src/test/java
+
+
+ src/main/resources
+
+
+
+ src/main/java
+
+ **/*Mapper.xml
+
+
+
+
+ ${basedir}/src/main/resources/lib
+ BOOT-INF/lib/
+
+ *.jar
+
+
+
+
+ ${basedir}/src/main/resources/部署文档
+
+ *.bat
+ *.sh
+
+ ${basedir}/target/部署文档
+
+
+
+
+ org.springframework.boot
+ spring-boot-maven-plugin
+
+
+ org.apache.maven.plugins
+ maven-compiler-plugin
+
+
+ ${java.version}
+
+
+
+
+ org.apache.maven.plugins
+ maven-war-plugin
+
+
+
+ ${project.basedir}/src/main/resources/lib
+ WEB-INF/lib
+
+ *.jar
+
+
+
+
+
+
+
+
diff --git a/src/main/java/Test.java b/src/main/java/Test.java
new file mode 100644
index 0000000..b805eee
--- /dev/null
+++ b/src/main/java/Test.java
@@ -0,0 +1,115 @@
+import org.opencv.core.*;
+import org.opencv.highgui.HighGui;
+import org.opencv.imgcodecs.Imgcodecs;
+import org.opencv.imgproc.Imgproc;
+
+import java.io.File;
+import java.net.URL;
+import java.util.ArrayList;
+import java.util.List;
+
+
+public class Test {
+ static {
+ URL systemResource = ClassLoader.getSystemResource("lib/x64/opencv_java460.dll");
+ System.load(systemResource.getPath());
+// System.loadLibrary(Core.NATIVE_LIBRARY_NAME);
+ //注意程序运行的时候需要在VM option添加该行 指明opencv的dll文件所在路径
+ //-Djava.library.path=$PROJECT_DIR$\opencv\x64
+ }
+
+ public static void main(String[] args) {
+
+ /*
+ * IMREAD_UNCHANGED = -1 :不进行转化,比如保存为了16位的图片,读取出来仍然为16位。
+ * IMREAD_GRAYSCALE = 0 :进行转化为灰度图,比如保存为了16位的图片,读取出来为8位,类型为CV_8UC1。
+ * IMREAD_COLOR = 1 :进行转化为三通道图像。
+ * IMREAD_ANYDEPTH = 2 :如果图像深度为16位则读出为16位,32位则读出为32位,其余的转化为8位。
+ * IMREAD_ANYCOLOR = 4 :图像以任何可能的颜色格式读取
+ * IMREAD_LOAD_GDAL = 8 :使用GDAL驱动读取文件,GDAL(Geospatial Data Abstraction
+ * Library)是一个在X/MIT许可协议下的开源栅格空间数据转换库。它利用抽象数据模型来表达所支持的各种文件格式。
+ * 它还有一系列命令行工具来进行数据转换和处理。
+ */
+
+
+ File file = new File("D://1.png");
+ Mat src = Imgcodecs.imread(file.getAbsolutePath());
+ HighGui.imshow("源图片", src);
+ HighGui.waitKey();
+ // 放大图像
+// Mat resize = new Mat();
+// Imgproc.resize(src, resize, new Size(src.cols()*1.5,src.rows()*1.5));
+// HighGui.imshow("放大图片", resize);
+// HighGui.waitKey();
+
+ //图片灰度化 https://blog.csdn.net/ren365880/article/details/103869207
+ Mat gary = new Mat();
+ Imgproc.cvtColor(src, gary, Imgproc.COLOR_BGR2GRAY);
+ HighGui.imshow("灰度化图片", gary);
+ HighGui.waitKey();
+
+ //图像边缘处理 https://blog.csdn.net/ren365880/article/details/103938232
+ Mat edges = new Mat();
+ Imgproc.Canny(gary, edges, 200, 500, 3, false);
+ HighGui.imshow("边缘处理", edges);
+ HighGui.waitKey();
+
+ //发现轮廓
+ List list = new ArrayList();
+ Mat hierarchy = new Mat();
+
+ /*
+ * 查找二进制图像中的轮廓。
+ * 该函数使用CITE算法:Suzuki85从二进制图像检索轮廓。轮廓是用于形状分析以及对象检测和识别的有用工具。
+ * @param image Source,一个8位单通道图像。非零像素被视为1。零像素保持为0,因此图像被视为binary。您可以使用#compare,#inRange,
+ * #threshold,#adaptiveThreshold,#Canny等创建灰度或彩色以外的二进制图像。如果模式等于#RETR_CCOMP或#
+ * RETR_FLOODFILL,则输入也可以是32位的整数图像(CV_32SC1)。
+ * @param轮廓检测到的轮廓。每个轮廓都存储为点的向量。
+ * @param层次结构可选的输出向量 包含有关图像拓扑的信息。它具有与轮廓数量一样多的元素。对于每个第i个轮廓轮廓[i],元素等级[i] [0],等级[i] [1],等级[i]
+ * [2]和等级[i][3]均设置为0-在相同的层次级别上,基于下一个和上一个轮廓的轮廓的索引,分别是第一个子轮廓和父轮廓。如果对于轮廓i,没有下一个,上一个,父级或嵌套的轮廓
+ * ,则hierarchy [i]的相应元素将为负。
+ * @param模式轮廓检索模式,请参见#RetrievalModes
+ * RETR_EXTERNAL = 0, 只检测最外围轮廓,包含在外围轮廓内的内围轮廓被忽略;
+ * RETR_LIST = 1,检测所有的轮廓,包括内围、外围轮廓,但是检测到的轮廓不建立等级关系,彼此之间独立,没有等级关系,这就意味着这个检索模式下不存在父轮廓或内嵌轮廓
+ * RETR_CCOMP = 2,检测所有的轮廓,但所有轮廓只建立两个等级关系,外围为顶层,若外围内的内围轮廓还包含了其他的轮廓信息,则内围内的所有轮廓均归属于顶层;
+ * RETR_TREE = 3,检测所有轮廓,所有轮廓建立一个等级树结构。外层轮廓包含内层轮廓,内层轮廓还可以继续包含内嵌轮廓
+ * RETR_FLOODFILL = 4; 官方没定义 使用此参数需要把输入源转为CV_32SC1
+ * Mat dst = new Mat();
+ * edges.convertTo(dst,CvType.CV_32SC1);
+ * @param方法轮廓近似方法,请参阅#ContourApproximationModes轮廓是从图像ROI中提取的,然后应在整个图像上下文中进行分析。
+ * CHAIN_APPROX_NONE = 1,保存物体边界上所有连续的轮廓点到contours向量内;
+ * CHAIN_APPROX_SIMPLE = 2,仅保存轮廓的拐点信息,把所有轮廓拐点处的点保存入contours向量内,拐点与拐点之间直线段上的信息点不予保留;
+ * CHAIN_APPROX_TC89_L1 = 3,使用teh-Chinl chain 近似算法;
+ * CHAIN_APPROX_TC89_KCOS = 4; 使用teh-Chinl chain 近似算法。
+ */
+
+ Imgproc.findContours(edges, list, hierarchy, Imgproc.RETR_TREE, Imgproc.CHAIN_APPROX_NONE);
+
+
+ /*
+ * 绘制轮廓轮廓或填充轮廓。
+ * 如果({thickness}> 0),则该函数在图像中绘制轮廓轮廓;如果({thickness}<0),则该函数填充轮廓所包围的区域。
+ * @param图像目标图像。
+ * @param轮廓所有输入轮廓。每个轮廓都存储为点向量。
+ * @param outlineIdx指示要绘制的轮廓的参数。如果为负,则绘制所有轮廓。
+ * @param color轮廓的颜色。
+ * @param thickness绘制轮廓的线的粗细。如果为负(例如,thickness =#FILLED),则绘制轮廓内部。
+ * @param lineType线路连接。请参阅https://blog.csdn.net/ren365880/article/details/103952856
+ */
+ Imgproc.drawContours(src, list, -1, new Scalar(0, 255, 0), 1, Imgproc.LINE_AA);
+
+ HighGui.imshow("轮廓", src);
+ HighGui.waitKey();
+//
+// // 创建输出单通道图像
+// Mat grayImage = new Mat(src.rows(), src.cols(), CvType.CV_8SC1);
+// // 进行图像色彩空间转换
+// Imgproc.cvtColor(src, grayImage, Imgproc.COLOR_RGB2GRAY);
+//
+// HighGui.imshow("Processed Image", grayImage);
+// Imgcodecs.imwrite("D://2.jpg", grayImage);
+// HighGui.waitKey();
+
+ System.out.println(src);
+ }
+}
diff --git a/src/main/resources/lib/opencv-460.jar b/src/main/resources/lib/opencv-460.jar
new file mode 100644
index 0000000..0862f45
Binary files /dev/null and b/src/main/resources/lib/opencv-460.jar differ
diff --git a/src/main/resources/lib/x64/opencv_java460.dll b/src/main/resources/lib/x64/opencv_java460.dll
new file mode 100644
index 0000000..4e6bde8
Binary files /dev/null and b/src/main/resources/lib/x64/opencv_java460.dll differ
diff --git a/src/main/resources/lib/x86/opencv_java460.dll b/src/main/resources/lib/x86/opencv_java460.dll
new file mode 100644
index 0000000..6aec396
Binary files /dev/null and b/src/main/resources/lib/x86/opencv_java460.dll differ