swift2 - Swift - GLKit 查看 CIFilter 图像

标签 swift2 glkit cifilter

我正在尝试使用 GLIKit View 来修改图像。到目前为止,我的类在所有 CIFilter 中都运行良好,除了它呈现黑色 View 的 CILineOverlay 之外。如果我使用任何其他效果,效果都会很好。

为什么CILineOverlay没有显示?

class ImageView: GLKView {
    let clampFilter = CIFilter(name: "CIAffineClamp")!
    let blurFilter = CIFilter(name: "CILineOverlay")!
    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: "inputIntensity")
            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)
        }
    }
}

最佳答案

Apple 文档指出“图像中没有轮廓的部分是透明的”。 - 这意味着您正在黑色背景上绘制黑色线条。您可以简单地将过滤器的输出合成在白色背景上以使线条出现:

    let background = CIImage(color: CIColor(color: UIColor.whiteColor()))
        .imageByCroppingToRect(inputCIImage.extent)

    let finalImage = filter.outputImage!
        .imageByCompositingOverImage(background)

关于swift2 - Swift - GLKit 查看 CIFilter 图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37839722/

相关文章:

ios - GLKit:为 Swift 格式化 Objective-C GLKit 参数

ios - 是否有适当的方法来为使用 CITextImageGenerator 生成的图像着色?

objective-c - 在 OS X 上正确应用 CALayer compositingFilter?

swift - 我创建了一个自定义 UIView,其中我尝试使用 UISwitch 来打开和关闭 blackStroke 边框

objective-c - GCD 和 for 循环

ios - 扩展保存特定元素类型的快速数组

ios - iOS 8 SDK 中的 GL_DRAW_FRAMEBUFFER_APPLE 和 GL_READ_FRAMEBUFFER_APPLE 在哪里?

ios - 使用 swift - ROI 应用于选定区域的 CIFilter

regex - 如何在 Swift 2 中将一串十六进制字符串解析为等效的 ascii

python - Swift 等效于 Python 切片赋值