ฉันพบว่ามันยากที่จะหาคำตอบที่คุณสามารถใช้นอกกรอบในโครงการSwift 3 ของคุณ ปัญหาหลักของคำตอบอื่น ๆ ที่พวกเขาไม่เคารพอัลฟาช่องของภาพ นี่คือเทคนิคที่ฉันใช้ในโครงการของฉัน
extension UIImage {
func scaledToFit(toSize newSize: CGSize) -> UIImage {
if (size.width < newSize.width && size.height < newSize.height) {
return copy() as! UIImage
}
let widthScale = newSize.width / size.width
let heightScale = newSize.height / size.height
let scaleFactor = widthScale < heightScale ? widthScale : heightScale
let scaledSize = CGSize(width: size.width * scaleFactor, height: size.height * scaleFactor)
return self.scaled(toSize: scaledSize, in: CGRect(x: 0.0, y: 0.0, width: scaledSize.width, height: scaledSize.height))
}
func scaled(toSize newSize: CGSize, in rect: CGRect) -> UIImage {
if UIScreen.main.scale == 2.0 {
UIGraphicsBeginImageContextWithOptions(newSize, !hasAlphaChannel, 2.0)
}
else {
UIGraphicsBeginImageContext(newSize)
}
draw(in: rect)
let newImage = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()
return newImage ?? UIImage()
}
var hasAlphaChannel: Bool {
guard let alpha = cgImage?.alphaInfo else {
return false
}
return alpha == CGImageAlphaInfo.first ||
alpha == CGImageAlphaInfo.last ||
alpha == CGImageAlphaInfo.premultipliedFirst ||
alpha == CGImageAlphaInfo.premultipliedLast
}
}
ตัวอย่างการใช้งาน:
override func viewDidLoad() {
super.viewDidLoad()
let size = CGSize(width: 14.0, height: 14.0)
if let image = UIImage(named: "barbell")?.scaledToFit(toSize: size) {
let imageView = UIImageView(image: image)
imageView.center = CGPoint(x: 100, y: 100)
view.addSubview(imageView)
}
}
รหัสนี้เป็นส่วนเสริมของแอปเปิ้ลที่เขียนใหม่พร้อมการรองรับภาพที่มีและไม่มีช่องอัลฟา
เป็นการอ่านเพิ่มเติมฉันแนะนำให้ตรวจสอบบทความนี้สำหรับเทคนิคการปรับขนาดรูปภาพต่าง ๆ แนวทางปัจจุบันมีประสิทธิภาพที่ดีใช้งาน API ระดับสูงและเข้าใจง่าย ฉันขอแนะนำให้ติดมันจนกว่าคุณจะพบว่าการปรับขนาดภาพเป็นคอขวดในประสิทธิภาพของคุณ