首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

从CIImage创建的UIImage创建的JPG太大了3倍

基础概念

CIImage 是 Core Image 框架中的一个类,用于表示图像数据。UIImage 是 UIKit 框架中的一个类,用于在 iOS 应用程序中显示和处理图像。将 CIImage 转换为 UIImage 并保存为 JPG 文件时,可能会遇到文件大小过大的问题。

问题原因

  1. 图像质量设置过高:默认情况下,保存 JPG 图像时可能会使用较高的质量设置,导致文件过大。
  2. 图像分辨率过高:如果原始 CIImage 的分辨率很高,保存为 JPG 文件时会占用更多空间。
  3. 色彩空间和位深度:不同的色彩空间和位深度也会影响图像文件的大小。

解决方法

可以通过调整图像质量和分辨率来减小 JPG 文件的大小。以下是一个示例代码,展示如何将 CIImage 转换为 UIImage 并保存为较小的 JPG 文件:

代码语言:txt
复制
import UIKit
import CoreImage

func saveCIImageAsJPG(_ ciImage: CIImage, quality: CGFloat = 0.75, completion: @escaping (URL?) -> Void) {
    let context = CIContext(options: nil)
    guard let cgImage = context.createCGImage(ciImage, from: ciImage.extent) else {
        completion(nil)
        return
    }
    
    let image = UIImage(cgImage: cgImage)
    guard let data = image.jpegData(compressionQuality: quality) else {
        completion(nil)
        return
    }
    
    let url = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask).first!.appendingPathComponent("image.jpg")
    do {
        try data.write(to: url)
        completion(url)
    } catch {
        completion(nil)
    }
}

// 示例调用
let ciImage = // 获取你的 CIImage 对象
saveCIImageAsJPG(ciImage, quality: 0.5) { url in
    if let url = url {
        print("JPG 文件保存成功: \(url)")
    } else {
        print("JPG 文件保存失败")
    }
}

代码解释

  1. 创建 CIContext:使用 CIContextCIImage 转换为 CGImage
  2. 创建 UIImage:使用 CGImage 创建 UIImage 对象。
  3. 调整图像质量:使用 UIImagejpegData(compressionQuality:) 方法设置图像质量,值范围为 0.0 到 1.0,数值越小,文件越小。
  4. 保存文件:将调整后的图像数据保存为 JPG 文件。

参考链接

通过调整图像质量和分辨率,可以有效减小 JPG 文件的大小,同时保持图像质量在可接受范围内。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • IOS 使用Core Image做单色调效果

    1 import UIKit 2 import CoreImage 3 4 class ViewController:UIViewController { 5 6 override func viewDidLoad() { 7 super.viewDidLoad() 8 9 let option = Dictionary(dictionaryLiteral: (kCIContextUseSoftwareRenderer, true)) 10 let context = CIContext(options:option) 11 let image = UIImage(named:“Pic1”) 12 let imageView = UIImageView(image:image) 13 14 let filter = CIFilter(name:“CIColorMonochrome”) 15 let ciImage = CIImage(image:image!) 16 let color = CIColor(red:0.8, green:0.6, blue:0.4) 17 filter?.setValue(color, forKey:kCIInputColorKey) 18 filter?.setValue(1.0, forKey:kCIInputIntensityKey) 19 filter?.setValue(ciImage, forKey:kCIInputImageKey) 20 21 let resltImage = filter?.outputImage 22 let outImage = context.createCGImage((filter?.outputImage)!, from: (resltImage?.extent)!) 23 imageView.image = UIImage(cgImage:outImage!) 24 self.view.addSubview(imageView) 25 } 26 }

    04

    IOS CIDetector检测出人脸区域

    1 import UIKit 2 class ViewController:UIViewController { 3 override func viewDidLoad() { 4 super.viewDidLoad() 5 // Do any additional setup after loading the view, typically from a nib. 6 self.view.backgroundColor = UIColor.black 7 8 let image = UIImage(named:“Picture”) 9 let imageView = UIImageView(image:image) 10 imageView.center = CGPoint(x:160, y:260) 11 self.view.addSubview(imageView) 12 13 let ciImage = CIImage(image:image!) 14 let ciContext:CIContext = { return CIContext(options:nil) }() 15 let ciDetector = CIDetector(ofType: CIDetectorTypeFace, context:ciContext, options: [CIDetectorAccuracy:CIDetectorAccuracyHigh]) 16 17 let ciImageSize = ciImage!.extent.size 18 var transform = CGAffineTransform.identity 19 transform = transform.scaledBy(x:1, y:-1) 20 transform = transform.translatedBy(x:0, y:- ciImageSize.height) 21 22 let features:[CIFeature]!= ciDetector!.features(in: ciImage!) 23 for feature in features 24 { 25 let frame = feature.bounds.applying(transform) 26 let faceView = UIView(frame:frame) 27 faceView.layer.borderWidth = 2 28 faceView.layer.borderColor = UIColor.white.cgColor 29 30 imageView.addSubview(faceView) 31 } 32 } 33 }

    02

    IOS 给相机添加滤镜效果

    1 import CoreImage 2 import AVFoundation 3 class ViewController:UIViewController,AVCaptureVideoDataOutputSampleBufferDelegate 4 var filter:CIFilter! 5 var ciImage:CIImage! 6 var videoLayer:CALayer! 7 var imageView:UIImageView! 8 var avCaptureSession:AVCaptureSession! 9 var context:CIContext = { 10 return CIContext(eaglContext:EAGLContext(api: EAGLRenderingAPI.openGLES2)!, options:nil) 11 }() 12 override func viewDidLoad() { 13 super.viewDidLoad() 14 filter = CIFilter(name:“CIPhotoEffectTransfer”) 15 buildUI() 16 buildSession() 17 } 18 func buildUI() 19 { 20 videoLayer = CALayer() 21 videoLayer.anchorPoint = CGPoint.zero 22 videoLayer.bounds = view.bounds 23 self.view.layer.insertSublayer(videoLayer, at:0) 24 25 imageView = UIImageView(frame:view.bounds) 26 self.view.addSubview(imageView) 27 28 let button = UIButton(frame:CGRect(x:0, y:420, width:320, height:60)) 29 button.setTitle(“截取图片”, for: UIControlState.init(rawValue:0)) 30 button.backgroundColor = UIColor.black 31 button.addTarget(self, action:

    01
    领券