GPUImage2使用SolidColorGenerator作为RectangleGenerator

时间:2017-02-02 00:48:16

标签: swift face-detection gpuimage

与simpleVideoFilter和人脸检测类似,我想用彩色矩形突出显示我的GPUImage2视频源的一部分。 SolidColorGenerator似乎是一个良好的开端,有两个例外。首先,我不确定如何将SolidColorGenerator输出转置到原始图像上的正确位置。其次,我不确定如何在原始图像中添加N个矩形。与此同时,我在LineGenerator上获得了成功,但我认为矩形看起来会更好。

加成: 具有圆角和单个像素边框的矩形。

enter image description here

1 个答案:

答案 0 :(得分:0)

对我来说有用的是编写RectangleGenerator。新RectangleGenerator的关键是绘制GL_TRIANGLES。

let vertex = "attribute vec4 position; void main(){ gl_Position = position; }"

let fragment = "uniform lowp vec3 fillColor; void main(){ gl_FragColor = vec4(fillColor, 1.0); }"

public class RectangleGenerator: ImageGenerator {

let rectangleShader:ShaderProgram
var uniformSettings = ShaderUniformSettings()

public var fillColor:Color = Color.green { didSet { uniformSettings["fillColor"] = fillColor } }

public override init(size:Size) {
    rectangleShader = crashOnShaderCompileFailure("RectangleGenerator"){try sharedImageProcessingContext.programForVertexShader(vertex, fragmentShader:fragment)}
    super.init(size:size)

    ({fillColor = Color.green})()
}

public func renderRectangles(_ positions:[Position]) {
    guard positions.count > 3 else { return }

    imageFramebuffer.activateFramebufferForRendering()

    rectangleShader.use()
    uniformSettings.restoreShaderSettings(rectangleShader)
    clearFramebufferWithColor(Color.transparent)

    guard let positionAttribute = rectangleShader.attributeIndex("position") else { fatalError("A position attribute was missing from the shader program during rendering.") }

    let convertedPositions = positions.flatMap{$0.toGLArray()}
    glVertexAttribPointer(positionAttribute, 2, GLenum(GL_FLOAT), 0, 0, convertedPositions)

    glBlendEquation(GLenum(GL_FUNC_ADD))
    glBlendFunc(GLenum(GL_ONE), GLenum(GL_ONE))
    glEnable(GLenum(GL_BLEND))

    glDrawArrays(GLenum(GL_TRIANGLES), 0, GLsizei(positions.count) * 2)
    glDisable(GLenum(GL_BLEND))

    notifyTargets()
}
}

可以进行的一项优化是使用GL_Elements和GL_TRIANGLE_STRIP,但我无法弄明白。

enter image description here

完整的解决方案应该支持border,borderWidth和cornerRadius。现在简单的矩形就足够了。完整代码如下。

decode

快乐编码