在iPhone的表格视图上显示联系人列表

时间:2013-04-27 10:13:38

标签: ios objective-c xcode xcode4.5

我有一个视图控制器,我有一个添加联系人按钮和一个表视图。单击添加联系人按钮时,将打开一个新的视图控制器,其中有一些文本字段和标签以及一个将文本字段数据添加到数据库的按钮(提交)。我希望在按下“提交”按钮时,前一个控制器中的表视图应包含名称和联系号。提交的联系人。 addContact方法如下:

-(IBAction)addContact{
    sqlite3_stmt    *statement;
    const char *dbpath = [mDatabasePath UTF8String];

    if (sqlite3_open(dbpath, &mDiary) == SQLITE_OK)
    {
        NSString *insertSQL1=[NSString stringWithFormat:@"INSERT INTO CONTACTS VALUES(\"%@\",\"%@\",\"%@\",\"%@\",\"%@\")", mName.text, mContactno.text,mCemail.text,mClatitude.text,mClongitude.text];
        const char *insert_stmt1 = [insertSQL1 UTF8String];  
        sqlite3_prepare_v2(mDiary, insert_stmt1,

                           -1, &statement, NULL);

        NSString *tempName = [NSString stringWithFormat:@"%@",mName.text];
        NSString *tempNo = [NSString stringWithFormat:@"%@",mContactno.text];
        tempName = [tempName stringByAppendingString:tempNo];

        [phoneContacts addObject:tempName];
        tableView.delegate = self;
        tableView.dataSource = self;
        [tableView reloadData];
        if (sqlite3_step(statement) == SQLITE_DONE)
        {  mStatus.text=@"Contact added";
            mName.text=@"";
            mContactno.text=@"";

            mCemail.text=@"";

            mClatitude.text=@"";
            mClongitude.text=@"";
        }   
        else {
            mStatus.text = @"Failed to add contact";
        }  
        sqlite3_finalize(statement);
        sqlite3_close(mDiary);
    }
}

表格视图方法是:

-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    return [self.phoneContacts count];
}
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
    return 1;
}
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    static NSString *simpleTableIdentifier = @"Cell";

    UITableViewCell *cell = [tableView   dequeueReusableCellWithIdentifier:simpleTableIdentifier];

    if (cell == nil) {
        cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:simpleTableIdentifier];
    }

    cell.textLabel.text = [self.phoneContacts objectAtIndex:indexPath.row];


    return cell;


}

表格视图中没有显示任何内容。为什么呢?

我添加了一个方法populateContactTable:

-(IBAction)populateContactTable:(id)sender
{
    sqlite3_stmt *statement;
    const char *dbpath = [mDatabasePath UTF8String];
    if (sqlite3_open(dbpath,&mDiary)== SQLITE_OK) {
        NSString *selectSQL = [NSString stringWithFormat:@"SELECT * FROM CONTACTS"];
        const char *query_stmt = [selectSQL UTF8String];
        if (sqlite3_prepare_v2(mDiary,
                               query_stmt, -1, &statement, NULL) == SQLITE_OK)
        {
            while(sqlite3_step(statement) == SQLITE_ROW)
            {
                tempContactName = [[NSString alloc]initWithUTF8String:(const char *) sqlite3_column_text(statement, 0)];
                tempContactNo = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement,1)];

                tempContactName = [tempContactName stringByAppendingString:@"     "];
                tempContactName = [tempContactName stringByAppendingString:tempContactNo];

                [phoneContacts addObject:tempContactName];

                tableView.delegate = self;
                tableView.dataSource = self;
                [tableView reloadData];

                //  NSLog(@"%@",userName);
              //  return tempContactName;
            }

        }

        sqlite3_finalize(statement);
    }
    sqlite3_close(mDiary);
}

通过根视图控制器中的按钮调用此方法。表中还没有显示数据库中的数据。

这是故事板的简要介绍: storyboard

0 个答案:

没有答案