gpt4 book ai didi

ios - 如何在 ImageView Swift 中显示裁剪后的图像

转载 作者:行者123 更新时间:2023-11-28 14:10:08 25 4
gpt4 key购买 nike

我正在尝试获取图像中面部的边界框值并裁剪边界框中的面部。我能够成功获取并绘制边界框,但无法裁剪图像并在 ImageView 中显示它们。谁能指导我哪里出错了?谢谢。

import UIKit
import Vision

class ViewController: UIViewController {

@IBOutlet weak var imageView: UIImageView!

override func viewDidLoad() {
super.viewDidLoad()
// 1. Load Default Image
guard let image = UIImage(named: "anuj.jpeg") else {return}
imageView.image = image
imageView.contentMode = .scaleAspectFit
self.detectFaces(img: image)
}



@IBAction func modeSwitch(_ sender: UISwitch) {
if sender.isOn{
print("Camera Mode ON !!")
}
else{
print("Camera Mode OFF !!")
}
}


// *******************************************************************
// 2. Function to detect faces in Image and retrun Bounding Box Values
// *******************************************************************
func detectFaces(img: UIImage){
// Get Image Scaled Height
let imageScaledHeight = view.frame.width / (img.size.width) * (img.size.height)
// Create Face Detection Request
let request = VNDetectFaceRectanglesRequest { (req, err)
in
if let err = err{
print("Failed to detect faces !! \(err)")
return
}
print("Request: \(req)")

req.results?.forEach({ (res) in
// Get face observations
guard let faceObservation = res as? VNFaceObservation else {return}

// Print detected face bounding box values
print("Face Observations: \(faceObservation.boundingBox)")

// Create Bounding Box
let x = self.view.frame.width * faceObservation.boundingBox.origin.x
let width = self.view.frame.width * faceObservation.boundingBox.width
let height = imageScaledHeight * faceObservation.boundingBox.height
let y = imageScaledHeight * (1 - faceObservation.boundingBox.origin.y) - height

// Show bounding Box
let redView = UIView()
redView.backgroundColor = .red
redView.frame = CGRect(x: x, y: y, width: width, height: height)
redView.alpha = 0.4
self.view.addSubview(redView)

// Crop Face in Red View i.e. in Bounding Box and show in Image View
let crop = CGRect(x: x, y: y, width: width, height: height)
let image = img.cgImage?.cropping(to: crop)
let cropImageView = UIImageView(image: UIImage(cgImage: image!))
self.view.addSubview(cropImageView)
})
}

// Convert Image to cgImage and pass to request handler
let cgImage = img.cgImage
let handler = VNImageRequestHandler(cgImage: cgImage!, options: [:])
// Perform vision request
do{
try handler.perform([request])
}
catch let reqErr{
print("Failed to perform request: \(reqErr)")
}
}
}

最佳答案

问题可能出在这一行:

let image = img.cgImage?.cropping(to: crop)

不是如何裁剪 UIImage,因为 UIImage 以及屏幕上绘制的所有其他内容都有一个比例,并且它有一个方向,但 CGImage 没有。

要裁剪 UIImage,请将其绘制到适当缩放的图形图像上下文中,以便图像的所需区域落入上下文中,然后提取生成的图像。

关于ios - 如何在 ImageView Swift 中显示裁剪后的图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52654951/

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