Я работаю над независимым приложением WatchOS, и я искал лучшее решение для постоянных данных локально и имею онлайн -синхронизацию с хранилищем iCloud. Затем я хотел подключить данные к контейнерам iCloud, чтобы я взял CloudKit. Я тестирую подход с помощью TestFlight Builds для моего приложения WatchOS, но я не вижу никаких записей, сохраняемых в контейнере iCloud. Это работает без проблем. Я вижу загруженные данные (в контейнере iCloud) из iOS, а также в приложении iOS при создании записи из консоли CloudKit. К сожалению, это не так для моего приложения WatchOS. < /P>
@Model
final class Item {
var timestamp: Date = Date()
init(timestamp: Date) {
self.timestamp = timestamp
}
}
@main
struct TestApp: App {
var sharedModelContainer: ModelContainer = {
let schema = Schema([
Item.self,
])
let modelConfiguration = ModelConfiguration(schema: schema, isStoredInMemoryOnly: false)
do {
return try ModelContainer(for: schema, configurations: [modelConfiguration])
} catch {
fatalError("Could not create ModelContainer: \(error)")
}
}()
var body: some Scene {
WindowGroup {
ContentView()
}
.modelContainer(sharedModelContainer)
}
}
struct ContentView: View {
@Environment(\.modelContext) private var modelContext
@Query private var items: [Item]
var body: some View {
NavigationSplitView {
List {
ForEach(items) { item in
NavigationLink {
Text("Item at \(item.timestamp, format: Date.FormatStyle(date: .numeric, time: .standard))")
} label: {
Text(item.timestamp, format: Date.FormatStyle(date: .numeric, time: .standard))
}
}
.onDelete(perform: deleteItems)
}
.toolbar {
ToolbarItem(placement: .navigationBarTrailing) {
EditButton()
}
ToolbarItem {
Button(action: addItem) {
Label("Add Item", systemImage: "plus")
}
}
}
} detail: {
Text("Select an item")
}
}
private func addItem() {
withAnimation {
let newItem = Item(timestamp: Date())
modelContext.insert(newItem)
}
}
private func deleteItems(offsets: IndexSet) {
withAnimation {
for index in offsets {
modelContext.delete(items[index])
}
}
}
}
< /code>
Код выше выше, в основном пример, предоставленный Xcode для приложения, используя CloudKit, и он очень хорошо работает для приложения iOS. /> push -уведомления < /li>
< /ol>
Я что -то пропустил при настройке настройки? Я подумал, что если Apple предоставит SwiftData и CloudKit, это будет выглядеть одинаково между платформами с точки зрения логики. Я не могу найти ничего еще для настройки SwiftData + CloudKit для независимого приложения WatchOS.
Подробнее здесь: https://stackoverflow.com/questions/797 ... -swiftdata
Синхронизация не работает для независимого приложения WatchOS с использованием CloudKit и SwiftData ⇐ IOS
Программируем под IOS
1756641835
Anonymous
Я работаю над независимым приложением WatchOS, и я искал лучшее решение для постоянных данных локально и имею онлайн -синхронизацию с хранилищем iCloud. Затем я хотел подключить данные к контейнерам iCloud, чтобы я взял CloudKit. Я тестирую подход с помощью TestFlight Builds для моего приложения WatchOS, но я не вижу никаких записей, сохраняемых в контейнере iCloud. Это работает без проблем. Я вижу загруженные данные (в контейнере iCloud) из iOS, а также в приложении iOS при создании записи из консоли CloudKit. К сожалению, это не так для моего приложения WatchOS. < /P>
@Model
final class Item {
var timestamp: Date = Date()
init(timestamp: Date) {
self.timestamp = timestamp
}
}
@main
struct TestApp: App {
var sharedModelContainer: ModelContainer = {
let schema = Schema([
Item.self,
])
let modelConfiguration = ModelConfiguration(schema: schema, isStoredInMemoryOnly: false)
do {
return try ModelContainer(for: schema, configurations: [modelConfiguration])
} catch {
fatalError("Could not create ModelContainer: \(error)")
}
}()
var body: some Scene {
WindowGroup {
ContentView()
}
.modelContainer(sharedModelContainer)
}
}
struct ContentView: View {
@Environment(\.modelContext) private var modelContext
@Query private var items: [Item]
var body: some View {
NavigationSplitView {
List {
ForEach(items) { item in
NavigationLink {
Text("Item at \(item.timestamp, format: Date.FormatStyle(date: .numeric, time: .standard))")
} label: {
Text(item.timestamp, format: Date.FormatStyle(date: .numeric, time: .standard))
}
}
.onDelete(perform: deleteItems)
}
.toolbar {
ToolbarItem(placement: .navigationBarTrailing) {
EditButton()
}
ToolbarItem {
Button(action: addItem) {
Label("Add Item", systemImage: "plus")
}
}
}
} detail: {
Text("Select an item")
}
}
private func addItem() {
withAnimation {
let newItem = Item(timestamp: Date())
modelContext.insert(newItem)
}
}
private func deleteItems(offsets: IndexSet) {
withAnimation {
for index in offsets {
modelContext.delete(items[index])
}
}
}
}
< /code>
Код выше выше, в основном пример, предоставленный Xcode для приложения, используя CloudKit, и он очень хорошо работает для приложения iOS. /> push -уведомления < /li>
< /ol>
Я что -то пропустил при настройке настройки? Я подумал, что если Apple предоставит SwiftData и CloudKit, это будет выглядеть одинаково между платформами с точки зрения логики. Я не могу найти ничего еще для настройки SwiftData + CloudKit для независимого приложения WatchOS.
Подробнее здесь: [url]https://stackoverflow.com/questions/79751738/sync-not-working-for-independent-watchos-app-using-cloudkit-and-swiftdata[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия