- July 11, 2025
- Mins Read
UITextField-based control for (NS)Measurement values input. Provides type-safe keyboard and picker based input of different measurements(such as length, mass, speed etc). See example app for API details.
First of all you need to import MeasurementTextField
:
import MeasurementTextField
Need text field for angle input? Just write:
let angleTextField = MeasurementTextField<UnitAngle>(inputType: .keyboard(.degrees))
Instead of UnitAngle
you can use any Dimension
type defined in Foundation or implement own Dimension
subclass if you need something special. Then to obtain Measurement value inputted by user just use value
property:
if let value = angleTextField.value {
let formatter = MeasurementFormatter()
print(“Your input is \(formatter.string(from: value))!”)
} else {
print(“You cleared the field!”)
}
Degrees input is not enough? Want also arc minutes and arc seconds? Just use another input type:
let angleTextField = MeasurementTextField<UnitAngle>(inputType: .picker([
PickerColumn(unit: UnitAngle.degrees, range: 0…360, step: 1.0), // `step` is optional here, 1.0 by default
PickerColumn(unit: UnitAngle.arcMinutes, range: 0…60),
PickerColumn(unit: UnitAngle.arcSeconds, range: 0…60),
]))
Need to be notified when value is changed? Just subscribe on UIControlEvents.valueChanged
:
@objc private func onAngleValueChanged() {
print(“Angle value was changed!”)
}
angleTextField.addTarget(self, action: #selector(onAngleValueChanged), for: .valueChanged)
To change text color of measurement unit label for .keyboard
input type just change tintColor
:
angleTextField.tintColor = .red
Want to remove it completely? Just pass showMeasureUnit: false
in input type configuration:
let angleTextField = MeasurementTextField<UnitAngle>(inputType: .keyboard(.degrees, showMeasureUnit: false))
Also be aware that MeasurementTextField
is an usual UITextField
, so you can use all APIs provided by it, except of textField(_:shouldChangeCharactersIn:replacementString:)
delegate method.
To run the example project, clone the repo, and run pod install
from the Example directory first.
If you need some feature or you found a bug feel free to open an issue.
MeasurementTextField is available through CocoaPods. To install it, simply add the following line to your Podfile:
pod ‘MeasurementTextField’
A SwiftUI View that emits confetti with user-defined shapes, images, and text.
A colour wheel made all in SwiftUI. There are 2 different colour wheels to choose from. The first main one ...
A color picker implementation with color wheel appearance written in plain SwiftUI. It is compatible with UIColor and NSColor.
This repository is no longer maintained. Here's why: with the release of iOS 16 SwiftUI now enables most of the ...