gpt4 book ai didi

ios - 如何快速裁剪圆孔中的缩放图像

转载 作者:行者123 更新时间:2023-11-28 23:46:30 27 4
gpt4 key购买 nike

我在我的应用程序中用相机拍照。我的 ImageView 顶部有一个带有透明孔的图层,如图所示 enter image description here

我想要做的是裁剪那个圆孔中的图像。我正在使用该代码,但它不起作用

UIGraphicsBeginImageContextWithOptions(CGSize(width: radius-60, height: radius-60),false,0)
final!.draw(at: CGPoint(x: 30, y: screenHeight/2 - radius/2 + 30)
let tmpImg = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()

其中UIGraphicsBeginImageContextWithOptions中的高和宽为圆孔的高和宽,draw中的x和y为孔的x坐标,y坐标为孔的上边界

图片代码

func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : Any]) {
print("here123")
let image = info[UIImagePickerControllerOriginalImage] as! UIImage
imageView.contentMode = .scaleAspectFit
imageView.image = image
self.view.backgroundColor = UIColor.black
picker.dismiss(animated: true, completion: nil)
photoSave()
}

透明孔代码

screenWidth = self.view.frame.width
screenHeight = self.view.frame.height
radius = min(screenWidth,screenHeight)
let path = UIBezierPath(roundedRect: CGRect(x: 0, y: 0, width: screenWidth, height: screenHeight), cornerRadius: 0)
let circlePath = UIBezierPath(roundedRect: CGRect(x: 30, y: screenHeight/2 - radius/2 + 30 , width: radius-60, height: radius - 60), cornerRadius: radius/2 - 30)

path.append(circlePath)
path.usesEvenOddFillRule = true
fillLayer.path = path.cgPath
fillLayer.fillRule = kCAFillRuleEvenOdd
fillLayer.fillColor = UIColor.black.cgColor
fillLayer.opacity = 0.5
view.layer.addSublayer(fillLayer)

最佳答案

您可以使用它来舍入 UIImage:

func roundedImage(from image: UIImage, radius: CGFloat) -> UIImage {
let frame = CGRect(x: 0, y: 0, width: 2 * radius, height: 2 * radius)
let imageView: UIImageView = UIImageView(frame: frame)
imageView.image = image

let layer = imageView.layer
layer.masksToBounds = true
layer.cornerRadius = radius

UIGraphicsBeginImageContext(imageView.bounds.size)
layer.render(in: UIGraphicsGetCurrentContext()!)
let roundedImg = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()

return roundedImg!
}

let img = UIImage(named: "NameOfTheImage")!
let r: CGFloat = 300
roundedImage(from: img, withRadius: r)

要在特定的圆圈中渲染图像,而不仅仅是围绕图像,请使用以下命令:

UIGraphicsBeginImageContext(newImageView.bounds.size)

let frame = CGRect(x: 30, y: screenHeight/2 - radius/2 + 30, width: radius - 60, height: radius - 60)

guard let img = imageView.image, let cgImage = img.cgImage, let croppedCGImage = cgImage.cropping(to: frame) else {
fatalError("Couldn't crop the image")
}

let newImage = UIImage(cgImage: croppedCGImage)
let newImageView: UIImageView = UIImageView(image: newImage)

let layer = newImageView.layer
layer.masksToBounds = true
layer.cornerRadius = radius

layer.render(in: UIGraphicsGetCurrentContext()!)
guard let roundedImg = UIGraphicsGetImageFromCurrentImageContext() else {
fatalError("Couldn't render the image")
}

UIGraphicsEndImageContext()

// use roundedImg

关于ios - 如何快速裁剪圆孔中的缩放图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52575071/

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