如何应用自定义过滤器

puk*_*978 2 swift alamofireimage

我正在使用 AlamofireImage 从我的 CDN 下载图像,但是我想对下载的某些图像应用自定义过滤器(灰度)。目前我正在使用 scrollView 来显示所有可用图像,如果图像具有特定属性,则应用过滤器。

我是 AlamofireImage 的新手,所以我不知道如何应用自定义过滤器。

我已经申请

let imageFilter = BlurFilter(blurRadius: 10)
Run Code Online (Sandbox Code Playgroud)

到过滤器参数,所以我知道实际的过滤器过程正在工作,但有人可以帮助创建自定义过滤器以将灰度应用于下载的图像吗?

小智 5

方法#1

使用 Alamofireimage 的“imageWithAppliedCoreImageFilter” UIImage 扩展。但出于某种原因,他们没有提供对这个过滤器选项的简单协议访问,所以让我们创建一个......

public struct CoreImageFilter: ImageFilter {

    let filterName: String
    let parameters: [String: AnyObject]

    public init(filterName : String, parameters : [String : AnyObject]?) {
        self.filterName = filterName
        self.parameters = parameters ?? [:]
    }

    public var filter: UIImage -> UIImage {
        return { image in
            return image.af_imageWithAppliedCoreImageFilter(self.filterName, parameters: self.parameters) ?? image
    }
}
Run Code Online (Sandbox Code Playgroud)

Alamofireimage 用户应该熟悉用法:

let imageView = UIImageView(frame: frame)
let URL = NSURL(string: "https://httpbin.org/image/png")!
let placeholderImage = UIImage(named: "placeholder")!
let color = CIColor(color: UIColor.grayColor())  // or whatever color desired
let intensity = 1.0  // 1.0 is the default, but setting it manually here to allow adjustment
let filter = CoreImageFilter(filterName: "CIColorMonochrome", parameters: ["inputColor": color, "inputIntensity" : intensity])

imageView.af_setImageWithURL(
    URL,
    placeholderImage: placeholderImage,
    filter: filter
)
Run Code Online (Sandbox Code Playgroud)

如果您对 CIColorMonochrome 过滤器不满意(我不满意),这里有一些其他选择...

let filter = CoreImageFilter(filterName: "CIPhotoEffectTonal", parameters: nil)
Run Code Online (Sandbox Code Playgroud)

或者

let filter = CoreImageFilter(filterName: "CIPhotoEffectNoir", parameters: nil)
Run Code Online (Sandbox Code Playgroud)

这是Apple 开发站点上可用过滤器完整列表的链接。

方法#2

查找自定义滤镜,例如最受好评的答案是什么是产生黑白效果的最佳核心图像滤镜?.

然后创建一个扩展。信用ShmidtDerGote为下面的代码的身体。

extension UIImage {
    public func ff_imageFilteredToGrayScale() -> UIImage? {
        let context = CIContext(options: nil)
        let ciImage = CoreImage.CIImage(image: self)!

        // Set image color to b/w
        let bwFilter = CIFilter(name: "CIColorControls")!
        bwFilter.setValuesForKeysWithDictionary([kCIInputImageKey:ciImage, kCIInputBrightnessKey:NSNumber(float: 0.0), kCIInputContrastKey:NSNumber(float: 1.1), kCIInputSaturationKey:NSNumber(float: 0.0)])
        let bwFilterOutput = (bwFilter.outputImage)!

        // Adjust exposure
        let exposureFilter = CIFilter(name: "CIExposureAdjust")!
        exposureFilter.setValuesForKeysWithDictionary([kCIInputImageKey:bwFilterOutput, kCIInputEVKey:NSNumber(float: 0.7)])
        let exposureFilterOutput = (exposureFilter.outputImage)!

        // Create UIImage from context
        let bwCGIImage = context.createCGImage(exposureFilterOutput, fromRect: ciImage.extent)
        let resultImage = UIImage(CGImage: bwCGIImage, scale: 1.0, orientation: self.imageOrientation)

        return resultImage
    }
}
Run Code Online (Sandbox Code Playgroud)

和结构...

public struct GrayScaleFilter: ImageFilter {

    public init() {
    }

    public var filter: UIImage -> UIImage {
        return { image in
            return image.ff_imageFilteredToGrayScale() ?? image
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

最后,用法...

let imageView = UIImageView(frame: frame)
let URL = NSURL(string: "https://httpbin.org/image/png")!
let placeholderImage = UIImage(named: "placeholder")!

let filter = GrayScaleFilter()

imageView.af_setImageWithURL(
    URL,
    placeholderImage: placeholderImage,
    filter: filter
)
Run Code Online (Sandbox Code Playgroud)