gpt4 book ai didi

ios - 在 iOS 上通过滑动对 UIImage 进行实时模糊

转载 作者:可可西里 更新时间:2023-11-01 00:23:40 25 4
gpt4 key购买 nike

如何在sliderValueChanged(_:)上实现UIImage的实时模糊?

@IBOutlet weak var imageView: UIImageView!

@IBAction func sliderValueChanged(sender: UISlider) {
let blurRadius = sender.value
var img = imageView.image

// some image processing for img

//blurring for img

// some another image processing for img

imageView.image = img
}

由于存在其他图像处理,我不适合 UIImageView 的模糊。

谢谢!

最佳答案

为了获得最佳性能,您应该使用 GLKViewCIFilter 而不是 UIImageView

最简单的实现之一是这样的(Xcode6/Swift1.2):

import UIKit
import GLKit

class BlurImageView: GLKView {
let clampFilter = CIFilter(name: "CIAffineClamp")!
let blurFilter = CIFilter(name: "CIGaussianBlur")!
let ciContext:CIContext

override init(frame: CGRect) {
let glContext = EAGLContext(API: .OpenGLES2)
ciContext = CIContext(
EAGLContext: glContext,
options: [
kCIContextWorkingColorSpace: NSNull()
]
)
super.init(frame: frame, context: glContext)
enableSetNeedsDisplay = true
}

required init(coder aDecoder: NSCoder) {
let glContext = EAGLContext(API: .OpenGLES2)
ciContext = CIContext(
EAGLContext: glContext,
options: [
kCIContextWorkingColorSpace: NSNull()
]
)
super.init(coder: aDecoder)
context = glContext
enableSetNeedsDisplay = true
}

@IBInspectable var inputImage: UIImage? {
didSet {
inputCIImage = inputImage.map { CIImage(image: $0)! }
}
}

@IBInspectable var blurRadius: Float = 0 {
didSet {
blurFilter.setValue(blurRadius, forKey: "inputRadius")
setNeedsDisplay()
}
}

var inputCIImage: CIImage? {
didSet { setNeedsDisplay() }
}

override func drawRect(rect: CGRect) {
if let inputCIImage = inputCIImage {
clampFilter.setValue(inputCIImage, forKey: kCIInputImageKey)
blurFilter.setValue(clampFilter.outputImage!, forKey: kCIInputImageKey)
let rect = CGRect(x: 0, y: 0, width: drawableWidth, height: drawableHeight)
ciContext.drawImage(blurFilter.outputImage!, inRect: rect, fromRect: inputCIImage.extent())
}
}
}

然后,你可以这样使用:

class ViewController: UIViewController {

@IBOutlet var imageView: BlurImageView!

override func viewDidLoad() {
super.viewDidLoad()
imageView.inputImage = UIImage(named:"testImage")!
}

@IBAction func sliderValueChanged(sender: UISlider) {
imageView.blurRadius = sender.value
}
}

参见 An Introduction to Core Image - objc.io它是更多解释和示例的示例代码。

关于ios - 在 iOS 上通过滑动对 UIImage 进行实时模糊,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32354977/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com