91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

OpenCV Java如何實現人臉識別和裁剪功能

發布時間:2021-04-15 11:23:22 來源:億速云 閱讀:559 作者:小新 欄目:編程語言

這篇文章將為大家詳細講解有關OpenCV Java如何實現人臉識別和裁剪功能,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

安裝及配置

1.首先安裝OpenCV,地址

這里我下載的是Windows版的3.4.5

OpenCV Java如何實現人臉識別和裁剪功能

然后安裝即可……

2.Eclipse配置OpenCV

Window->Preferences->Java->User Libraries

OpenCV Java如何實現人臉識別和裁剪功能

New輸入你的Libraries名

OpenCV Java如何實現人臉識別和裁剪功能

這里我的安裝目錄是D:\OpenCV,所以是:

OpenCV Java如何實現人臉識別和裁剪功能

然后引入dll,我是64位機子,所以是:

OpenCV Java如何實現人臉識別和裁剪功能

OpenCV Java如何實現人臉識別和裁剪功能

Ok,下面創建Java項目做Java與OpenCV的人臉識別。

人臉識別

創建項目后首先右擊選擇Properties

OpenCV Java如何實現人臉識別和裁剪功能

OpenCV Java如何實現人臉識別和裁剪功能

然后引入即可。

引入haarcascade_frontalface_alt.xml這個xml文件:

OpenCV Java如何實現人臉識別和裁剪功能

我的pom文件如下:

 <dependencies>
 <dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-web</artifactId>
 </dependency>
 
 
 <dependency>
 <groupId>org.bytedeco.javacpp-presets</groupId>
 <artifactId>ffmpeg</artifactId>
 <version>3.1.2-1.2</version>
 </dependency>
 <dependency>
 <groupId>org.bytedeco</groupId>
 <artifactId>javacv</artifactId>
 <version>1.4.1</version>
 </dependency>
 <!-- https://mvnrepository.com/artifact/org.bytedeco.javacpp-presets/ffmpeg-platform -->
 <dependency>
 <groupId>org.bytedeco.javacpp-presets</groupId>
 <artifactId>ffmpeg-platform</artifactId>
 <version>3.4.2-1.4.1</version>
 </dependency>
 <dependency>
 <groupId>commons-io</groupId>
 <artifactId>commons-io</artifactId>
 <version>2.4</version>
 </dependency>
 
 
 <!-- 視頻攝像頭 -->
 <!-- https://mvnrepository.com/artifact/org.bytedeco/javacv-platform -->
 <dependency>
 <groupId>org.bytedeco</groupId>
 <artifactId>javacv-platform</artifactId>
 <version>1.4.1</version>
 </dependency>
 <!-- https://mvnrepository.com/artifact/org.bytedeco.javacpp-presets/opencv-platform -->
 <dependency>
 <groupId>org.bytedeco.javacpp-presets</groupId>
 <artifactId>opencv-platform</artifactId>
 <version>3.4.1-1.4.1</version>
 </dependency>
 
 <dependency>
 <groupId>junit</groupId>
 <artifactId>junit</artifactId>
 <version>4.12</version>
 <scope>test</scope>
 </dependency>
 
 <dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-test</artifactId>
 <scope>test</scope>
 </dependency>
 </dependencies>

修改我的端口號:

server.port=8889

最后代碼如下:

import java.io.BufferedInputStream;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
 
import javax.servlet.http.HttpServletResponse;
 
import org.apache.commons.io.FileUtils;
import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfRect;
import org.opencv.core.Point;
import org.opencv.core.Rect;
import org.opencv.core.Scalar;
import org.opencv.core.Size;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;
import org.opencv.objdetect.CascadeClassifier;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.core.io.Resource;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
 
/* 
* @author zzf 
* @date 2019年1月17日 下午12:04:45 
*/
@RestController
public class OpenCVController {
 
 @Value("classpath:haarcascade_frontalface_alt.xml")
 private Resource xml;
 
 @PostMapping("/face")
 public void FaceDetector(HttpServletResponse response, MultipartFile file) throws IOException {
 // D:\workspace-sts-3.9.2.RELEASE\OpenCV\src\main\resources
 // String opencvpath = System.getProperty("user.dir") +
 // "\\src\\main\\resources\\";
 // String opencvDllName = opencvpath + Core.NATIVE_LIBRARY_NAME + ".dll";
 // System.load(opencvDllName);
 System.loadLibrary(Core.NATIVE_LIBRARY_NAME);
 System.out.println("人臉檢測開始……");
 
 // 創建臨時文件,因為boot打包后無法讀取文件內的內容
 File targetXmlFile = new File("src/" + xml.getFilename() + "");
 FileUtils.copyInputStreamToFile(xml.getInputStream(), targetXmlFile);
 CascadeClassifier faceDetector = new CascadeClassifier(targetXmlFile.toString());
 if (faceDetector.empty()) {
 System.out.println("請引入文件……");
 return;
 }
 // 創建圖片tempFile
 File tempFile = new File("src/" + file.getOriginalFilename() + "");
 FileUtils.copyInputStreamToFile(file.getInputStream(), tempFile);
 
 // 讀取創建的圖片tempFile
 Mat image = Imgcodecs.imread(tempFile.toString());
 MatOfRect faceDetections = new MatOfRect();
 // 進行人臉檢測
 faceDetector.detectMultiScale(image, faceDetections);
 System.out.println(String.format("檢測到人臉: %s", faceDetections.toArray().length));
 Integer i = 1;
 // 制圖將圖填充到image中
 for (Rect rect : faceDetections.toArray()) {
 Imgproc.rectangle(image, new Point(rect.x, rect.y), new Point(rect.x + rect.width, rect.y + rect.height),
  new Scalar(0, 255, 0), 3);
 imageCut(tempFile.toString(), i+".jpg", rect.x, rect.y, rect.width, rect.height);// 進行圖片裁剪
 i++;
 }
 // 下面部分是返回給頁面
 String filename = file.getOriginalFilename();
 Imgcodecs.imwrite(filename, image);
 File imgFile = new File(filename);
 if (imgFile.exists()) {
 response.getOutputStream().write(toByteArray(imgFile));
 response.getOutputStream().close();
 }
 
 // 刪除臨時文件
 if (targetXmlFile.exists() && targetXmlFile.isFile()) {
 if (targetXmlFile.delete()) {
 System.out.println("刪除臨時文件" + targetXmlFile + "成功!");
 }
 }
 if (imgFile.exists() && imgFile.isFile()) {
 if (imgFile.delete()) {
 System.out.println("刪除臨時文件" + imgFile + "成功!");
 }
 }
 if (tempFile.exists() && tempFile.isFile()) {
 if (tempFile.delete()) {
 System.out.println("刪除臨時文件" + tempFile + "成功!");
 }
 }
 }
 
 public static void imageCut(String imagePath, String outFile, int posX, int posY, int width, int height) {
 // 原始圖像
 Mat image = Imgcodecs.imread(imagePath);
 // 截取的區域:參數,坐標X,坐標Y,截圖寬度,截圖長度
 Rect rect = new Rect(posX, posY, width, height);
 // 兩句效果一樣
 Mat sub = image.submat(rect); // Mat sub = new Mat(image,rect);
 Mat mat = new Mat();
 Size size = new Size(width, height);
 Imgproc.resize(sub, mat, size);// 將人臉進行截圖并保存
 Imgcodecs.imwrite(outFile, mat);
 System.out.println(String.format("圖片裁切成功,裁切后圖片文件為: %s", outFile));
 
 }
 
 public static byte[] toByteArray(File file) throws IOException {
 File f = file;
 if (!f.exists()) {
 throw new FileNotFoundException("file not exists");
 }
 ByteArrayOutputStream bos = new ByteArrayOutputStream((int) f.length());
 BufferedInputStream in = null;
 try {
 in = new BufferedInputStream(new FileInputStream(f));
 int buf_size = 1024;
 byte[] buffer = new byte[buf_size];
 int len = 0;
 while (-1 != (len = in.read(buffer, 0, buf_size))) {
 bos.write(buffer, 0, len);
 }
 return bos.toByteArray();
 } catch (IOException e) {
 e.printStackTrace();
 throw e;
 } finally {
 try {
 in.close();
 } catch (IOException e) {
 e.printStackTrace();
 }
 bos.close();
 }
 }
 
}

下面來一張我男神們的合照

OpenCV Java如何實現人臉識別和裁剪功能

OpenCV Java如何實現人臉識別和裁剪功能

OpenCV Java如何實現人臉識別和裁剪功能

OpenCV Java如何實現人臉識別和裁剪功能

關于“OpenCV Java如何實現人臉識別和裁剪功能”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

兴仁县| 桐柏县| 南丹县| 石河子市| 温州市| 湾仔区| 呼和浩特市| 三原县| 独山县| 阿拉善左旗| 石狮市| 崇信县| 黄石市| 洛扎县| 清苑县| 千阳县| 庄河市| 南漳县| 遵义县| 陕西省| 三河市| 嘉兴市| 成武县| 定陶县| 安仁县| 遂溪县| 沅陵县| 荥阳市| 陈巴尔虎旗| 珲春市| 鄂州市| 牡丹江市| 常州市| 巴林右旗| 天祝| 大理市| 安平县| 南岸区| 靖江市| 遵义市| 高雄市|