Skip to content

Latest commit

 

History

History
272 lines (195 loc) · 9.23 KB

README.md

File metadata and controls

272 lines (195 loc) · 9.23 KB

Transformations UI

Filestack's Transformations UI implementation for iOS and iPadOS.

Transformations UI is shipped as a Swift Package.

NOTE: Starting in version 1.2.0, all modules (previously categorized as either Standard or Premium) are now part of this Swift Package.

Requirements

  • Xcode 12+
  • Swift 4.2+ / Objective-C
  • iOS 11.0+ / iPadOS 13.0+

Installation

To install our Swift Package, please follow the steps below:

  • Add https://github.com/filestack/transformations-ui-ios.git as a Swift Package Manager dependency to your project.
  • When asked to Choose Package Options, use the default settings provided by Xcode.
  • When asked to Add Package, add TransformationsUI to your desired target(s).

Usage

  1. Import TransformationsUI

    import TransformationsUI
  2. Instantiate TransformationsUI passing a Filestack.Client and set delegate

    let fsConfig = Filestack.Config.builder
        .with(callbackURLScheme: "transformationsuidemo")
        .with(imageURLExportPreset: .current)
        .with(maximumSelectionLimit: 1)
        .with(documentPickerAllowedUTIs: ["public.image"])
        .with(cloudSourceAllowedUTIs: ["public.image"])
        .build()
    
    let policy = Policy(expiry: .distantFuture,
                        call: [.pick, .read, .stat, .write, .writeURL, .store, .convert, .remove, .exif])
    
    let security = try FilestackSDK.Security(policy: policy, appSecret: "YOUR-APP-SECRET")
    let fsClient = Filestack.Client(apiKey: "YOUR-API-KEY", security: security, config: fsConfig)
    let config = try Config(modules: modules, fsClient: fsClient)
    
    let transformationsUI = TransformationsUI(with: config)
    transformationsUI.delegate = self
  3. Add conformance to TransformationsUIDelegate

    extension ViewController: TransformationsUIDelegate {
        func editorDismissed(with image: UIImage?) {
            if let image = image {
                // TODO: Do something with resulting image...
            }
        }
    }
  4. Present TransformationsUI view controller

    if let editorVC = transformationsUI.editor(with: image) {
        editorVC.modalPresentationStyle = .fullScreen
        present(editorVC, animated: true)
    }

Modules Features

Below you will find an exhaustive list of configurable properties and commands per module.

Transform Module

Commands

Command Purpose Options Group
Resize Image resize None extraCommands
Flip Flip image along the horizontal axis None extraCommands
Flop Flip image along the vertical axis None extraCommands
Rotate Rotate image 90 degrees clockwise: true/false extraCommands
Crop cropCommands
Crop image freely (no constraints) type: .rect, aspectRatio: .free cropCommands
Crop image using original image aspect ratio type: .rect, aspectRatio: .original cropCommands
Crop image using a custom aspect ratio type: .rect, aspectRatio: .custom(CGSize) cropCommands
Circle crop image type: .circle cropCommands

Filters Module

Commands

Command Purpose Options Group
None Does not apply any filter None commands
Chrome Applies a chrome effect to image None commands
Fade Applies a fade effect to image None commands
Instant Applies an instant effect to image None commands
Mono Applies a mono effect to image None commands
Noir Applies a noir effect to image None commands
Process Applies a process effect to image None commands
Tonal Applies a tonal effect to image None commands
Transfer Applies a transfer effect to image None commands

Adjustments Module

Commands

Command Purpose Options Group
Blur Applies gaussian blur to image (interactive) None commands
Brightness Allows adjusting image brightness (interactive) None commands
Contrast Allows adjusting image contrats (interactive) None commands
Gamma Allows adjusting RGB gamma components separately (interactive) None commands
Hue Allows adjusting image hue 360 degrees (interactive) None commands

Text Module

Properties

Property Purpose Example
availableFontFamilies Defines the list of font families available in the editor ["Courier", "Futura", "Helvetica", "Times New Roman"]
defaultFontFamily Defines the default font family "Helvetica"
defaultFontColor Defines the default font color .white
defaultFontStyle Defines the default font style [.bold, .underline]
defaultTextAlignment Defines the default text alignment .left

Commands

Command Purpose Options Group
SelectFontFamily Allows user to select a font family amongst families listed in availableFontFamilies None commandsInGroups
SelectFontColor Allows user to select a font color None commandsInGroups
SelectFontStyle Allows user to toggle font style options (.bold, .italic, .underline) None commandsInGroups
SelectTextAlignment Allows user to select text alignment (.left, .center, .right, .justified) None commandsInGroups

Stickers Module (added in 1.1)

Properties

Property Purpose Example
stickers Defines the available stickers grouped by stickerset ["Stickerset 1": [UIImage, UIImage], "Stickerset 2": [UIImage, UIImage]]

Overlays Module (added in 1.1.3)

Properties

Property Purpose Example
fsClient Filestack's client (read-only) N/A

Border Module

Commands

Command Purpose Options Group
Color Allows user to select a border color None commands
Width Allows user to select a border width None commands
Transparency Allows user to set the border transparency amount None commands

Enabling or Disabling Modules

Modules may be enabled or disabled programmatically. Let's see an example:

  1. Defining the available modules

    modules.all = [
        modules.transform,
        modules.filters,
        modules.adjustments
    ]

Enabling or Disabling Module Features

Module features may be enabled or disabled programmatically. Let's see a few examples:

  1. Allow only circle crop in transform module

    modules.transform.cropCommands = [
        Modules.Transform.Commands.Crop(type: .none),
        Modules.Transform.Commands.Crop(type: .circle)
    ]
  2. Disable extra commands in transform module

    modules.transform.extraCommands = []
  3. Define custom crop modes in transform module

    // Keep original ratio
    modules.transform.cropCommands.append(
        Modules.Transform.Commands.Crop(type: .rect, aspectRatio: .original)
    )
    
    // Keep 16:9 ratio
    modules.transform.cropCommands.append(
        Modules.Transform.Commands.Crop(type: .rect, aspectRatio: .custom(CGSize(width: 16, height: 9)))
    )
  4. Define available filters in filters module

    modules.filters.commands = [
        Modules.Filters.Commands.Filter(type: .chrome),
        Modules.Filters.Commands.Filter(type: .process),
        Modules.Filters.Commands.Filter(type: .instant)
    ]
  5. Add extra available font families in text module

    modules.text.availableFontFamilies.append(contentsOf: ["Optima Regular", "Symbol"])

    Or you may want to replace available font families completely:

    modules.text.availableFontFamilies = ["Optima Regular", "Symbol"]
  6. Add stickers in stickers module

    IMPORTANT: Make sure these stickers are first added to your project (e.g. as part of an XCAsset.)

    modules.sticker.stickers = [
        "Funny": (1...18).compactMap { UIImage(named: "stickers-funny-\($0)") },
        "Hilarious": (1...18).compactMap { UIImage(named: "stickers-hilarious-\($0)") },
        "Extravagant": (1...18).compactMap { UIImage(named: "stickers-extravagant-\($0)") },
        "Kick-ass": (1...18).compactMap { UIImage(named: "stickers-kickass-\($0)") }
    ]

To discover other module features that may be configured, enabled or disabled, try Xcode's autocompletion on your Modules objects.

Screenshots

Demo

Check the demo showcasing Transformations UI usage.

Versioning

Transformations UI follows the Semantic Versioning.

Issues

If you have problems, please create a Github Issue.

Credits

Thank you to all the contributors.