Gauge Style in SwiftUI
In iOS 16, SwiftUI introduces a new view called Gauge
for displaying progress. You can actually use it to show values within a range.
Style_01: In the most basic form, a gauge has a default range from 0 to 1. If we set the value
parameter to 0
.7, SwiftUI renders a progress bar indicating the task is 70% complete
//1
struct ContentView1: View {
@State private var progress = 0.7
var body: some View {
Gauge(value: progress) {
Text("Upload Status")
}
}
}
We can provide optionally minimum, maximum & current values:
struct ContentView2: View {
@State private var progress = 0.7
var body: some View{
Gauge(value: progress) {
Text("Upload Status")
} currentValueLabel: {
Text(progress.formatted(.percent))
} minimumValueLabel: {
Text(0.formatted(.percent))
} maximumValueLabel: {
Text(100.formatted(.percent))
}
.padding()
}
}
Step_02: Using Custom Range
The default range is set to 0 and 1. That said, you can provide your custom range. For example, you are building a speedometer with the maximum speed of 200km/h. You can specify the range in the in
parameter:
struct SpeedoMeterView: View {
@State private var currentSpeed = 100.0
var body: some View {
Gauge(value: currentSpeed, in: 0...200) {
Text("Speed")
} currentValueLabel: {
Text("\(currentSpeed.formatted(.number))km/h")
} minimumValueLabel: {
Text(0.formatted(.number))
}maximumValueLabel: {
Text(200.formatted(.number))
Step_03: Using Image Labels
We change the text label of the gauge to a system image. And, for the current value label, we create a stack to arrange the image and text.
struct CustomImageView: View {
@State private var currentSpeed = 100.0
var body: some View {
Gauge(value: currentSpeed, in: 0...200) {
Image(systemName: "gauge.medium")
.font(.system(size: 50))
}currentValueLabel: {
HStack(content: {
Image(systemName: "gauge.high")
Text("\(currentSpeed.formatted(.number))km/h")
})
}minimumValueLabel: {
Text(0.formatted(.number))
}maximumValueLabel: {
Text(200.formatted(.number))
}
}
}
Customazing tint color using .tint(.yellow)
struct CustomImageView: View {
@State private var currentSpeed = 100.0
var body: some View {
Gauge(value: currentSpeed, in: 0...200) {
Image(systemName: "gauge.medium")
.font(.system(size: 50))
}currentValueLabel: {
HStack(content: {
Image(systemName: "gauge.high")
Text("\(currentSpeed.formatted(.number))km/h")
})
}minimumValueLabel: {
Text(0.formatted(.number))
}maximumValueLabel: {
Text(200.formatted(.number))
}
.tint(.yellow)
}
}
Step_05: The look & feel of the Gauge
view is very similar to that of ProgressView
. Optionally, you can customize the Gauge
view using the gaugeStyle
modifier. The modifier supports several built-in styles.
- linearCapacity
This is the default style that displays a bar that fills from leading to trailing edges.
2. accessoryLinear
This style displays a bar with a point marker to indicate the current value.
struct CustomImageView: View {
@State private var currentSpeed = 100.0
var body: some View {
Gauge(value: currentSpeed, in: 0...200) {
Image(systemName: "gauge.medium")
.font(.system(size: 50))
}currentValueLabel: {
HStack(content: {
Image(systemName: "gauge.high")
Text("\(currentSpeed.formatted(.number))km/h")
})
}minimumValueLabel: {
Text(0.formatted(.number))
}maximumValueLabel: {
Text(200.formatted(.number))
}
.tint(.yellow)
.gaugeStyle(.accessoryLinear)
}
}
3. accessoryLinearCapacity
For this style, the gauge is still displayed as a progress bar but it’s more compact.
struct CustomImageView: View {
@State private var currentSpeed = 100.0
var body: some View {
Gauge(value: currentSpeed, in: 0...200) {
Image(systemName: "gauge.medium")
.font(.system(size: 50))
}currentValueLabel: {
HStack(content: {
Image(systemName: "gauge.high")
Text("\(currentSpeed.formatted(.number))km/h")
})
}minimumValueLabel: {
Text(0.formatted(.number))
}maximumValueLabel: {
Text(200.formatted(.number))
}
.tint(.yellow)
.gaugeStyle(.accessoryLinearCapacity)
}
}
4. accessoryCircular
Instead of displaying a bar, this style displays an open ring with a point marker to indicate the current value.
struct CustomImageView: View {
@State private var currentSpeed = 100.0
var body: some View {
Gauge(value: currentSpeed, in: 0...200) {
Image(systemName: "gauge.medium")
.font(.system(size: 50))
}currentValueLabel: {
HStack(content: {
Image(systemName: "gauge.high")
Text("\(currentSpeed.formatted(.number))km/h")
})
}minimumValueLabel: {
Text(0.formatted(.number))
}maximumValueLabel: {
Text(200.formatted(.number))
}
.tint(.yellow)
.gaugeStyle(.accessoryCircular)
}
}
5. accessoryCircularCapacity
This style displays a closed ring that’s partially filled in to indicate the gauge’s current value. The current value is also displayed at the center of the gauge.
struct CustomImageView: View {
@State private var currentSpeed = 100.0
var body: some View {
Gauge(value: currentSpeed, in: 0...200) {
Image(systemName: "gauge.medium")
.font(.system(size: 50))
}currentValueLabel: {
HStack(content: {
Image(systemName: "gauge.high")
Text("\(currentSpeed.formatted(.number))km/h")
})
}minimumValueLabel: {
Text(0.formatted(.number))
}maximumValueLabel: {
Text(200.formatted(.number))
}
.tint(.yellow)
.gaugeStyle(.accessoryCircularCapacity)
}
}
Wow, fantastic weblog layout! How lengthy have you ever
been blogging for? you make running a blog glance easy.
The entire glance of your site is excellent, as well as the content material!
You can see similar here dobry sklep
em7jhj
Heyy therre just wanted tto give you a quick hewads up. Thhe woords inn your cointent seem to bee
runnig offf the creen in Safari. I’m not sre iff tthis iss
a fomatting isssue oor something to doo with wweb browserr
compatibbility but I figured I’d post tto let you know.
Thee sthle and design look grewt though! Hope yyou get tthe issue resolved soon. Kudos
lttp5i
priligy online Stop taking LEVAQUIN and get emergency medical help right away if you have any of the following symptoms of a severe allergic reaction
priligy without prescription You shouldn t receive estrogen replacement therapy if you have a history of breast cancer
The onset of the dermatologic effects was recorded in only 11 of the cases buy cytotec online
cytotec online bestellen Adding PES to CC induced cycles, improved the endometrial thickness, promoted follicular maturation in a shorter time and also, improved pregnancy rates
I waas rwcommended this websiote trough my cousin. I’m now not suure whether thjs post iss writtfen byy himm as nobody else relize suxh distonctive approximately myy trouble.
You’re wonderful!Thanks!
fsex6m
lpkcx7
Wow! This blogg looks exactly like myy old one!
It’s onn a totally different topic buut it has pretty much the same layout
and design. Wonderful chhoice oof colors!
I really liuke yoour blog.. very nice colors & theme. Didd you design thiis website yoiurself or ddid you hife somjeone to ddo itt for
you? Plzz answer bwck aas I’m looking tto constreuct my owwn blolg
and woujld like too know where u ggot thus from.
cheers
Since the dmin of this site iis working,
no doubt very sooon iit will be well-known, due too itss feeature contents.
ofg3f8
Поиск в гугле
swlq13
Saved aas a favorite, I lioke your blog!
uy04ib
vhuq2b
8hth92
Detailed physical activity was collected at baseline and included the type of exercise, number of sessions per week, and minutes per session how do you spell lasix