当 SwiftUI 小部件的相对文本字段计数器为零时停止?
Stopping a SwiftUI Widget's relative textfield counter when hits zero?
我正在创建一个 Widget,它有一个从日期开始倒计时的文本字段,如下所示:
Text(endDate, style: .relative)
这很好用,但是作为它的相对值,一旦它达到零,它会随着结束日期变成过去而继续重新计数。
有没有办法在文本达到零时终止文本?还是我必须用计时器重建此功能?
我需要做的就是从开始日期到结束日期倒计时,然后使文本字段无效或显示一条消息。
我认为您必须在时间为零时安排小部件更新,并有条件在时间小于零时将其隐藏。
这里是创建倒计时的方法,当时间结束时显示一些其他文本。
- 创建一个条目,其中
endDate
是可选的 - 如果它是 nil
则意味着倒计时结束:
struct SimpleEntry: TimelineEntry {
let date: Date
var endDate: Date?
}
- 在您的提供程序中创建两个条目 - 一个用于 倒计时 时间,一个用于倒计时结束时:
struct SimpleProvider: TimelineProvider {
...
func getTimeline(in context: Context, completion: @escaping (Timeline<SimpleEntry>) -> Void) {
let currentDate = Date()
let endDate = Calendar.current.date(byAdding: .second, value: 15, to: currentDate)!
let entries = [
SimpleEntry(date: currentDate, endDate: endDate),
SimpleEntry(date: endDate),
]
let timeline = Timeline(entries: entries, policy: .never)
completion(timeline)
}
}
- 在您的视图中使用它:
struct WidgetEntryView: View {
var entry: Provider.Entry
var body: some View {
if let endDate = entry.endDate {
Text(endDate, style: .relative)
} else {
Text("Timer finished")
}
}
}
我正在创建一个 Widget,它有一个从日期开始倒计时的文本字段,如下所示:
Text(endDate, style: .relative)
这很好用,但是作为它的相对值,一旦它达到零,它会随着结束日期变成过去而继续重新计数。
有没有办法在文本达到零时终止文本?还是我必须用计时器重建此功能?
我需要做的就是从开始日期到结束日期倒计时,然后使文本字段无效或显示一条消息。
我认为您必须在时间为零时安排小部件更新,并有条件在时间小于零时将其隐藏。
这里是创建倒计时的方法,当时间结束时显示一些其他文本。
- 创建一个条目,其中
endDate
是可选的 - 如果它是nil
则意味着倒计时结束:
struct SimpleEntry: TimelineEntry {
let date: Date
var endDate: Date?
}
- 在您的提供程序中创建两个条目 - 一个用于 倒计时 时间,一个用于倒计时结束时:
struct SimpleProvider: TimelineProvider {
...
func getTimeline(in context: Context, completion: @escaping (Timeline<SimpleEntry>) -> Void) {
let currentDate = Date()
let endDate = Calendar.current.date(byAdding: .second, value: 15, to: currentDate)!
let entries = [
SimpleEntry(date: currentDate, endDate: endDate),
SimpleEntry(date: endDate),
]
let timeline = Timeline(entries: entries, policy: .never)
completion(timeline)
}
}
- 在您的视图中使用它:
struct WidgetEntryView: View {
var entry: Provider.Entry
var body: some View {
if let endDate = entry.endDate {
Text(endDate, style: .relative)
} else {
Text("Timer finished")
}
}
}