Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/Zaprogramiacz/MGFlipView

MGFlipView allows to create flipping view in easy way without worrying about flipping animation and flipping logic.
https://github.com/Zaprogramiacz/MGFlipView

flip flipcard flipping-cards flippingcard flipview ios macos swift swift-package-manager swift5-3 swiftui tvos watchos

Last synced: 2 months ago
JSON representation

MGFlipView allows to create flipping view in easy way without worrying about flipping animation and flipping logic.

Awesome Lists containing this project

README

        

# MGFlipView

![Swift](https://img.shields.io/badge/Swift-5.3-orange)
![Platforms](https://img.shields.io/badge/Platform-iOS%20%7C%20macOS%20%7C%20watchOS%20%7C%20tvOS-blue)
![Dependency manager](https://img.shields.io/badge/Dependency%20manager-SPM-green)

## About

If you are looking for an easy way of implement 3D flipping view, you are in the right place. MGFlipView allows to create flipping view in easy way without worring about flipping animation and flipping logic.

The library is written in SwiftUI and it can be used on all platforms (iOS, macOS, watchOS, tvOS).

Examples of usage for all platforms are available after opening `MGFlipView.xcworkspace`.

The library is distributed via SPM.

## Preview

![Preview](Examples/flip_view_example.gif)

## Documentation

`FlipView` takes 6 arguments:

| Argument | Type | Description |
| --------- |:----------------------:| ------------ |
| frontView | `() -> View` | Front view builder. Visible if flipped == true. |
| backView | `() -> View` | Back view builder. Visible if flipped == false. |
| flipped | `Binding` | Binding which gives possiblity to flip the view. |
| flipAxis | `FlipAxis` | Rotation axis. `FlipAxis` have 4 defined values(`x`, `y`, `xy`, `custom(x: Double, y: Double)`). The custom value gives possiblity to declare your own axis. It has `x` default value when argument is not passed to the FlipView initializer. |
| perspective | `CGFloat` | The relative vanishing point. It has 0.5 default value when argument is not passed to the FlipView initializer. |
| animation | `AnimationDescription` | Defines the animation that takes place when flipping. Animation can be customized by setting duration and timing function (`linear`, `easeIn`, `easeOut`, `easeInOut`). It has `.init(type: .linear, duration: 0.25)` default value when argument is not passed to the FlipView initializer. |

```swift
public init(@ViewBuilder frontView: @escaping () -> ContentFront,
@ViewBuilder backView: @escaping () -> ContentBack,
flipped: Binding,
flipAxis: FlipAxis = .x,
perspective: CGFloat = 0.5,
animation: AnimationDescription = .default)
```

## Installation

Use `https://github.com/Zaprogramiacz/MGFlipView.git` link to add Swift Package to Xcode project

## License

[MIT License](LICENSE)

Copyright (c) 2020 Maciej Gomółka