1

公開されたアプリがあり、コア データ ストアからのデータが取り込まれたテーブルをウォッチに表示するだけのウォッチ拡張機能を構築したいと考えています。今のところ非常に簡単です。だから私は基本的に私のアプリtableviewcontrollerにあるコードをwatch拡張用に修正して使用しようとしました。アプリ グループを配置し、アプリとウォッチ拡張機能の両方がアクセスできるコア データ クラスを作成しました。デバッグ ログに基づいてウォッチ拡張機能で正常に動作しているように見えますが、ウォッチでアプリを実行すると、ウォッチ テーブルにデータが取得されません。コードとデバッグ ログは次のとおりです。

InterfaceController.h

#import <WatchKit/WatchKit.h>
#import <Foundation/Foundation.h>
#import "CoreDataHelper.h"

@interface InterfaceController : WKInterfaceController

@property (strong, nonatomic) IBOutlet WKInterfaceTable *table;
@property (strong, nonatomic) NSArray *objects;

@end

InterfaceController.m:

#import "InterfaceController.h"
#import "ScheduleTableRow.h"

@interface InterfaceController()

@end

@implementation InterfaceController

@synthesize objects; 

- (void)awakeWithContext:(id)context {
[super awakeWithContext:context];

// Configure interface objects here.

NSManagedObjectContext * managedContext = [[CoreDataHelper sharedHelper] context];

NSEntityDescription *entity = [NSEntityDescription entityForName:@"Cschedule" inManagedObjectContext:managedContext];

NSManagedObject *object = [[NSManagedObject alloc] initWithEntity:entity insertIntoManagedObjectContext:managedContext];

NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];

[fetchRequest setEntity:entity];

NSArray *myResults = [managedContext executeFetchRequest:fetchRequest error:nil];

self.objects = myResults;

NSLog(@"Results count: %lu", (unsigned long)myResults.count);

[self.table setNumberOfRows:myResults.count withRowType:@"ScheduleTableRow"];

for (object in myResults) {

    ScheduleTableRow *scheduleRow = [self.table rowControllerAtIndex:[myResults indexOfObject:object]];
    [scheduleRow.name setText:[NSString stringWithFormat:@"%@",[object valueForKey:@"day"]]];
    [scheduleRow.date setText:[NSString stringWithFormat:@"%@",[object valueForKey:@"date"]]];
}

}

- (void)willActivate {
// This method is called when watch view controller is about to be visible to user
[super willActivate];
}

- (void)didDeactivate {
// This method is called when watch view controller is no longer visible
[super didDeactivate];
}

@end

デバッグ ログ:

2015-11-17 15:07:12.143 canada2016Watch Extension[89456:1406057] Running CoreDataHelper 'init'
2015-11-17 15:07:12.148 canada2016Watch Extension[89456:1406057] Running CoreDataHelper 'setupCoreData'
2015-11-17 15:07:12.148 canada2016Watch Extension[89456:1406057] Running CoreDataHelper 'loadStore'
2015-11-17 15:07:12.148 canada2016Watch Extension[89456:1406057] Running CoreDataHelper 'storeURL'
2015-11-17 15:07:12.148 canada2016Watch Extension[89456:1406057] Running CoreDataHelper 'applicationStoresDirectory'
2015-11-17 15:07:12.148 canada2016Watch Extension[89456:1406057] Running CoreDataHelper 'applicationDocumentsDirectory'
2015-11-17 15:07:12.159 canada2016Watch Extension[89456:1406057]    Successfully added store: <NSSQLCore: 0x7b8692b0> (URL:   file:///Users/barry/Library/Developer/CoreSimulator/Devices/E7C26A87-B22C-45C5-9AE3-18CB24393EA9/data/Containers/Data/PluginKitPlugin/6717F002-7F1B-44EB-8C9F-861B6CF01E08/Documents/Stores/group.org.bicsi.canada2016app)
2015-11-17 15:07:12.160 canada2016Watch Extension[89456:1406057] Results count: 1
4

1 に答える 1

1

方法を誤解しているかもしれませんrowControllerAtIndex。このメソッドは、テーブルに行を追加する実際の場所です。代わりに、indexOfObjectテーブルにまだオブジェクトがないかのようにインデックスを参照します。

代わりに、インデックスをループして、各行の項目を作成し、適切なオブジェクトを設定する必要があります。

for (int i = 0; i < self.objects.count; i++) {
   ScheduleTableRow *scheduleRow = [self.table rowControllerAtIndex:i];
   NSManagedObject *item = self.objects[i];
   scheduleRow.name.text = [item valueForKey:@"day"];
   scheduleRow.date.text = [item valueForKey:@"date"];
}

Swift でよりエレガントに

for (idx, object) in self.objects.enumerate() {
   let scheduleRow = self.table.rowControllerAtIndex(idx)
   scheduleRow.name.text = object.valueForKey("day")
   scheduleRow.date.text = object.valueForKey("date")
}
于 2015-11-17T22:35:49.807 に答える