4

UISearchBarDelegateとUISearchDisplayDelegateを実装するテーブルビューコントローラーがあります。テーブルビューの編集ビューを切り替えるボタンがあります。編集モードでは、ユーザーは多くの行を選択してコピーしたり、削除したりできます。テーブルビューが編集モードのときに検索バーに何かを入力しようとすると、shouldReloadTableForSearchStringメソッドが起動し、そこで再実行します。更新された述語を使用してコアデータからデータをフェッチし、関数からYESを返します。これは、テーブルビューを再ロードする必要があることを示します。フィルタリングされた結果が表示されるとき、cellForRowAtIndexPathでtableView isEditingがYESであることがわかりますが、編集モードではありません。複数選択の円が見えません。結果を大幅に制限するには、ユーザーがリストをフィルタリングできるようにする必要があります。

結果が編集モードで表示されないのはなぜですか?

検索バーを使用せずに編集モード:

検索バーを使用せずに編集モード

編集モードで検索すると、編集モードではなく、スタイルも設定されていない結果が生成されます。

編集モードで検索すると、編集モードではなく、スタイルも設定されていない結果が生成されます

よろしくお願いします、アレックス

shouldReloadTableForSearchStringメソッドは次のとおりです。

    - (BOOL)searchDisplayController:(UISearchDisplayController *)controller shouldReloadTableForSearchString:(NSString *)searchString {
NSPredicate *predicate = nil;
if ([searchString length])
{
    NSArray* filteredTags = nil;
    if ([searchString length] < 3)
    {
        // Check for tags starting with 1 or 2 characters.
        filteredTags = [[tagResultsController fetchedObjects] filteredArrayUsingPredicate:[NSPredicate predicateWithBlock:^BOOL(TagEntity* te, NSDictionary *bindings)
        {
            if ([[[te.name lowercaseString] substringToIndex:[searchString length]] isEqualToString:[searchString lowercaseString]])
                return YES;

            return NO;
        }]];

    }
    else
    {
        // Check for tags with 3 or more consecutive characters anywhere in name
        filteredTags = [[tagResultsController fetchedObjects] filteredArrayUsingPredicate:[NSPredicate predicateWithBlock:^BOOL(TagEntity* te, NSDictionary *bindings)
        {
           if ([[te.name lowercaseString] rangeOfString:[searchString lowercaseString]].location != NSNotFound)
               return YES;

           return NO;
        }]];
    }

    //  OR ANY(self.tags) in %@
    predicate = [NSPredicate predicateWithFormat:
        @"ANY(self.songlists) in %@ AND (name contains[cd] %@ OR artist_name contains[cd] %@ OR number = %@ OR ANY(tag_entities) in %@)",
        currentSonglist.songs, searchString, searchString, searchString,filteredTags];

    [self.fetchedResultsController.fetchRequest setPredicate:predicate];

    NSError *error = nil;
    if (![[self fetchedResultsController] performFetch:&error]) {
        NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
        abort();
    }
    // Return YES to cause the search result table view to be reloaded.

}

return YES;

}

そして、これが.hファイルからの私のCoreDataテーブルビューのヘッダーです:

    @interface SonglistTVC : CoreDataTableViewController
<UISearchBarDelegate, 
UISearchDisplayDelegate,
UIPickerViewDataSource,
UIPickerViewDelegate,
UIActionSheetDelegate,
AddSongTVCDelegate,
ListSelectorDelegate>

cellForRowAtIndexPathとdidSelectRowAtIndexPathの両方が起動しているため、テーブルビューコントローラーを使用していることがわかります。内部でデバッグでき、テーブルビューでisEditingがYESに設定されています。しかし、それでもテーブルビューは適切な編集モードのスタイルを反映していません。

これは、検索ボックスに文字を入力した直後に起動するcellForRowAtIndexPathです。

    - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
NSString *identifier = @"SongCell";
UITableViewCell *cell = [self.tableView dequeueReusableCellWithIdentifier:identifier];

Song* song = [self.fetchedResultsController objectAtIndexPath:indexPath];     

UILabel* artistLabel    = (UILabel*)[cell viewWithTag:ARTIST_NAME_TAG];
UILabel* songLabel      = (UILabel*)[cell viewWithTag:SONG_NAME_TAG];
UILabel* keyLabel       = (UILabel*)[cell viewWithTag:KEY_TAG];
UILabel* numberLabel    = (UILabel*)[cell viewWithTag:NUMBER_TAG];

//artistLabel.font = [UIFont systemFontOfSize:17];
[artistLabel setText:   song.artist_name];
[songLabel setText:     song.name];
//[songLabel setFont:[UIFont systemFontOfSize:16]];
[keyLabel setText:      song.key];
[numberLabel setText:   [NSString stringWithFormat:@"%@", song.number]];


UIView *backView = [[UIView alloc] initWithFrame:CGRectMake(0,0,320,61)];
UIView *selectedBackView = [[UIView alloc] initWithFrame:CGRectMake(0,0,320,61)];

CAGradientLayer *backGradient = [[CAGradientLayer alloc] init];
backGradient.frame = cell.layer.bounds;

CAGradientLayer *selectedGradient = [[CAGradientLayer alloc] init];
selectedGradient.frame = cell.layer.bounds;

if (song.status == [NSNumber numberWithUnsignedInt: 1])
{
    [backGradient setColors:[NSArray arrayWithObjects:
                           (id)[[UIColor colorWithRed:240.0f/255.0f green:200.0f/255.0f blue:200.0f/255.0f alpha:1.0f] CGColor],
                           (id)[[UIColor colorWithRed:1 green:1 blue:1 alpha:1.0f] CGColor],
                           nil]];
}
else if (song.status == [NSNumber numberWithUnsignedInt: 2])
{
    [backGradient setColors:[NSArray arrayWithObjects:
                         (id)[[UIColor colorWithRed:240.0f/255.0f green:240.0f/255.0f blue:200.0f/255.0f alpha:1.0f] CGColor],
                         (id)[[UIColor colorWithRed:1 green:1 blue:1 alpha:1.0f] CGColor],
                         nil]];
}
else if (song.status == [NSNumber numberWithUnsignedInt: 3])
{
    [backGradient setColors:[NSArray arrayWithObjects:
                         (id)[[UIColor colorWithRed:200.0f/255.0f green:240.0f/255.0f blue:200.0f/255.0f alpha:1.0f] CGColor],
                         (id)[[UIColor colorWithRed:1 green:1 blue:1 alpha:1.0f] CGColor],
                         nil]];
}
[selectedGradient setColors:[NSArray arrayWithObjects:
                     (id)[[UIColor colorWithRed:255.0f/255.0f green:160.0f/255.0f blue:60.0f/255.0f alpha:1.0f] CGColor],
                     (id)[[UIColor colorWithRed:1 green:1 blue:1 alpha:0.7f] CGColor],
                     nil]];


if (![self.tableView isEditing] )
{
    cell.backgroundView = backView;
    [cell.backgroundView.layer insertSublayer:backGradient atIndex:1];

    cell.selectedBackgroundView = selectedBackView;
    [cell.selectedBackgroundView.layer insertSublayer:selectedGradient atIndex:1];
}
else
{
    //cell.backgroundView = backView;
    //[cell.backgroundView.layer insertSublayer:backGradient atIndex:1];
    cell.selectedBackgroundView = backView;
    [cell.selectedBackgroundView.layer insertSublayer:backGradient atIndex:1];
}

for (NSIndexPath* ip in selectedIndexes)
{
    [self.tableView selectRowAtIndexPath:ip animated:YES scrollPosition:UITableViewScrollPositionNone];
}

[sortOrderPicker reloadAllComponents];
[self sendPickerDownAnimated:NO];

return cell;

}

セグメント化されたコントロール内のボタンを使用して、編集のオン/オフを切り替えます。

    - (IBAction)segmentChanged:(id)sender{
UISegmentedControl* sg = (UISegmentedControl*)sender;
if (sg.selectedSegmentIndex == 0)
{
    // Edit
    if (![self.tableView isEditing])
    {
        [self.tableView setEditing:YES animated:YES];
        [self.navigationController setToolbarHidden:NO animated:YES];
    }
    else
    {
        [self.tableView setEditing:NO animated:YES];
        [self.navigationController setToolbarHidden:YES animated:YES];
        selectedIndexes = nil;
    }
    [self.tableView reloadData];
}
else
{
    // Sort
    if (pickerShown)
        [self sendPickerDownAnimated:YES];
    else
        [self bringPickerUpAnimated:YES];
}

}

4

2 に答える 2

3

問題は、UISearchDisplayControllerが自動的に多くのことを実行するという事実にあります。検索結果を表示する独自のテーブルビューを作成し、そのテーブルビューを管理します。そのテーブルビューのデータソースおよびデリゲートとして自分自身を設定できます。デフォルトでは、これは自動的に行われますが、それはテーブルビューではなく、制御していません。これをどのテーブルビューにするかをより明確に指定したい場合は、検索ディスプレイコントローラーを設定する必要があります。searchResultsTableView; または、状況が進むにつれて(たとえば、UISearchDisplayControllerの独自のデリゲートメソッドを介して)それへの参照を取得できます。ただし、それでも、結果テーブルビューを管理するUITableViewControllerにはなりません。これは完全にUISearchDisplayControllerの内部です。それが気に入らない場合の簡単な解決策の1つは、UISearchDisplayControllerを使用しないでください。別のインターフェイスを考えてください。

于 2013-01-04T18:01:00.217 に答える
1

mattが言ったように、検索モードではUISearchDisplayControllerに独自のUITableViewがあるため、編集モードで同じデザインをUITableViewに保持するには、self.tableViewで設定したものと同じデザインパラメーターを渡す必要があります。

-(void)searchDisplayController:(UISearchDisplayController *)controller didLoadSearchResultsTableView:(UITableView *)tableView
{
    tableView.backgroundColor = self.tableView.backgroundColor;
    tableView.separatorColor = [UIColor redColor];
    tableView.separatorInset = UIEdgeInsetsMake(0, 0, 0, 0);
}
于 2014-07-15T19:07:08.060 に答える