Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kmcgill88/McPicker-iOS
McPicker is a customizable, closure driven UIPickerView drop-in solution with animations that is rotation ready.
https://github.com/kmcgill88/McPicker-iOS
animation inputview ios ipad iphone pickerview popover swift swift-framework uipickerview uitoolbar
Last synced: about 2 months ago
JSON representation
McPicker is a customizable, closure driven UIPickerView drop-in solution with animations that is rotation ready.
- Host: GitHub
- URL: https://github.com/kmcgill88/McPicker-iOS
- Owner: kmcgill88
- License: mit
- Created: 2017-03-23T02:18:50.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2023-09-28T15:41:08.000Z (over 1 year ago)
- Last Synced: 2024-05-01T15:01:05.586Z (9 months ago)
- Topics: animation, inputview, ios, ipad, iphone, pickerview, popover, swift, swift-framework, uipickerview, uitoolbar
- Language: Swift
- Homepage:
- Size: 136 KB
- Stars: 214
- Watchers: 9
- Forks: 42
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-ios - McPicker - A customizable, closure driven UIPickerView drop-in solution with animations that is rotation ready. (UI / PickerView)
- awesome-ios-star - McPicker - A customizable, closure driven UIPickerView drop-in solution with animations that is rotation ready. (UI / PickerView)
- awesome-swift-lib-hunt - McPicker - Easy to use and very useful pickerview, also it is customizable (UI)
- awesome-swift-lib-hunt - McPicker - Easy to use and very useful pickerview, also it is customizable (UI)
README
# McPicker
[![Build Status](https://travis-ci.org/kmcgill88/McPicker-iOS.svg?branch=master)](https://travis-ci.org/kmcgill88/McPicker-iOS)
[![Version](https://img.shields.io/cocoapods/v/McPicker.svg?style=flat)](http://cocoapods.org/pods/McPicker)
[![License](https://img.shields.io/cocoapods/l/McPicker.svg?style=flat)](http://cocoapods.org/pods/McPicker)
[![Platform](https://img.shields.io/cocoapods/p/McPicker.svg?style=flat)](http://cocoapods.org/pods/McPicker)## About
McPicker is a UIPickerView drop-in solution with animations that is rotation ready. The more string arrays you pass, the more picker components you'll get. You can set custom label or use the defaults. McPicker can be presented as a Popover on iPhone or iPad using `showAsPopover`, as an `inputView` using `McTextField` or use the default slide up and down style `show`.`showAsPopover` can be used to display from a `UIView` or `UIBarButtonItem`. `showAsPopover` will always be presented as a Popover, even when used on an iPhone.
## Usage
To run the example project, clone the repo, and run `pod install` from the Example directory first.![](https://mcgilldevtech.com/img/github/mcpicker/mcpicker-1.0.0-3.gif)
#### Short Syntax
- Normal - (Slide up from bottom)
```swift
McPicker.show(data: [["Kevin", "Lauren", "Kibby", "Stella"]]) { [weak self] (selections: [Int : String]) -> Void in
if let name = selections[0] {
self?.label.text = name
}
}
```
- As Popover
```swift
let data: [[String]] = [["Kevin", "Lauren", "Kibby", "Stella"]]
McPicker.showAsPopover(data: data, fromViewController: self, barButtonItem: sender) { [weak self] (selections: [Int : String]) -> Void in
if let name = selections[0] {
self?.label.text = name
}
}
```
- As an `inputView` via `McTextField`
```swift
@IBOutlet weak var mcTextField: McTextField!
override func viewDidLoad() {
let data: [[String]] = [["Kevin", "Lauren", "Kibby", "Stella"]]
let mcInputView = McPicker(data: data)
mcInputView.backgroundColor = .gray
mcInputView.backgroundColorAlpha = 0.25
mcTextField.inputViewMcPicker = mcInputViewmcTextField.doneHandler = { [weak mcTextField] (selections) in
mcTextField?.text = selections[0]!
}
mcTextField.selectionChangedHandler = { [weak mcTextField] (selections, componentThatChanged) in
mcTextField?.text = selections[componentThatChanged]!
}
mcTextField.cancelHandler = { [weak mcTextField] in
mcTextField?.text = "Cancelled."
}
mcTextField.textFieldWillBeginEditingHandler = { [weak mcTextField] (selections) in
if mcTextField?.text == "" {
// Selections always default to the first value per component
mcTextField?.text = selections[0]
}
}
}
```#### Customization
```swift
let data: [[String]] = [
["Sir", "Mr", "Mrs", "Miss"],
["Kevin", "Lauren", "Kibby", "Stella"]
]
let mcPicker = McPicker(data: data)let customLabel = UILabel()
customLabel.textAlignment = .center
customLabel.textColor = .white
customLabel.font = UIFont(name:"American Typewriter", size: 30)!
mcPicker.label = customLabel // Set your custom labellet fixedSpace = McPickerBarButtonItem.fixedSpace(width: 20.0)
let flexibleSpace = McPickerBarButtonItem.flexibleSpace()
let fireButton = McPickerBarButtonItem.done(mcPicker: mcPicker, title: "Fire!!!") // Set custom Text
let cancelButton = McPickerBarButtonItem.cancel(mcPicker: mcPicker, barButtonSystemItem: .cancel) // or system items
// Set custom toolbar items
mcPicker.setToolbarItems(items: [fixedSpace, cancelButton, flexibleSpace, fireButton, fixedSpace])mcPicker.toolbarItemsFont = UIFont(name:"American Typewriter", size: 17)!
mcPicker.toolbarButtonsColor = .white
mcPicker.toolbarBarTintColor = .darkGray
mcPicker.backgroundColor = .gray
mcPicker.backgroundColorAlpha = 0.50
mcPicker.pickerBackgroundColor = .gray
mcPicker.pickerSelectRowsForComponents = [
0: [3: true],
1: [2: true] // [Component: [Row: isAnimated]
]if let barButton = sender as? UIBarButtonItem {
// Show as Popover
//
mcPicker.showAsPopover(fromViewController: self, barButtonItem: barButton) { [weak self] (selections: [Int : String]) -> Void in
if let prefix = selections[0], let name = selections[1] {
self?.label.text = "\(prefix) \(name)"
}
}
} else {
// Show Normal
//
mcPicker.show(doneHandler: { [weak self] (selections: [Int : String]) -> Void in
if let prefix = selections[0], let name = selections[1] {
self?.label.text = "\(prefix) \(name)"
}
}, cancelHandler: {
print("Canceled Styled Picker")
}, selectionChangedHandler: { (selections: [Int:String], componentThatChanged: Int) -> Void in
let newSelection = selections[componentThatChanged] ?? "Failed to get new selection!"
print("Component \(componentThatChanged) changed value to \(newSelection)")
})
}
```##### The `selections`
McPicker's `doneHandler` passes back `selections: [Int : String]` as an argument. This is as simple as `[: ]` from the `data` you've passed in.## Requirements
- iOS 8+
- Swift 5.2
- Xcode 12> __Note__: Starting in 0.5.1 McPicker uses the Swift 4 Compiler. [Ensure the correct compiler is set in your project.](https://github.com/kmcgill88/McPicker-iOS/issues/23). If you'd like to use Swift 3 use version <=0.5.0.
## Installation
McPicker is available through [CocoaPods](http://cocoapods.org). To install
it, simply add the following line to your Podfile:```ruby
pod "McPicker"
```### Xcode 12+ - Swift 5.2 Support
```ruby
pod 'McPicker', '~> 3.0.0'
```### Swift 4.2 Support
For Swift 4.2 support, please use version `2.0.0`.
```ruby
pod 'McPicker', '~> 2.0.0'
```## Author
Kevin McGill, [email protected]
## License
McPicker is available under the MIT license. See the LICENSE file for more info.