Accéder au contenu principal

UISwitch dans un UITableViewCell





Je construis des formulaire dans des UITable, chaque UITableViewCell peut donc contenir des UILabel, UISwitch, UIButton, etc. Je partage le code entre plusieurs application, mais j'ai eu un bug dans l'une d'elles que je n'avais pas dans les autres. Les gadgets interactifs ne fonctionnaient pas...

En fait, j'avais construit mes UITableViewCell avec du code comme celui-ci :

-(instancetype)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier {

    self = [super initWithStyle:style reuseIdentifier:reuseIdentifier];

    self.backgroundColor = [UIColor clearColor];


    _uiLabel = [UILabel new];

    _uiLabel.frame = CGRectMake(8, 4, self.frame.size.width-51-24, self.frame.size.height-8);

    _uiLabel.translatesAutoresizingMaskIntoConstraints = NO;

    _uiLabel.textAlignment = NSTextAlignmentLeft;

    _uiLabel.lineBreakMode = NSLineBreakByWordWrapping;

    _uiLabel.adjustsFontSizeToFitWidth = YES;

    _uiLabel.minimumScaleFactor = 0.5;

    _uiLabel.numberOfLines = 0  ;

    _uiLabel.text = NSLocalizedString(@"none", nil);

    [_uiLabel  removeConstraints:_uiLabel.constraints];

    [self addSubview:_uiLabel];

    

    _uiSwitch = [UISwitch new];

    _uiSwitch.frame = CGRectMake(self.frame.size.width-_uiSwitch.frame.size.width-8,

                                 self.frame.size.height/2-16,

                                 _uiSwitch.frame.size.width,

                                 _uiSwitch.frame.size.height);

    _uiSwitch.translatesAutoresizingMaskIntoConstraints = NO;

    

    [_uiSwitch addTarget:self action:@selector(changeOn:) forControlEvents:UIControlEventValueChanged];


    [_uiSwitch removeConstraints:_uiSwitch.constraints];

    [self addSubview:_uiSwitch];



    NSDictionary *children =@{ @"label":_uiLabel,@"sw":_uiSwitch };

    [self addConstraints:[NSLayoutConstraint

                          constraintsWithVisualFormat:@"H:|-8-[label(>=160)]-8-[sw]-16-|"

                          options:0 metrics:nil views:children]];

    [self addConstraints:[NSLayoutConstraint

                          constraintsWithVisualFormat:@"V:|-8-[label]-8-|"

                          options:0 metrics:nil views:children]];

    [self addConstraints:[NSLayoutConstraint

                          constraintsWithVisualFormat:@"V:|-8-[sw]-8-|"

                          options:0 metrics:nil views:children]];


    [self setNeedsLayout];

    return self;

}


Mon erreur était dans l'appel de addSubView, il ne faut pas mettre les éléments directement dans le UITableViewCell, car la contentView peut alors se retrouver au-dessus et empêcher les interactions. 
Il faut donc mettre :


    [self.contentView addSubview:_uiLabel];

    [self.contentView addSubview:_uiSwitch];


Remplacer self par self.contentView règle le problème. On doit aussi s'occuper des addConstraints qui devraient aussi être mis à self.contentView.

    NSDictionary *children =@{ @"label":_uiLabel,@"sw":_uiSwitch };

    [self.contentView addConstraints:[NSLayoutConstraint 

     constraintsWithVisualFormat:@"H:|-8-[label(>=160)]-8-[sw]-16-|"

                         options:0 metrics:nil views:children]];

    [self.contentView addConstraints:[NSLayoutConstraint

     constraintsWithVisualFormat:@"V:|-8-[label]-8-|"

                         options:0 metrics:nil views:children]];

    [self.contentView addConstraints:[NSLayoutConstraint

     constraintsWithVisualFormat:@"V:|-8-[sw]-8-|"

                         options:0 metrics:nil views:children]];




Commentaires

Posts les plus consultés de ce blog

Tailles d'écran et iTunesConnect

 Lorsque l'on crée une nouvelle application, nous devons inclure des photos d'écran dans l'interface d'iTunes Connect :      Pour l'iPad, ce n'est pas bien compliqué, c'est indiqué, : Il faut les photos d'écran d'un iPadPro 12,9 pouce de 6ème (sans bouton home) et de 2e génération (avec le bouton home). Mais pour les iPhone c'est plus problématique, car il n'est indiqué que la taille de l'écran, et pas le modèle de l'appareil. Or dans la sélection des simulateurs, il n'y a pas les tailles des écrans des différent modèles ! Il faut donc se renseigner ici ;-) Appareil Taille iTunes Connect iPhone Pro Max 12, 13 6,7” Optionnel iPhone 11 Pro Max 6,5” Obligatoire iPhone 11, 12, 13 iPhone Pro 12, 13 6,1” iPhone X 5,8” iPhone 6+, 6S+, 7+, 8+ 5,5” Obligatoire iPhone 6, 6S, 7, 8 4,7” iPhone 5, 5S, SE 4” iPhone 4s 3,5” Personnellement, je ne savais pas que l'iPhone 11 Pro Max était le seul iPhone avec un écran 6,5 pouces !

Les bases de la programmation : Le binaire

Le binaire ”Ce monde est un code binaire où nous avons seulement deux options : accepter ou refuser. ” Ardit BEQIRI Lorsque l’on parle d’ordinateur on dit très souvent que ce n’est qu’un outil qui traite des 0 et 1, et ce n’est pas faux. Si l’on résume un ordinateur à de l’électronique, effectivement la mémoire, le processeur, les périphériques peuvent se résumer à des suites binaires, donc des suites de 0 et de 1. Mais c’est comme dire que le cerveau n’est qu’un imbroglio de neurones, c’est réducteur. La complexité du système est tel que l’on peut oublier qu’à la base c’est un système binaire, du reste un utilisateur d’ordinateur n’a même pas à savoir comment cela fonctionne, et même un programmeur n’a pas toujours à le savoir. Cependant, tous les langages informatiques comprennent une partie binaire. Et donc la compréhension du binaire est essentielle à un moment ou à un autre. En fait il y a plusieurs sujets interconnectés, la logique binaire, les opérations binaires, les nombr...

xCode: auto-incrémentation du BUILD_VERSION

 Lorsque vous envoyez votre application à Apple, vous devez mettre à jour deux valeurs, le numéro de version et le numéro de build : Pour le numéro de Version, ce n'est pas vraiment un problème puisque celui-ci n'augmente que lors d'une mise à jour sur l'appStore. Cela peut être fait à la main. Pour le numéro de Build, c'est plus embêtant. Si vous êtes comme moi, et que vous faites de nombreuses bêta, il faut mettre à jour le numéro à chaque envoi de l'app, et on oublie souvent d'incrémenter la valeur. Le plus simple est alors d'incrémenter automatiquement la valeur à chaque compilation. Ainsi plus besoin de s'en occuper. J'avais trouvé ce script, à insérer avant la compilation : Cela fonctionnait très bien, mais xCode a changé, et les nouveaux projets ne range plus directement le numéro de Build dans le fichier Info.plist et cela ne fonctionne donc plus. J'ai donc cherché une nouvelle méthode, et la voici. Tout d'abord il faut changer l...