I want to develop the live face filters as MSQRD/Snapchat live filters but did not able to find out how should I proceed should I use Augmented Reality framework and detect face OR use core image to detect the face and process accordingly. Please let me know if anyone has the idea how to implement the same?
Wickr Me is one of the apps like Snapchat for iPhone and Android users. It has everything a user may need – encrypted messages, voice memos, video and image sharing, etc. Wickr Me also features unique stickers and photo and video filters, but they aren't as interesting as the ones on Snapchat.
Camera. You can open the camera by tapping the camera icon in the top left of the app or by swiping right from News Feed. From there, you can play with masks, frames, and interactive filters to turn your content into an actual work of art.
Yes, you can easily get Snap filters without a Snapchat account. Unlike many photo editing apps, Snapchat allows its users to use the filters without having an account.
Answer: B – Augmented Reality is the technology that powers Snapchat's 'selfie' filters, allowing them to appear on your front and back camera.
I would recommend going with Core Image
and CIDetector. https://developer.apple.com/library/ios/documentation/GraphicsImaging/Conceptual/CoreImaging/ci_detect_faces/ci_detect_faces.html It has been available since iOS 5 and it has great documentation.
Creating a face detector example:
CIContext *context = [CIContext contextWithOptions:nil]; // 1 NSDictionary *opts = @{ CIDetectorAccuracy : CIDetectorAccuracyHigh }; // 2 CIDetector *detector = [CIDetector detectorOfType:CIDetectorTypeFace context:context options:opts]; // 3 opts = @{ CIDetectorImageOrientation : [[myImage properties] valueForKey:kCGImagePropertyOrientation] }; // 4 NSArray *features = [detector featuresInImage:myImage options:opts]; // 5
Here’s what the code does:
1.- Creates a context; in this example, a context for iOS. You can use any of the context-creation functions described in Processing Images.) You also have the option of supplying nil instead of a context when you create the detector.)
2.- Creates an options dictionary to specify accuracy for the detector. You can specify low or high accuracy. Low accuracy (CIDetectorAccuracyLow) is fast; high accuracy, shown in this example, is thorough but slower.
3.- Creates a detector for faces. The only type of detector you can create is one for human faces.
4.- Sets up an options dictionary for finding faces. It’s important to let Core Image know the image orientation so the detector knows where it can find upright faces. Most of the time you’ll read the image orientation from the image itself, and then provide that value to the options dictionary.
5.- Uses the detector to find features in an image. The image you provide must be a CIImage object. Core Image returns an array of CIFeature objects, each of which represents a face in the image.
Here some open projects that could help you out to start with CoreImage
or other technologies as GPUImage
or OpenCV
1 https://github.com/aaronabentheuer/AAFaceDetection (CIDetector - Swift)
2 https://github.com/BradLarson/GPUImage (Objective-C)
3 https://github.com/jeroentrappers/FaceDetectionPOC (Objective-C: it has deprecated code for iOS9)
4 https://github.com/kairosinc/Kairos-SDK-iOS (Objective-C)
5 https://github.com/macmade/FaceDetect (OpenCV)
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With