SwiftUI使用.timer更改Text的输出格式 没有解决方案=>解决方法代码 WidgetKit的局限性

问题描述

是否可以使用Text来更改init(_ date: Date,style: Text.DateStyle)输出格式?

使用.timer输出类似于:0:42,但是我想要类似00:00:42的东西。


背景

我想创建一个运行计时器的窗口小部件(iOS 14),并且我认为每秒触发一次窗口小部件更新不是一个好主意,这甚至可能也不可靠,至少不是这样缩进使用。 因此,我考虑使用Text的预定义计时器功能

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

或者换句话说:是否有办法自行创建可以在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的局限性

很遗憾,此方法不适用于WidgetKit,因为计时器不运行,或者至少UI不刷新。因此,我结束了,仅在窗口小部件中显示分钟(就我的目的而言还可以),并且只需在“时间轴”中为每分钟设置一个更新。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...