草庐IT

iphone - 如何将 "load more"选项添加到 TableView

coder 2023-07-20 原文

我的应用程序有一个由 Sqlite DB 填充的表,其中包含大量数据 所以导致table view延迟加载

这是代码

- (void) searchData {
    //i=0;
    [newSearchBar setShowsCancelButton:YES animated:YES];



    NSLog(@"search data started ");

     NSLog(@" checking value %@",newSearchBar.text);
    NSString *databaseName = @"imeating.sql";
    NSArray *documentPaths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask,YES);
    NSString *documentsDir=[documentPaths objectAtIndex:0];
    NSString *databasePath=[documentsDir stringByAppendingPathComponent:databaseName];
    sqlite3 *database;

    if (sqlite3_open([databasePath UTF8String], &database) == SQLITE_OK)
    {
        NSLog(@"with in if sqlite3 open");
        // Setup the SQL Statement and compile it for faster access
        sqlite3_stmt *compiledStatement ;
        const char *sqlStatement ;

        /* if ([searchFlag isEqualToString:@"DEF"])
         {
         sqlStatement = "select subitem_name, subitem_detail_id from subitem_detail limit 200" ;
         }
         else
         {*/
        sqlStatement = "select category_id, upper(subitem_name), subitem_detail_id, protein, carbohydrates, fat, calorie from subitem_detail where subitem_name LIKE ? order by subitem_name limit ?,?" ;
       NSLog(@"inside search b4 wildsearch %@",searchString);

        wildSearch = [NSString stringWithFormat:@"%@%@",searchString, @"%"];

        NSLog(@"wildsearch %@",wildSearch);

        [newSearchBar setShowsCancelButton:YES animated:YES];
        //NSLog(@"inside search : %@", wildSearch);


        //}

        if (sqlite3_prepare_v2(database, sqlStatement, -1, &compiledStatement, NULL) == SQLITE_OK) 
        {

             NSLog(@"with in if sqlite3 prepare v2");
            // if (![searchFlag isEqualToString:@"DEF"])
            // {
            sqlite3_bind_text(compiledStatement, 1, [wildSearch UTF8String], -1, SQLITE_TRANSIENT);
            sqlite3_bind_int(compiledStatement, 2, llimit);
            sqlite3_bind_int(compiledStatement, 3, ulimit);

            // }
            // Loop through the results and add it to array

            if (llimit <200){
                 NSLog(@"with in if limit < 200");

                itemArray = [[NSMutableArray alloc] init] ;
            }

            while (sqlite3_step(compiledStatement) == SQLITE_ROW) {

                //NSLog(@" while sqlite3 step");

                NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init] ;
                //[itemDic release];
                //itemDic = nil ;
                itemDic = [[[NSMutableDictionary alloc] init] autorelease];


                NSString *categoryId = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 0)];
                NSString *itemName = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 1)];
                NSString *itemId = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 2)];
                NSString *protein = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 3)];
                NSString *carbo = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 4)];
                NSString *fat = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 5)];
                NSString *calorie = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 6)];

                /* NSLog(@"itemname : %@", itemName);
                 NSLog(@"itemid : %@", itemId);
                 NSLog(@"\n");*/

                [itemDic setObject:categoryId forKey:@"categoryId"];
                [itemDic setObject:itemId forKey:@"itemId"];
                [itemDic setObject:itemName forKey:@"itemName"];
                [itemDic setObject:protein forKey:@"protein"];
                [itemDic setObject:carbo forKey:@"carbohydrate"];
                [itemDic setObject:fat forKey:@"fat"];
                [itemDic setObject:calorie forKey:@"calorie"];

                [itemArray addObject:itemDic];
                if (ulimit%200 == 0)
                {
                    //activity = [[UIActivityIndicatorView alloc] initWithActivityIndicatorStyle:UIActionSheetStyleDefault];
                    //[activity startAnimating];
                    [newTableView reloadData];
                    //[newSearchBar setShowsCancelButton:YES animated:YES];
                    //NSLog(@"list all views after 1st reload: %@", [self.navigationController.viewControllers description]);
                    //[newTableView addSubview:activity];
                    //[activity stopAnimating];
                    //[activity release];
                    //NSLog(@" with in if");
                }
                [pool drain];
            } /*else
               {
               UIAlertView *alert = [[UIAlertView alloc ] initWithTitle:@"Error" message:@"sqlite rows not returned" delegate:self cancelButtonTitle:@"OK" otherButtonTitles: nil] ;
               [alert show];
               }*/


        }
    } else
    {
        UIAlertView *alert = [[UIAlertView alloc ] initWithTitle:@"Error" message:@"DataBase Path doesn't exists" delegate:self cancelButtonTitle:@"OK" otherButtonTitles: nil] ;
        [alert show];
    }

    //NSLog(@"itemArray desc : %@",[itemArray description]);

}

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
    //NSLog(@"Inside number of sections in tableview");
    return 1;

}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    return [itemArray count] ;

}

// Customize the appearance of table view cells.
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    static NSString *CellIdentifier = @"Cell";

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

    //NSLog(@"indexpath row val : %d", indexPath.row);

    tableIndex = indexPath ;

    //NSLog(@"print indexpath row : %d", indexPath.row);
    //NSLog(@"print limit : %d", limit);

    if (indexPath.row > limit)
    {
        llimit = llimit+200 ;
        ulimit = ulimit+200 ;

        NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];

        //[opq cancelAllOperations];
        NSLog(@"before ns operation");

        opq = [NSOperationQueue new];
        //opq = [[NSOperationQueue alloc] init];
        //[opq setMaxConcurrentOperationCount:2];

        // [self performSelectorOnMainThread:@selector(searchData) withObject:nil waitUntilDone:YES];

        NSInvocationOperation *op = [[[NSInvocationOperation alloc] initWithTarget:self selector:@selector(searchData) object:nil] autorelease];



        [opq addOperation:op];

        NSLog(@"after ns operation");
        //[op release];
        //[opq release];

        [pool drain];
        i++;
        limit = limit + 120 ;
        NSLog(@"i=%d",i);

        //[cell setText:[[itemArray objectAtIndex:indexPath.row] valueForKey:@"itemName"]];
    }

    // Configure the cell.
    //[cell setText:[[itemArray objectAtIndex:indexPath.row] valueForKey:@"itemName"]];
    cell.textLabel.text = [[itemArray objectAtIndex:indexPath.row] valueForKey:@"itemName"] ;
    NSString *pval, *cval, *fval, *cal ;
    if ([[[itemArray objectAtIndex:indexPath.row] valueForKey:@"protein"] length] <= 5)
         pval = [[itemArray objectAtIndex:indexPath.row] valueForKey:@"protein"];
    else
        pval = [[[itemArray objectAtIndex:indexPath.row] valueForKey:@"protein"] substringWithRange:NSMakeRange(0, 5)];

    if ([[[itemArray objectAtIndex:indexPath.row] valueForKey:@"carbohydrate"] length] <= 5)
        cval = [[itemArray objectAtIndex:indexPath.row] valueForKey:@"carbohydrate"];
    else
        cval = [[[itemArray objectAtIndex:indexPath.row] valueForKey:@"carbohydrate"] substringWithRange:NSMakeRange(0, 5)];

    if ([[[itemArray objectAtIndex:indexPath.row] valueForKey:@"fat"] length] <= 5)
        fval = [[itemArray objectAtIndex:indexPath.row] valueForKey:@"fat"];
    else
        fval = [[[itemArray objectAtIndex:indexPath.row] valueForKey:@"fat"] substringWithRange:NSMakeRange(0, 5)];

    if ([[[itemArray objectAtIndex:indexPath.row] valueForKey:@"calorie"] length] <= 5)
        cal = [[itemArray objectAtIndex:indexPath.row] valueForKey:@"calorie"];
    else
        cal = [[[itemArray objectAtIndex:indexPath.row] valueForKey:@"calorie"] substringWithRange:NSMakeRange(0, 5)];

    cell.detailTextLabel.text = 
    [NSString stringWithFormat:@"Prot: %@ Carb: %@ Fat: %@ Cal: %@", pval, cval, fval, cal] ;
    return cell;
}

我的 TableView 需要行中的“加载更多”按钮才能在特定的限制期间从 sqlite 数据库加载记录

最佳答案

将 a + 1 添加到部分中的行数:

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    return [itemArray count] + 1;

}
  • 然后在 cellforrowatindexpath 中,查看 indexPath.row 是否大于 [itemArray count]。如果是,则将文本“加载更多...”作为该单元格的标题。

  • 在 didSelectRowAtIndexPath 中,查看 indexPath.row 是否等于 [itemArray count]。如果是这种情况,则向 itemArray 添加 x 个结果,然后调用 [tableView reloadData]。

  • 对于某些 UI 改进,您可以在 TableView 顶部添加一个 UIActivityIndi​​cator,以显示后台正在进行某些处理。

关于iphone - 如何将 "load more"选项添加到 TableView ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5898399/

有关iphone - 如何将 "load more"选项添加到 TableView的更多相关文章

  1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

    我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

  2. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  3. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

  4. ruby-on-rails - rails : "missing partial" when calling 'render' in RSpec test - 2

    我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou

  5. ruby - 我需要将 Bundler 本身添加到 Gemfile 中吗? - 2

    当我使用Bundler时,是否需要在我的Gemfile中将其列为依赖项?毕竟,我的代码中有些地方需要它。例如,当我进行Bundler设置时:require"bundler/setup" 最佳答案 没有。您可以尝试,但首先您必须用鞋带将自己抬离地面。 关于ruby-我需要将Bundler本身添加到Gemfile中吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4758609/

  6. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-

  7. ruby-on-rails - 如何验证 update_all 是否实际在 Rails 中更新 - 2

    给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru

  8. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  9. ruby - 如何将脚本文件的末尾读取为数据文件(Perl 或任何其他语言) - 2

    我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚

  10. ruby - 如何指定 Rack 处理程序 - 2

    Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack

随机推荐