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

IOS14 et Bonjour qui ne fonctionne pas.

 J'utilise Bonjour dans certaines de mes application pour échanger des données entre appareils se trouvant sur le même réseau local.  Depuis IOS14, vous devez déclarer dans info.plist : <key> NSLocalNetworkUsageDescription </key> <string> L'accès au réseau local est obligatoire pour.... </string> <key> NSBonjourServices </key> <array> <string> _http._tcp </string> </array>  La clef NSLocalNetworkUsageDescription est obligatoire pour toute utilisation du réseau local (en dehors des produits Apple comme AirDrop, AirPrint, etc.). C'est la même chose que l'accès à la caméra ou au micro, vous devez dire pourquoi vous désirez cet accès dans votre application. La clef NSBonjourServices est spécifique pour le protocole Bonjour, elle contient la liste des services que vous partagez avec Bonjour. Dans l'exemple, il s'agit d'un serveur web (http).

UITableView avec multi-sélection sur Mac Catalyst

Si vous mettez à YES les attributs Multi Selection  et Multi Sélection During Editing d'un UITableView, cela ne fonctionnera pas comme attendu sur Mac. C'est juste énervant et voici ubout de code qui règle le problème. #if TARGET_OS_MACCATALYST -( NSIndexPath *) tableView :( UITableView *)tableView willSelectRowAtIndexPath :( NSIndexPath *)indexPath {     if ([tableView. indexPathsForSelectedRows containsObject :indexPath]) {         [tableView deselectRowAtIndexPath :indexPath animated : NO ];         return nil ;     }     return indexPath; } -( NSIndexPath *) tableView :( UITableView *)tableView willDeselectRowAtIndexPath :( NSIndexPath *)indexPath {     if ([tableView. indexPathsForSelectedRows containsObject :indexPath]) {         return nil ;     }     return indexPath; } -( BOOL ) tableView :( UITableView *)tableView shouldHighlightRowAtIndexPath :( NSIndexPath *)indexPath {     for ( NSIndexPath *ip in tableView. indexPathsForSelectedRows ) {         [tabl

Tiret insécable

 Ecrivant un livre sur CoreAnimation en Objective-C et en Swift, j'écris souvent "Objective-C".  Mais je ne souhaite pas que la césure du texte se face avec le C, il me faut donc un tiret insécable. Malheureusement il n'y a pas de tiret insécable sur le clavier du Mac, il faut donc utiliser le caractère Unicode U+2011. Mais le clavier du Mac ne comprends pas non plus par défaut de possibilité d'ajouter un caractère par son code Unicode.  Il faut donc aller dans les réglages d'Apple, dans les réglages du clavier, dans les méthodes de saisie et ajouter le clavier "Universel (Unicode Hex)". Ensuite, lorsque l'on a besoin d'un caractère Unicode, on change de clavier et on utilise la touche Option + le code en hexadécimal. Pour accélérer le changement d'un clavier à l'autre, toujours dans les réglages du clavier, vous pouvez activer les raccourcis clavier. Bon, c'était encore trop long, alors j'ai mis un remplacement automatique da