Skip to content

A Swift Package for facial segmentation using Vision

License

Notifications You must be signed in to change notification settings

SaladDays831/FaceSeg

Repository files navigation

FaceSeg

FaceSeg is a facial segmentation package written in Swift. It uses Apple's Vision framework and its' facial observations + landmarks to create different images with segmented faces

Requirements

iOS 11.0+ / macOS 10.13+

Installation

Swift Package Manager:

  • File > Swift Packages > Add Package Dependency
  • Add https://github.com/SaladDays831/FaceSeg.git

Usage

Create an instance of FaceSeg, set its' delegate. Create a FaceSegConfiguration object, and set whatever you need to true. Every property is false by default to save on performance. If you don't explicitly set the needed settings in FaceSegConfiguration - only metadata will be returned in the result

let faceSeg = FaceSeg()
faceSeg.delegate = self

let configuration = FaceSegConfiguration()
// Modify the configuration as per your needs
faceSeg.configuration = configuration

faceSeg.process(myCoolImage)
extension ViewController: FaceSegDelegate { 
    func didFinishProcessing(_ result: FaceSegResult) {
        print("Finished processing image") 
    }

    func didFinishWithError(_ error: FaceSegError) {
        print("FaceSeg finished with error: \(error.errorString)")
    }
}

A working example can be found in the FaceSegDemo folder

FaceSegConfiguration parameters

drawDebugImage
Original image with face bounding boxes, paths, and landmarks

Debug image

drawFacesImage
Image with the segmented faces on a transparent background. The location/scale of the faces is preserved

Faces image

drawCutoutFacesImage
-Original image with transparent holes instead of the detected faces

Cutout Faces image

faceInBoundingBoxImageHeight
The size (width == height) of the resulting images in the facesInBoundingBoxes array
drawFacesInBoundingBoxes
An array of detected faces as separate images

Note ⚠️

Running on the simulator doesn't work. This is an issue with Vision introduced with iOS 15. https://developer.apple.com/forums/thread/690605

Licence

FaceSeg is released under the MIT license. See LICENSE for details.

About

A Swift Package for facial segmentation using Vision

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages