Как сделать так, чтобы UITableViewCell казался отключенным?


86

Я знаю о UITableview: как отключить выделение для некоторых строк, но не для других, и cell.selectionStyle = UITableViewCellSelectionStyleNone, но как мне сделать ячейку (или любую другуюUIView в этом отношении) отключенной (выделенной серым цветом), как показано ниже?

отключен UITableViewCell

Ответы:


164

Вы можете просто отключить текстовые поля ячейки, чтобы они были серыми:

Swift 4.x

cell!.isUserInteractionEnabled = false
cell!.textLabel!.isEnabled = false
cell!.detailTextLabel!.isEnabled = false

17
Или немного короче:cell.userInteractionEnabled = cell.textLabel.enabled = cell.detailTextLabel.enabled = NO;
Thomas Kekeisen

51
короче, но уродливее
спорт

25

Расширение Swift, которое хорошо работает в том контексте, в котором я его использую; ваш пробег может отличаться.

Swift 2.x

extension UITableViewCell {
    func enable(on: Bool) {
        for view in contentView.subviews as! [UIView] {
            view.userInteractionEnabled = on
            view.alpha = on ? 1 : 0.5
        }
    }
}

Swift 3:

extension UITableViewCell {
    func enable(on: Bool) {
        for view in contentView.subviews {
            view.isUserInteractionEnabled = on
            view.alpha = on ? 1 : 0.5
        }
    }
}

Теперь осталось только позвонить myCell.enable(truthValue).


22

Благодаря @Ajay Sharma я понял, как отключить UITableViewCell отображение :

// Mac's native DigitalColor Meter reads exactly {R:143, G:143, B:143}.
cell.textLabel.alpha = 0.439216f; // (1 - alpha) * 255 = 143
aSwitch.enabled = NO; // or [(UISwitch *)cell.accessoryView setEnabled:NO];

А затем, чтобы фактически отключить ячейку:

cell.userInteractionEnabled = NO;

Да, конечно, вы могли бы сделать то же самое, установив альфа :)
Аджай Шарма

18

Попробуйте использовать небольшой трюк:

Просто установите альфа ячейки. Поставьте какое-нибудь условие в соответствии с вашими требованиями и установите альфа-канал.

cell.alpha=0.2;

Если не работает, как вам нравится, тогда используйте второй трюк,

Просто возьмите изображение размера ячейки с серым фоном с прозрачным фоном, просто добавьте это изображение в изображение поверх содержимого ячейки. Как это:

// 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:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier] autorelease];
    }

    // Configure the cell...


    if(indexPath.row==0)
    {
        cell.userInteractionEnabled=FALSE;

        UIImageView *img=[[UIImageView alloc]init];
        img.frame=CGRectMake(0, 0, 320, 70);
        img.image=[UIImage imageNamed:@"DisableImage.png"];
        img.backgroundColor=[UIColor clearColor];
        [cell.contentView addSubview:img];
        [img release];

    }
    else {
        //Your usual code for cell interaction.

    }
    return cell;
}

Хотя я не уверен, как это сделать, но это обязательно выполнит ваше требование. Это создаст в сознании пользователя некую иллюзию, что ячейка отключена. Просто попробуйте использовать это решение. Надеюсь, оно решит вашу проблему.


5
cell.alpha = 0.2 - у меня не работает. cell.ContentView.Alpha = 0.2 у меня сработало
Михал Доброденка

То же самое здесь, что установка cell.alpha - не работает, установка cell.ContentView.alpha выполняет свою работу
infinity_coding7

4

Отличное расширение от Кевина Оуэнса, это моя поправка к работе со Swift 2.x :

extension UITableViewCell {
    func enable(on: Bool) {
        self.userInteractionEnabled = on
        for view in contentView.subviews {
            view.userInteractionEnabled = on
            view.alpha = on ? 1 : 0.5
        }
    }
}

Swift 3:

extension UITableViewCell {
    func enable(on: Bool) {
        self.isUserInteractionEnabled = on
        for view in contentView.subviews {
            view.isUserInteractionEnabled = on
            view.alpha = on ? 1 : 0.5
        }
    }
}

Используйте .isUserInteractionEnabled в Swift 3.0
Матиас Массо,

4

Swift 4.X

Хорошее расширение от Кевина Оуэнса, я исправляю поведение ячейки.

extension UITableViewCell {
    func enable(on: Bool) {
        self.isUserInteractionEnabled = on
        for view in contentView.subviews {
            self.isUserInteractionEnabled = on
            view.alpha = on ? 1 : 0.5
        }
    }
}

Как это назвать: -

cell.enable(on: switch.isOn)


2

Я создал следующее расширение для Enable / Disable UITableViewCell, им очень удобно пользоваться. Создайте расширение UITableViewCell с «UITableViewCell + Ext.h», содержащим в нем следующее.

@interface UITableViewCell (Ext)

- (void)enableCell:(BOOL)enabled withText:(BOOL)text;
- (void)enableCell:(BOOL)enabled withText:(BOOL)text withDisclosureIndicator:(BOOL)disclosureIndicator;
- (void)disclosureIndicator:(BOOL)disclosureIndicator;

@end

"UITableViewCell + Ext.m" содержит в себе следующее.

@implementation UITableViewCell (Ext)

- (UITableView *)uiTableView {
    if ([[UIDevice currentDevice] systemVersionIsGreaterThanOrEqualTo:@"7.0"]) {
        return (UITableView *)self.superview.superview;
    }
    else {
        return (UITableView *)self.superview;
    }
}

- (void)enableCell:(BOOL)enabled withText:(BOOL)text {
    if (enabled) {
        self.userInteractionEnabled = YES;

        if (text) {
            self.textLabel.alpha = 1.0f;
            self.alpha = 1.0f;
            self.detailTextLabel.hidden = NO;
        }
    }
    else {
        self.userInteractionEnabled = NO;

        if (text) {
            self.textLabel.alpha = 0.5f;
            self.alpha = 0.5f;
            self.detailTextLabel.hidden = YES;
        }
    }
}

- (void)enableCell:(BOOL)enabled withText:(BOOL)text withDisclosureIndicator:(BOOL)disclosureIndicator {
    if (enabled) {
        self.userInteractionEnabled = YES;

        if (text) {
            self.textLabel.alpha = 1.0f;
            self.alpha = 1.0f;
            self.detailTextLabel.hidden = NO;
        }

        self.accessoryType = disclosureIndicator ? UITableViewCellAccessoryDisclosureIndicator : UITableViewCellAccessoryNone;
    }
    else {
        self.userInteractionEnabled = NO;

        if (text) {
            self.textLabel.alpha = 0.5f;
            self.alpha = 0.5f;
            self.detailTextLabel.hidden = YES;
        }

        self.accessoryType = UITableViewCellAccessoryNone;
    }
}

- (void)disclosureIndicator:(BOOL)disclosureIndicator {
    if (disclosureIndicator) {
        self.accessoryType = UITableViewCellAccessoryDisclosureIndicator;
    }
    else {
        self.accessoryType = UITableViewCellAccessoryNone;
    }
}

@end

Как отключить ячейку:

[cell enableCell:NO withText:NO];

[cell enableCell:NO withText:YES withDisclosureIndicator:YES];

Как включить ячейку:

[cell enableCell:YES withText:NO];

[cell enableCell:YES withText:YES withDisclosureIndicator:YES];

Надеюсь, это поможет тебе.


Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.