Accéder au contenu principal

Parcourir des dates avec NSDate

Pour utiliser NSDate nous avons besoin de dire de quoi nous parlons... En effet une date n'a de sens que par rapport à un calendrier (Arabe, Hébreux, Japonais, etc...).
Notre calendrier (à nous français) est le calendrier grégorien. Nous avons donc besoin d'une variable NSCalendar initialisée en grégorien.

NSCalendar* calendar = [[NSCalendar alloc] initWithCalendarIdentifierNSCalendarIdentifierGregorian];

Ensuite si nous avons besoin de récupérer un élément de la date, nous avons besoin d'une variable NSDateComponent

NSDateComponents* components = [calendar components: NSCalendarUnitYear | NSCalendarUnitMonthNSCalendarUnitDay fromDate:[NSDate new]];

Le [NSDate new] fournit la date du jour.
Vous devez définir quelles parties de la date vous intéresse, quels composants. Ici, par exemple nous coulons récupérer :
- L'année : NSCalendarUnitYear
- Le mois : NSCalendarUnitMonth
- Le jour dans le mois : NSCalendarUnitDay

Après, nous pouvons récupérer les données dans l'objet composants, par exemple : composants.day, ou composants.weekday. Mais nous pouvons aussi les changer... Ainsi le voici la fonction pour extraire le premier jour du mois :


-(NSDate*)firstDayOfCurrentMonth {
    NSCalendar* calendar = [[NSCalendar alloc] initWithCalendarIdentifierNSCalendarIdentifierGregorian];
    NSDateComponents* components = [calendar components: NSCalendarUnitYear | NSCalendarUnitMonth | NSCalendarUnitDay fromDate:[NSDate date]];
    components.day = 1;
    return [calendar dateFromComponents:components];
}

Mais, aujourd'hui, ce qui m'intéresse c'est d'avoir le mois précédent... Donc :


- (NSDate*)previousMonthFrom:(NSDate*)date  {
    NSCalendar* calendar = [[NSCalendar alloc] initWithCalendarIdentifierNSCalendarIdentifierGregorian];

    NSDateComponents* components = [calendar componentsNSCalendarUnitYear | NSCalendarUnitMonth | NSCalendarUnitDay fromDate:date];

    components.day = 1;
    if(components.month==1) {
        components.month = 12;
        components.year--;
    } else {
        components.month--;
    }

    return [calendar dateFromComponents:components];
}

Ensuite c'est d'avoir la date en chaine de caractères. Là, j'utilise NSDateFormater. Même si nous sommes en grégorien, la date au format texte peut-être en anglais, en français, ou en allemand, etc...


-(NSString*)monthYearOfDate:(NSDate*)date {
    NSDateFormatter *dateFormatter = [NSDateFormatter new];
    dateFormatter.locale = [NSLocale localeWithLocaleIdentifier:[[NSLocale preferredLanguages] firstObject]];
    dateFormatter.dateFormat = @"MMMM yyyy";
    return [dateFormatter stringFromDate:date];
}

Le preferredLanguage va regarder dans les réglages de l'appareil et mettre "Janvier", "January", "Januar" ou encore "enero" selon la première langue définit dans les réglages de l'appareil. Le "MMMM" veut dire le nom du mois au format long. Regardez la documentation de NSDateFormatter pour voir toutes les possibilités.










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 !

malloc: xzm: failed to initialize deferred reclamation buffer

Lorsque je lance une de mes applications avec Xcode sur mon iPhone .... J'ai ce message de début :  malloc: xzm: failed to initialize deferred reclamation buffer (46)  Et franchement, je n'aime pas avoir des message que je ne comprends pas et qui contiennent le mot "failed" ! Mais le message n'existe pas avec mon iPad IOS16. Donc, ok, malloc je connais, on parle de la fonction de base d'allocation de mémoire système, il y a pleins d'outils pour les problèmes d'allocation mémoire, "xzm" doit être un de ces outils. Je ne trouve rien sur internet ! RIEN ! Perplexity ou Claude ne savent pas non plus ce que c'est. Je suis obligé de faire des suppositions... XZ est un format de compression conçu pour remplacer BZIP qui est conçu pour remplacer GZIP qui est conçu pour remplacer Z. Peut-être que les données de debug de Xcode transitent en étant compressé par défaut ? Allons voir dans le schéma du projet, pour voir les options concernant les mallo...

Réglages MACCATALYST

Lors de l'envoi de la mise à jour de mon application Appel sur Mac, Apple m'a refusé cette mise à jour au motif que le bouton Réglages ne fonctionnait pas. Il faut dire que mon application est une application IOS qui fonctionne sur Mac avec MACCATALYST, c'est à dire un peu comme dans un simulateur. Jusque là, Apple n'avait jamais fait de remarque sur ce sujet, il y a dû y avoir des changements de politique de test. C'est un peu gonflé de la part d'Apple, puisqu'une application IOS n'a pas forcément de réglages systèmes, ni de réglages tout court. Or, MACCATALYST crée le menu système avec une entrée "Réglages" par défaut, sans que le développeur n'ai rien demandé. Mais il n'y a pas d'action par défaut... C'est idiot, autant ne pas mettre l'entrée du tout. Bon, ceci étant dit, il faut tout de même gérer la chose. On ne peut pas le faire dans l'éditeur de ressource (ce que l'on ferait avec une application MacOSX), le me...