微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决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不刷新。因此,我结束了,仅在窗口小部件中显示分钟(就我的目的而言还可以),并且只需在“时间轴”中为每分钟设置一个更新。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。