繁体   English   中英

UIGraphicsImageRenderer 应用过滤器后镜像图像

[英]UIGraphicsImageRenderer mirrors image after applying filter

我正在尝试对图像应用过滤器。 应用滤镜效果很好,但它会垂直镜像图像。

最下面一行图像在初始化后调用过滤器 function。

顶部的主图像,在按下底部的一个后应用过滤器

ciFilterCIFilter.sepiaTone()

func applyFilter(image: UIImage) -> UIImage? {
        let rect = CGRect(origin: CGPoint.zero, size: image.size)
        let renderer = UIGraphicsImageRenderer(bounds: rect)

        ciFilter.setValue(CIImage(image: image), forKey: kCIInputImageKey)
        
        let image = renderer.image { context in
            let ciContext = CIContext(cgContext: context.cgContext, options: nil)

            if let outputImage = ciFilter.outputImage {
                ciContext.draw(outputImage, in: rect, from: rect)
            }
        }

        return image
    }

在应用两次过滤器后,新图像会被放大。

这是一些屏幕截图。 开始 应用过滤器后 第二次应用过滤器后

您不需要使用UIGraphicsImageRenderer 您可以直接从CIContext获取图像。

func applyFilter(image: UIImage) -> UIImage? {
        
        ciFilter.setValue(CIImage(image: image), forKey: kCIInputImageKey)
        
        guard let ciImage = ciFilter.outputImage else {
            return nil
        }
        let outputCGImage = CIContext().createCGImage(ciImage, from: ciImage.extent)
        
        guard let _ = outputCGImage else { return nil }
        let filteredImage = UIImage(cgImage: outputCGImage!, scale: image.scale, orientation: image.imageOrientation)
        
        return filteredImage
    }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM