外观更改时更新小部件
Update Widget when appearance changes
我想知道你们中是否有人知道 SwiftUI 中的系统可以在外观从 light
模式更改为 dark
模式时更新 Widget,反之亦然。
我可以更改文本和图像,但我使用一种方法来显示地图的屏幕截图,每次外观更改时我都应该运行它以获得正确的地图颜色。
- 创建两个屏幕截图(每个主题一个)并将其传递到条目中:
struct SimpleEntry: TimelineEntry {
let date: Date
let mapScreenshots: [ColorScheme: Image]
}
struct Provider: TimelineProvider {
...
func getTimeline(in context: Context, completion: @escaping (Timeline<SimpleEntry>) -> Void) {
let entry = SimpleEntry(
date: Date(),
mapScreenshots: [
// replace with actual map screenshots
.dark: Image(systemName: "plus"),
.light: Image(systemName: "minus"),
]
)
let timeline = Timeline(entries: [entry], policy: .never)
completion(timeline)
}
}
- 使用
@Environment(\.colorScheme)
响应主题变化:
struct WidgetEntryView: View {
@Environment(\.colorScheme) var colorScheme
var entry: Provider.Entry
var body: some View {
if let screenshot = entry.mapScreenshots[colorScheme] {
screenshot
}
}
}
我想知道你们中是否有人知道 SwiftUI 中的系统可以在外观从 light
模式更改为 dark
模式时更新 Widget,反之亦然。
我可以更改文本和图像,但我使用一种方法来显示地图的屏幕截图,每次外观更改时我都应该运行它以获得正确的地图颜色。
- 创建两个屏幕截图(每个主题一个)并将其传递到条目中:
struct SimpleEntry: TimelineEntry {
let date: Date
let mapScreenshots: [ColorScheme: Image]
}
struct Provider: TimelineProvider {
...
func getTimeline(in context: Context, completion: @escaping (Timeline<SimpleEntry>) -> Void) {
let entry = SimpleEntry(
date: Date(),
mapScreenshots: [
// replace with actual map screenshots
.dark: Image(systemName: "plus"),
.light: Image(systemName: "minus"),
]
)
let timeline = Timeline(entries: [entry], policy: .never)
completion(timeline)
}
}
- 使用
@Environment(\.colorScheme)
响应主题变化:
struct WidgetEntryView: View {
@Environment(\.colorScheme) var colorScheme
var entry: Provider.Entry
var body: some View {
if let screenshot = entry.mapScreenshots[colorScheme] {
screenshot
}
}
}