0

この解析チュートリアルに従って、カスタムUITableViewControllerを作成しました。ストーリーボードでUITableViewを編集できるようにしたいと思います。このチュートリアルのどこかで、ViewControllerをTableViewにリンクすると思いましたが、そうではありませんでした。UI編集のためにこのViewControllerにリンクされているstroyboardでこのTableViewにアクセスするにはどうすればよいですか?

これがGitHubのViewControllerコードです。

編集:これは実際にはParseAPIとは何の関係もありません。テーブルビューはストーリーボードにありません-これは私が解決しようとしている問題です。チュートリアルでは、これをAppDelegate.mに追加するように指示されました。

MyTableViewController *controller = [[MyTableViewController alloc] init];

self.window.rootViewController = controller;

そしてこれをMyTableViewController.mに:

- (id)initWithStyle:(UITableViewStyle)style

{

self = [super initWithStyle:style];

if (self) {

    // Custom the table

    // The className to query on

    self.className = @"Artists"; 

    // The key of the PFObject to display in the label of the default cell style

    self.keyToDisplay = @"artistName"; 

    // Whether the built-in pull-to-refresh is enabled

    self.pullToRefreshEnabled = YES;


    // Whether the built-in pagination is enabled

    self.paginationEnabled = YES;


    // The number of objects to show per page

    self.objectsPerPage = 50;

 }

return self;

}

アプリは正常に実行されていますが、ストーリーボードにあるのは空白のビューだけです。TableViewを作成し、それをMyTableViewControllerにリンクする必要がありますか?AppDelegateからそのself.window...コードを削除する必要があると思います。

編集:更新されたコード:

#import "MyTableViewController.h"

@implementation MyTableViewController
@synthesize tableView = _tableView;


#pragma mark - View lifecycle

- (void)viewDidLoad
{
[super viewDidLoad];


    // Custom the table

    // The className to query on
    self.className = @"Artists";

    // The key of the PFObject to display in the label of the default cell style
    self.keyToDisplay = @"artistName";

    // Whether the built-in pull-to-refresh is enabled
    self.pullToRefreshEnabled = YES;

    // Whether the built-in pagination is enabled
    self.paginationEnabled = YES;

    // The number of objects to show per page
    self.objectsPerPage = 50;




// Uncomment the following line to preserve selection between presentations.
// self.clearsSelectionOnViewWillAppear = NO;

// Uncomment the following line to display an Edit button in the navigation bar for this     view controller.
 self.navigationItem.rightBarButtonItem = self.editButtonItem;
}

- (void)viewDidUnload
{
[self setTableView:nil];
[super viewDidUnload];
// Release any retained subviews of the main view.
// e.g. self.myOutlet = nil;
}

- (void)viewWillAppear:(BOOL)animated
{
[super viewWillAppear:animated];
}

- (void)viewDidAppear:(BOOL)animated
{
[super viewDidAppear:animated];
}

- (void)viewWillDisappear:(BOOL)animated
{
[super viewWillDisappear:animated];
}

- (void)viewDidDisappear:(BOOL)animated
{
[super viewDidDisappear:animated];
}

- (BOOL)shouldAutorotateToInterfaceOrientation:            (UIInterfaceOrientation)interfaceOrientation
{
// Return YES for supported orientations
return (interfaceOrientation == UIInterfaceOrientationPortrait);
}

- (void)didReceiveMemoryWarning
{
// Releases the view if it doesn't have a superview.
[super didReceiveMemoryWarning];

// Release any cached data, images, etc that aren't in use.
}

#pragma mark - Parse

- (void)objectsDidLoad:(NSError *)error {
[super objectsDidLoad:error];

// This method is called every time objects are loaded from Parse via the PFQuery
}

- (void)objectsWillLoad {
[super objectsWillLoad];

// This method is called before a PFQuery is fired to get more objects
}


// Override to customize what kind of query to perform on the class. The default is to query for
// all objects ordered by createdAt descending.
- (PFQuery *)queryForTable {
PFQuery *query = [PFQuery queryWithClassName:self.className];

// If no objects are loaded in memory, we look to the cache first to fill the table
// and then subsequently do a query against the network.
if ([self.objects count] == 0) {
    // ** There are other caching options in Parse iOS guide
    query.cachePolicy = kPFCachePolicyNetworkElseCache;
}

[query orderByDescending:@"tweetInfluence"];

return query;
}
// Override to customize the look of a cell representing an object. The default is to display
// a UITableViewCellStyleDefault style cell with the label being the first key in the object. 
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath object:(PFObject *)object {
static NSString *CellIdentifier = @"Cell";

UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
if (cell == nil) {
    cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:CellIdentifier];
}

// Configure the cell
cell.textLabel.text = [object objectForKey:@"artistName"];
cell.detailTextLabel.text = [NSString stringWithFormat:@"Tweet Influence: %@", [object objectForKey:@"tweetInfluence"]];

return cell;
}
#pragma mark - Table view delegate

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
[super tableView:tableView didSelectRowAtIndexPath:indexPath];
}


@end
4

1 に答える 1

0

ストーリーボードを使用している場合は、削除する必要があります

MyTableViewController *controller = [[MyTableViewController alloc] init];

self.window.rootViewController = controller;

AppDelegate から。ストーリーボードを使用すると、アプリのエントリ ポイントは、右向きの矢印で表されるストーリーボード自体で制御されます。

また、現在のコードでは、アプリはinit関数ではなく、View Controller の関数を呼び出していinitWithStyleます。initWithStyleビューコントローラーの関数に現在含まれているコードを配置して、viewDidLoad確実に呼び出されるようにする必要があります。

于 2012-05-01T17:29:20.790 に答える