是否有方法使用init(_ date: Date, style: Text.DateStyle)
更改Text
的输出格式?
使用.timer
,输出类似于:0:42
,但我想要类似于00:00:42
的东西。
背景
我想创建一个运行计时器的小部件(iOS 14(,因为我认为每秒触发一次小部件更新不是一个好主意,而且这可能也不可靠,至少小部件不是这样缩进使用的。因此,我考虑使用Text
的预定义计时器功能。
我是SwiftUI的新手,还不知道所有的功能。所以也许我可以自己创建一个类似的自定义文本视图?关于如何实现这一点,有什么想法吗?
或者问:有没有一种方法可以自己创建这样的自我更新组件,也可以在iOS 14小部件中工作?(似乎使用Timer.publish
更新视图在iOS 14小部件中不起作用(
无解决方案=>变通办法
到今天为止,似乎还没有一个合适的解决方案。但作为对";解决方案";或者解决这个问题的方法似乎已经存在,我现在只发布我最终得到的结果。
代码
基本上我只是手动地每秒更新一次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
不起作用,因为计时器没有运行,或者至少UI没有刷新。所以我最终只在小部件中显示分钟(这对我来说有点好(,并在";时间线";每分钟。