Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yonat/MultiSelectSegmentedControl
UISegmentedControl remake that supports selecting multiple segments, vertical stacking, combining text and images.
https://github.com/yonat/MultiSelectSegmentedControl
selected-segments selection uisegmentedcontrol
Last synced: about 2 months ago
JSON representation
UISegmentedControl remake that supports selecting multiple segments, vertical stacking, combining text and images.
- Host: GitHub
- URL: https://github.com/yonat/MultiSelectSegmentedControl
- Owner: yonat
- License: mit
- Created: 2013-04-20T12:48:41.000Z (almost 12 years ago)
- Default Branch: master
- Last Pushed: 2024-11-01T14:11:53.000Z (3 months ago)
- Last Synced: 2024-11-28T17:17:16.421Z (about 2 months ago)
- Topics: selected-segments, selection, uisegmentedcontrol
- Language: Swift
- Homepage:
- Size: 362 KB
- Stars: 300
- Watchers: 12
- Forks: 60
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-ios - MultiSelectSegmentedControl - adds Multiple-Selection to the standard `UISegmentedControl`. (UI / Segmented Control)
- awesome-swift - MultiSelectSegmentedControl - UISegmentedControl remake that supports selecting multiple segments, vertical stacking, combining text and images. (Libs / UI)
- awesome-swift - MultiSelectSegmentedControl - UISegmentedControl remake that supports selecting multiple segments, vertical stacking, combining text and images. (Libs / UI)
- awesome-ios-star - MultiSelectSegmentedControl - adds Multiple-Selection to the standard `UISegmentedControl`. (UI / Segmented Control)
- fucking-awesome-swift - MultiSelectSegmentedControl - UISegmentedControl remake that supports selecting multiple segments, vertical stacking, combining text and images. (Libs / UI)
- awesome-swift - MultiSelectSegmentedControl - UISegmentedControl remake that supports selecting multiple segments, vertical stacking, combining text and images. ` 📝 4 months ago ` (UI [🔝](#readme))
README
# MultiSelectSegmentedControl
[![Swift Version][swift-image]][swift-url]
[![Build Status][travis-image]][travis-url]
[![License][license-image]][license-url]
[![CocoaPods Compatible](https://img.shields.io/cocoapods/v/MultiSelectSegmentedControl.svg)](https://img.shields.io/cocoapods/v/MultiSelectSegmentedControl.svg)
[![Platform](https://img.shields.io/cocoapods/p/MultiSelectSegmentedControl.svg?style=flat)](http://cocoapods.org/pods/MultiSelectSegmentedControl)
[![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat-square)](http://makeapullrequest.com)UISegmentedControl remake that supports selecting multiple segments, vertical stacking, combining text and images.
## Features
- [x] Single or multiple selection.
- [x] Horizontal or vertical stacking.
- [x] Can show text and images together.
- [x] Use from either storyboard or code.
- [x] UIAppearance support.## Usage
Very similar to `UISegmentedControl`, can be used as a drop-in replacement in most cases.
If you use Interface Builder, add a regular `UIView` and then set its class to `MultiSelectSegmentedControl`.
### SwiftUI Usage
```swift
MultiSegmentPicker(
selectedSegmentIndexes: $indexSet,
items: ["One", "Two", image, [image2, "Text"], "Last"]
)
```The properties mentioned below can be passed as arguments to the `MultiSegmentPicker` initializer, or used as view modifiers (e.g., `.borderWidth(3)`).
### Creating Segments
Each segment can contain an image, a text, or both:
```swift
let multiSelect = MultiSelectSegmentedControl()
multiSelect.items = ["One", "Two", image, [image2, "Text"], "Last"]
```Images are shown in full color (unlike `UISegmentedControl`). To make them render in the same `tintColor` as the control, use template mode:
```swift
multiSelect.items = [image1, image2, image3].map { $0.withRenderingMode(.alwaysTemplate) }
```### Selecting Segments
```swift
multiSelect.selectedSegmentIndexes = [1, 2, 4]
```Or just single selection:
```swift
multiSelect.allowsMultipleSelection = false
multiSelect.selectedSegmentIndex = 3
```### Getting Selected Segments
```swift
let selectedIndices: IndexSet = multiSelect.selectedSegmentIndexes
```Or to get the titles:
```swift
let titles: [String] = multiSelect.selectedSegmentTitles
```### Handling User Selection Changes
You can use standard target-action:
```swift
multiSelect.addTarget(self, action: #selector(selectionChanged), for: .valueChanged)
```Or conform to the delegate protocol:
```swift
extension MyViewController: MultiSelectSegmentedControlDelegate {
func multiSelect(_ multiSelectSegmentedControl: MultiSelectSegmentedControl, didChange value: Bool, at index: Int) {
print("selected \(value) at \(index)")
}
}
```... and set the delegate:
```swift
multiSelect.delegate = self
```### Changing Appearance
Color:
```swift
multiSelect.tintColor = .green
```Background Color (optional - use if background color should be different from tint color):
```swift
multiSelect.selectedBackgroundColor = .blue
```Shape:
```swift
multiSelect.borderWidth = 3 // Width of the dividers between segments and the border around the view.
multiSelect.borderRadius = 32 // Corner radius of the view.
```Stack the segments vertically:
```swift
multiSelect.isVertical = true
```Stack each segment contents vertically when it contains both image and text:
```swift
multiSelect.isVerticalSegmentContents = true
```Text styling:
```swift
multiSelect.setTitleTextAttributes([.foregroundColor: UIColor.yellow], for: .selected)
multiSelect.setTitleTextAttributes([.obliqueness: 0.25], for: .normal)
```More label styling:
```swift
multiSelect.titleConfigurationHandler = {
$0.numberOfLines = 0
$0.lineBreakMode = .byWordWrapping
}
```## Installation
### CocoaPods:
```ruby
pod 'MultiSelectSegmentedControl'
```### Swift Package Manager:
```swift
dependencies: [
.package(url: "https://github.com/yonat/MultiSelectSegmentedControl", from: "2.4.1")
]
```## TODO
- [ ] foreground color of selected segment should be/appear transparent
- [ ] configure segment `layoutMargins`, `stackView.spacing`## Meta
[@yonatsharon](https://twitter.com/yonatsharon)
[https://github.com/yonat/MultiSelectSegmentedControl](https://github.com/yonat/MultiSelectSegmentedControl)
[swift-image]:https://img.shields.io/badge/swift-5.0-orange.svg
[swift-url]: https://swift.org/
[license-image]: https://img.shields.io/badge/License-MIT-blue.svg
[license-url]: LICENSE.txt
[travis-image]: https://img.shields.io/travis/dbader/node-datadog-metrics/master.svg?style=flat-square
[travis-url]: https://travis-ci.org/dbader/node-datadog-metrics