4

有没有办法改变Textusing的输出格式init(_ date: Date, style: Text.DateStyle)

使用 a .timer,输出类似于:0:42,但我想要类似00:00:42.


背景

我想创建一个正在运行计时器的小部件(iOS 14),因为我认为每秒触发小部件更新并不是一个好主意,这甚至可能也无法可靠地工作,至少小部件不是这样缩进的要使用的。所以我想到了使用这个预定义的计时器功能Text

我对 SwiftUI 很陌生,还不太了解所有功能。所以也许我可以自己创建一个类似的自定义文本视图?关于如何实现这一目标的任何想法?

或者换一种方式问:有没有办法自己创建这样的自我更新组件,也可以在 iOS 14 小部件中使用?(似乎Timer.publish用于更新视图在 iOS 14 小部件中不起作用)

4

1 回答 1

0

没有解决方案 => 解决方法

截至今天,似乎没有适当的解决方案。但是由于对“解决方案”或解决方法的兴趣似乎存在,所以我现在只发布我最终得到的结果。

代码

基本上我只是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 没有刷新。所以我最终只在小部件中显示分钟(这对我的目的来说还可以),并且只是在“时间线”中为每分钟设置一个更新。

于 2020-09-18T06:58:43.173 回答