将方向应用于 CGContext

Apply orientation to CGContext

我正在使用以下代码缩小 UIImage

let image = UIImage(contentsOfFile: imageUrl.path!)!.CGImage

                let width = Float(CGImageGetWidth(image)) / 1.01
                let height = Float(CGImageGetHeight(image)) / 1.01
                let bitsPerComponent = CGImageGetBitsPerComponent(image)
                let bytesPerRow = CGImageGetBytesPerRow(image)
                let colorSpace = CGImageGetColorSpace(image)
                let bitmapInfo = CGImageGetBitmapInfo(image)

                let context = CGBitmapContextCreate(nil, Int(width), Int(height), bitsPerComponent, bytesPerRow, colorSpace, bitmapInfo)
                CGContextSetInterpolationQuality(context, kCGInterpolationHigh)

                CGContextDrawImage(context, CGRect(origin: CGPointZero, size: CGSize(width: CGFloat(width), height: CGFloat(height))), image)

                let scaledImage = UIImage(CGImage: CGBitmapContextCreateImage(context))

用于照片扩展。它可以工作,缩放输入图像,但不考虑方向。我在编辑开始时保持方向:

func startContentEditingWithInput(contentEditingInput: PHContentEditingInput?, placeholderImage: UIImage) {

        let output = PHContentEditingOutput(contentEditingInput: self.input)
        let url = self.input?.fullSizeImageURL
        if let imageUrl = url {
           imageOrientation = input!.fullSizeImageOrientation
        }

}

保存的输出总是横向的。

最简单的解决方案是在创建 UIImage 输出时重新使用 UIImage 输入的图像方向。

let uiImage = UIImage(contentsOfFile: imageUrl.path!)
let image = uiImage!.CGImage
// ...
let scaledImage = UIImage(CGImage: CGBitmapContextCreateImage(context),
                          scale: uiImage.scale,
                          orientation: uiImage.imageOrientation)

这对我有用:

let scaledImage = UIImage(CGImage: CGBitmapContextCreateImage(context))

                var cimage: CIImage
                cimage = CIImage(image: scaledImage)

                if self.imageOrientation != nil {
                    cimage = cimage.imageByApplyingOrientation(self.imageOrientation!)
                }
                var _context = CIContext(options: nil)

                var cgImage = _context.createCGImage(cimage,
                    fromRect: cimage.extent())

                var resultImage = UIImage(CGImage: cgImage)

当我保存图像时,Mats 的回答确实有效。