NSFetchRequest の結果を UIPickerView に取り込もうとしています。NSFetchRequest の結果は、NSArray に格納されます。Core Data を使用して SQLite DB とやり取りしています。プロジェクトのストーリーボード シーンに関連付けられた UIPickerView を含む単純なクラス ファイルがあります。
クラスのヘッダー ファイルは次のようになります。
ViewControllerUsers.h
#import <UIKit/UIKit.h>
#import "AppDelegate.h"
@interface ViewControllerUsers : UIViewController <NSFetchedResultsControllerDelegate, UIPickerViewDelegate, UIPickerViewDataSource>
{
NSArray *dictionaries;
}
@property (nonatomic, strong) NSFetchedResultsController *fetchedResultsController;
// Core Data
@property (strong, nonatomic) NSManagedObjectContext *managedObjectContext;
@property (nonatomic, strong) NSArray *users;
@property (strong, nonatomic) IBOutlet UIPickerView *uiPickerViewUsers;
@property (weak, nonatomic) IBOutlet UIBarButtonItem *btnDone;
@property (weak, nonatomic) IBOutlet UIButton *btnChangePin;
// added for testing purposes
@property (nonatomic, strong) NSArray *usernames;
- (IBAction)dismissScene:(id)sender;
- (IBAction)changePin:(id)sender;
@end
実装ファイルは次のようになります。
ViewControllerUsers.m
#import "ViewControllerUsers.h"
@interface ViewControllerUsers ()
@end
@implementation ViewControllerUsers
// Core Data
@synthesize managedObjectContext = _managedObjectContext;
@synthesize uiPickerViewUsers = _uiPickerViewUsers;
@synthesize usernames = _usernames;
- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
{
self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
if (self) {
// Custom initialization
}
return self;
}
- (void)viewDidLoad
{
[super viewDidLoad];
// Do any additional setup after loading the view.
// Core Data
if (_managedObjectContext == nil)
{
_managedObjectContext = [(AppDelegate *)[[UIApplication sharedApplication] delegate] managedObjectContext];
NSLog(@"After _managedObjectContext: %@", _managedObjectContext);
}
NSFetchRequest *request = [NSFetchRequest fetchRequestWithEntityName:@"Account"];
NSEntityDescription *entity = [NSEntityDescription entityForName:@"Account" inManagedObjectContext:_managedObjectContext];
request.resultType = NSDictionaryResultType;
request.propertiesToFetch = [NSArray arrayWithObject:[[entity propertiesByName] objectForKey:@"username"]];
request.returnsDistinctResults = YES;
_usernames = [_managedObjectContext executeFetchRequest:request error:nil];
NSLog (@"names: %@",_usernames);
}
-(NSInteger)numberOfComponentsInPickerView:(UIPickerView *)pickerView
{
//One column
return 1;
}
-(NSInteger)pickerView:(UIPickerView *)pickerView numberOfRowsInComponent:(NSInteger)component
{
//set number of rows
return _usernames.count;
}
-(NSString *)pickerView:(UIPickerView *)pickerView titleForRow:(NSInteger)row forComponent:(NSInteger)component
{
//set item per row
return [_usernames objectAtIndex:row];
}
- (void)didReceiveMemoryWarning
{
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}
- (void)viewDidUnload {
[self setBtnDone:nil];
[self setUiPickerViewUsers:nil];
[self setBtnChangePin:nil];
[super viewDidUnload];
}
- (IBAction)dismissScene:(id)sender {
[self dismissModalViewControllerAnimated:YES];
}
- (IBAction)changePin:(id)sender {
}
@end
現在のコードが原因でアプリがクラッシュしていますが、NSLog は NSArray の NSFetchRequest の結果を示しています。推測する必要がある場合、現在、NSArray の NSFetchRequest の結果を適切にフォーマットしていないと思います。
クラッシュログは次のようになります。
2013-06-26 16:49:24.219 KegCop[41233:c07] 名前: ( { ユーザー名 = 何とか; }, { ユーザー名 = クリス; }, { ユーザー名 = ルート; } ) 2013-06-26 16:49:24.223 KegCop[41233:c07] -[NSKnownKeysDictionary1 isEqualToString:]: 認識されないセレクターがインスタンス 0xe54d9a0 2013-06-26 16:49:24.223 KegCop[41233:c07] に送信されましたキャッチされていない例外 'NSInvalidArgumentException' が原因でアプリを終了しています。理由: '-[NSKnownKeysDictionary1 isEqualToString:]: 認識されないセレクターがインスタンス 0xe54d9a0 に送信されました' 最初のスロー コール スタック: