2016-06-28 3 views
2

이상한 다음을 사용 :CIColorMatrix 필터 결과 나는 다음과 같은 QR 코드를 변환하는 CIFilter를 만들기 위해 노력하고

let invert = CIFilter(name: "CIColorInvert") 
invert!.setDefaults() 
invert!.setValue(ciImage, forKey: "inputImage") 

let filter = CIFilter(name: "CIColorMatrix") 
filter?.setDefaults() 
filter?.setValue(invert?.outputImage, forKey: kCIInputImageKey) 

let r = CGFloat(70.0/255.0) 
let g = CGFloat(224.0/255.0) 
let b = CGFloat(182.0/255.0) 

filter?.setValue(CIVector(x: r, y: 0, z: 0, w: 0), forKey: "inputRVector") 
filter?.setValue(CIVector(x: 0, y: g, z: 0, w: 0), forKey: "inputGVector") 
filter?.setValue(CIVector(x: 0, y: 0, z: b, w: 0), forKey: "inputBVector") 
filter?.setValue(CIVector(x: 0, y: 0, z: 0, w: 1), forKey: "inputAVector") 

does는 먼저 일반 QR 코드를 반전하여 흰색이 검은 색이되게 한 다음 이미지를 가져 와서 필터를 적용합니다. 코드의 결과는 이것이다 :

내가 원하는 색상이 아닌

enter image description here

. 나는 어떤 도움을 주셔서 감사합니다!

감사합니다!

답변

1

다음 방법 중 하나를 사용하여 QR filter effect을 사용하면 coreImage을 사용할 수 있습니다.

출력 :

enter image description here

방법 1 :Using Custom Filter

Step1:는 다음과 같은 custom kernel에 별도의 class을 만듭니다.

class CustomFilter: CIFilter { 
var inputImage: CIImage? 

override public var outputImage: CIImage! { 
    get { 
     if let inputImage = self.inputImage { 
      let args = [inputImage as AnyObject] 
      return createCustomKernel().apply(withExtent: inputImage.extent, arguments: args) 
     } else { 
      return nil 
     } 
     } 
    } 
} 


func createCustomKernel() -> CIColorKernel { 
let kernelString = 
    "kernel vec4 chromaKey(__sample s) { \n" + 
     " vec4 newPixel = s.rgba;" + 
     " newPixel[0] = 0.0;" + 
     " newPixel[2] = newPixel[2]/2.0;" + 
     " return newPixel;\n" + 
"}" 
return CIColorKernel(string: kernelString)! 
} 

귀하의 ViewController에 사용자 정의 필터를 아래와 같이 선언 할 수 있습니다.

var context = CIContext(options: nil) 

func customQRFilter() { 

    let myInvertFilter = CIFilter(name: "CIColorInvert") 
    myInvertFilter!.setValue(CIImage(image: imageView.image!), forKey: kCIInputImageKey) 
    let output = myInvertFilter!.outputImage 

    let filter = CustomFilter() 
    filter.setValue(output, forKey: kCIInputImageKey) 

    // Get the filtered output image and return it 
    let outputImage = filter.outputImage! 
    let cgimg = context.createCGImage(outputImage,from: output!.extent) 
    let processedImage = UIImage(cgImage: cgimg!) 
    imageView.image = processedImage 
    } 

방법 2 :CIColorMatrix 필터를 사용하여.

func colorMatrixFilter() { 

    let myInvertFilter = CIFilter(name: "CIColorInvert") 
    myInvertFilter!.setValue(CIImage(image: imageView.image!), forKey: kCIInputImageKey) 
    let output = myInvertFilter!.outputImage 

    let filter = CIFilter(name: "CIColorMatrix") 
    filter?.setDefaults() 
    filter?.setValue(output, forKey: kCIInputImageKey) 

    let r = CGFloat(0.0) 
    let g = CGFloat(0.9) 
    let b = CGFloat(0.416) 

    filter?.setValue(CIVector(x: r, y: 0, z: 0, w: 0), forKey: "inputRVector") 
    filter?.setValue(CIVector(x: 0, y: g, z: 0, w: 0), forKey: "inputGVector") 
    filter?.setValue(CIVector(x: 0, y: 0, z: b, w: 0), forKey: "inputBVector") 
    filter?.setValue(CIVector(x: 0, y: 0, z: 0, w: 1), forKey: "inputAVector") 

    let outputs = filter?.outputImage 
    let cgimg = context.createCGImage(outputs!,from: output!.extent) 
    let processedImage = UIImage(cgImage: cgimg!) 
    imageView2.image = processedImage 
} 

참고 : I 조언 당신이 원하는 RGB value of any colour을 선택하는 colour Picker tool를 사용합니다.

관련 문제