没有解决方案 => 解决方法
截至今天,似乎没有适当的解决方案。但是由于对“解决方案”或解决方法的兴趣似乎存在,所以我现在只发布我最终得到的结果。
代码
基本上我只是Text
每秒手动更新一次,并计算从参考日期到“现在”的差异。
struct SomeView: View {
let referenceDate = Date() // <- Put your start date here
@State var duration: Int = 0
let timer = Timer.publish(every: 1, on: .current, in: .common).autoconnect()
var body: some View {
Text(self.duration.formatted(allowedUnits: [.hour, .minute, .second]) ?? "")
.onReceive(self.timer) { _ in
self.duration = referenceDate.durationToNow ?? 0
}
}
}
extension Date {
var durationToNow: Int? {
return Calendar.current
.dateComponents([.second], from: self, to: Date())
.second
}
}
extension Int {
func formatted(allowedUnits: NSCalendar.Unit = [.hour, .minute]) -> String? {
let formatter = DateComponentsFormatter()
formatter.allowedUnits = allowedUnits
formatter.zeroFormattingBehavior = .pad
return formatter.string(from: DateComponents(second: self))
}
}
WidgetKit 限制
不幸的是,这不适用于WidgetKit
,因为计时器没有运行,或者至少 UI 没有刷新。所以我最终只在小部件中显示分钟(这对我的目的来说还可以),并且只是在“时间线”中为每分钟设置一个更新。