Я пишу независимое приложение для Apple Watch. Структура выглядит следующим образом: class HostingController
вызывает class ContentView
, class ContentView
имеет экземпляр EventFetcher
, объявленный как @ObservedObject var ef: EventFetcher = EventFetcher()
. Ниже класса EventFecthcer
public class EventFetcher: ObservableObject{
@Published var eventi = [EventoWK]()
init(){
load()
}
func load() {
---decoding items from JSON
}
}
Данные декодируются и загружаются прямо в мой список. Я хочу перезагрузить список, делая фоновый запрос. Я следую инструкциям, указанным в документации здесь Документация Apple . Это мой код для выполнения фонового запроса в классе ExtensionDelegate:
import WatchKit
class ExtensionDelegate: NSObject, WKExtensionDelegate, URLSessionDelegate {
func applicationDidFinishLaunching() {
// Perform any final initialization of your application.
}
func applicationDidBecomeActive() {
// Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface.
}
func applicationWillResignActive() {
// Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state.
// Use this method to pause ongoing tasks, disable timers, etc.
}
func handle(_ backgroundTasks: Set<WKRefreshBackgroundTask>) {
// Sent when the system needs to launch the application in the background to process tasks. Tasks arrive in a set, so loop through and process each one.
for task in backgroundTasks {
// Use a switch statement to check the task type
switch task {
case let backgroundTask as WKApplicationRefreshBackgroundTask:
// Be sure to complete the background task once you’re done.
backgroundTask.setTaskCompletedWithSnapshot(false)
case let snapshotTask as WKSnapshotRefreshBackgroundTask:
// Snapshot tasks have a unique completion call, make sure to set your expiration date
snapshotTask.setTaskCompleted(restoredDefaultState: true, estimatedSnapshotExpiration: Date.distantFuture, userInfo: nil)
case let connectivityTask as WKWatchConnectivityRefreshBackgroundTask:
// Be sure to complete the connectivity task once you’re done.
connectivityTask.setTaskCompletedWithSnapshot(false)
case let urlSessionTask as WKURLSessionRefreshBackgroundTask:
// Be sure to complete the URL session task once you’re done.
urlSessionTask.setTaskCompletedWithSnapshot(false)
case let relevantShortcutTask as WKRelevantShortcutRefreshBackgroundTask:
// Be sure to complete the relevant-shortcut task once you're done.
relevantShortcutTask.setTaskCompletedWithSnapshot(false)
case let intentDidRunTask as WKIntentDidRunRefreshBackgroundTask:
// Be sure to complete the intent-did-run task once you're done.
intentDidRunTask.setTaskCompletedWithSnapshot(false)
default:
// make sure to complete unhandled task types
task.setTaskCompletedWithSnapshot(false)
}
}
}
func loadInBackground(){
let url = URL(string: "https://myserver/mypath/myfile.json")!
let backgroundSessionConfig : URLSessionConfiguration = URLSessionConfiguration.background(withIdentifier: "it.myserver.bgt")
let bgsession: URLSession = URLSession(configuration: backgroundSessionConfig,delegate: self, delegateQueue: OperationQueue.main)
let task = bgsession.downloadTask(with: url) { localURL, urlResponse, error in
if let localURL = localURL {
if let string = try? String(contentsOf: localURL) {
print(string)
}
}
}
task.resume()
}// loadInBackground
}
Пункты 5 и 6 документации Apple по предыдущей ссылке указывают «Реализация дескриптора делегата расширения WatchKit (_ :) метод для ответа (и выполнения) фоновой задачи WatchKit. " Но если положить вызов метода loadInBackground в метод handle, это не сработает. И тогда они предлагают реализовать «методы делегата сеанса для получения данных». Мне интересно, как реализовать этот фоновый сеанс, чтобы сделать мой запрос и обновить мои данные для пользователя. Я сделал в своем коде шаги с 1 по 4, но как и когда должен вызываться метод loadInBackground () для обновления списка? Спасибо, любая помощь в понимании механизма сессии приветствуется.