Skip to content

svilon/SmartSegmentedControlSwift

Repository files navigation

SmartSegmentedControlSwift

Version License Platform

This control was created to solve issue, that native UISegmentedControl has. Reffer to SmartSegmentedControl for obj-c version. UISegmentedControl has issue with apportionsSegmentWidthsByContent setting (adjust segments width proportionally to content). Often, it appears that control bounds are wider, than actual segments width. See screenshot bellow - I put yellow color as layer background.

UISegmentedControl

With SmartSegmentedControl issue is fixed and same segmented control will look like:

SmartSegmentedControl

Also, SmartSegmentedControl introduces “smart” mode, where, if there is enough room, every segment, that needs to be wider than average width, gets enough room to display content (which is usually less then in proportional mode). If there is no enough room for all content - segments width is distributed proportionally (fixed, of course :) ).

NOTE. SmartSegmentedControl is designed and test only to work with segments with titles, not with images.

Usage

SmartSegmentedControl provides two new properties to adjust it's behaviour:

  • @IBInspectable public var fixNativeProportionalSizing: Bool = false
  • @IBInspectable public var smartAdjustment: Bool = false

As you can see, you can change them in runtime, or configure in IB.

Example

To run the example project, clone the repo, and run pod install from the Example directory first.

Requirements

Installation

SmartSegmentedControlSwift is available through CocoaPods. To install it, simply add the following line to your Podfile:

pod "SmartSegmentedControlSwift"

License

SmartSegmentedControlSwift is available under the MIT license. See the LICENSE file for more info.

About

UISegmentedControl replacement which provides more accurate segments width management

Resources

License

Stars

Watchers

Forks

Packages

No packages published