recherche
Maisoninterface Webtutoriel CSSChanger les tons de peau des emoji programmatiques

Changer les tons de peau des emoji programmatiques

Modificateur de teint emoji: Guide de traitement programmatique

Ce n'est pas un secret que les emoji ont plusieurs couleurs de peau. Surtout dans le texte et les médias sociaux, ils sont très populaires. ✊? (Rising Black Fist) Les emojis ont même été nommés "Meilleurs emoji de 2020" par le prix Emoji World Emoji d'Emojipedia.

Chaque couleur de peau est un modificateur, et de nombreux emojis sont composés de modificateurs et d'encodages de base qui correspondent à des caractères spécifiques. Malheureusement, toutes les bibliothèques Emoji ne prennent pas en charge les modificateurs. Mais compte tenu de sa popularité, les modificateurs du teint emoji sont bien plus que la fonction «glaçage sur le gâteau». De plus, ils sont également un moyen de travail intelligent car ils nous permettent d'écrire du code plus modulaire et plus efficace.

Par conséquent, le but de cet article est de comprendre comment traiter les modificateurs d'emoji par programme. De cette façon, si vous rencontrez des situations où les tons de peau ne sont pas pris en charge ou que vous souhaitez créer des variantes personnalisées d'autres emojis, vous savez quoi faire!

Méthode de classement du teint Fitzpatrick

Le modificateur du teint a été officiellement ajouté aux emoji en 2015 dans le cadre de Unicode 8.0. Ils sont basés sur la méthode de l'évaluation du teint Fitzpatrick, une classification formelle des tons de peau humaine. Le tableau suivant montre comment les personnages des emoji correspondent au type Fitzpatrick:

Dans le cas d'utilisation le plus simple, lorsque l'un de ces caractères est attaché à un emoji qui prend en charge le modificateur du teint, il modifie le teint de l'emoji.

Autrement dit: ? ? = ??

Appliquer les modificateurs de couleur de peau à l'aide de CSS

Pour basculer entre les tons de peau des emoji à l'aide de CSS, nous commencerons avec le caractère emoji de base (?), Puis attacher les tons de peau en utilisant ::after pseudo.

En plus d'utiliser des caractères emoji rendus, nous pouvons également utiliser un code hexadécimal Unicode:

Utilisez JavaScript pour éliminer et changer les modificateurs de couleur de peau

Et si les emoji traités ont déjà appliqué le modificateur du teint? Pour ce faire, nous devons aller au-delà de CSS. Voici un exemple utilisant JavaScript:

Que se passe-t-il ici? Tout d'abord, nous commençons par un bébé emoji avec Fitzpatrick Type 4. Il est ensuite transmis à la fonction de removeModifier , qui recherche tout modificateur de teint et le supprime de la chaîne. Maintenant que nous avons des emojis sans modificateurs, nous pouvons ajouter tous les modificateurs que nous aimons.

Bien que cette approche fonctionne pour de nombreux emojis, nous avons des problèmes lors de l'introduction d'autres modificateurs. C'est pourquoi nous devons discuter maintenant ...

Traitement des séquences ZWJ

La séquence du connecteur à largeur zéro (ZWJ) est comme le mot composé d'Unicode. Ils se composent de deux emojis ou plus reliés par un connecteur à largeur zéro U 200D.

Les séquences ZWJ sont le plus souvent utilisées pour ajouter des modificateurs de genre aux emojis. Par exemple, un haltérophile plus ZWJ, plus un symbole féminin, équivaut à une femme d'haltérophilie (️? ️ ♀︎ =? ️‍♀️).

Lors du traitement des séquences ZWJ, vous devez faire attention aux points suivants:

  • Ces séquences ne sont que des suggestions. Ils proviennent de l'alliance Unicode et ne sont pas garantis d'être pris en charge sur chaque plate-forme. Si la plate-forme ne les prend pas en charge, une séquence de secours d'émojis régulière sera affichée.
  • Si un modificateur de teint est présent, il doit être inclus après les emoji mais avant ZWJ.
  • Certaines séquences ZWJ contiennent plusieurs emojis, chacun avec un modificateur de teint différent.

Compte tenu de ces informations, nous devons apporter les modifications suivantes à l'exemple de code précédent:

  • Le modificateur du teint doit être inséré après tout emoji de base, pas seulement attaché à la fin des emoji.
  • S'il y a plusieurs emojis dans la séquence ZWJ avec des modificateurs de teint, vous devez remplacer le modificateur pour chaque emoji.

limite

À partir de cet exemple, vous pouvez remarquer les limites de la cohérence. La vue de l'éditeur affiche chaque caractère de la séquence ZWJ, à l'exception du modificateur de teint, qui est immédiatement appliqué à leurs emojis correspondants. D'un autre côté, la console ou la vue de résultats essaiera de rendre les caractères de toute la séquence.

La prise en charge de cela varie d'une plate-forme à l'autre. Certains éditeurs peuvent essayer de rendre les séquences ZWJ, et tous les navigateurs ne prennent pas en charge le même ensemble de séquences ZWJ.

De plus, l'ajout de tons de peau à la séquence ZWJ nécessite de savoir ce qui est utilisé comme emoji de base. Bien que cela soit relativement simple dans le cas où les emojis sont fournis par des collections connues, les choses peuvent devenir plus difficiles si nous voulons pouvoir gérer les entrées arbitraires de l'utilisateur.

Notez également que la solution CSS dans cet article n'est pas compatible avec les séquences ZWJ.

Problèmes guidant le développement

J'ai réglé quelques questions que vous pourriez avoir besoin pour vous poser lors de la conception d'un système qui doit traiter les modificateurs du teint emoji:

  • Puis-je contrôler avec quels emojis mon système interagira?
  • Ma bibliothèque emoji contient-elle des informations sur les emojis prennent en charge les modificateurs du teint?
  • Mon système doit-il ajouter, supprimer ou modifier les modificateurs?
  • Ma plate-forme prend-elle en charge les séquences ZWJ? Si oui, lesquels?
  • Mon système doit-il prendre en charge les séquences ZWJ avec plusieurs modificateurs de teint?

Espérons qu'avec les réponses à ces questions et les exemples que nous voyons ici, vous aurez tout ce dont vous avez besoin pour soutenir les modificateurs du teint emoji en cas de besoin.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
CSS Flexbox vs Grid: une revue complèteCSS Flexbox vs Grid: une revue complèteMay 12, 2025 am 12:01 AM

Le choix de Flexbox ou de la grille dépend des exigences de mise en page: 1) Flexbox convient aux dispositions unidimensionnelles, telles que la barre de navigation; 2) La grille convient aux dispositions bidimensionnelles, telles que les dispositions de magazines. Les deux peuvent être utilisés dans le projet pour améliorer l'effet de mise en page.

Comment inclure les fichiers CSS: méthodes et meilleures pratiquesComment inclure les fichiers CSS: méthodes et meilleures pratiquesMay 11, 2025 am 12:02 AM

La meilleure façon d'inclure des fichiers CSS est d'utiliser des balises pour introduire des fichiers CSS externes dans la pièce HTML. 1. Utilisez des balises pour introduire des fichiers CSS externes, tels que. 2. Pour les petits ajustements, le CSS en ligne peut être utilisé, mais doit être utilisé avec prudence. 3. Les grands projets peuvent utiliser des préprocesseurs CSS tels que SASS ou moins pour importer d'autres fichiers CSS via @Import. 4. Pour les performances, les fichiers CSS doivent être fusionnés et CDN doit être utilisé et compressé à l'aide d'outils tels que CSSNANO.

Flexbox vs Grid: Dois-je les apprendre tous les deux?Flexbox vs Grid: Dois-je les apprendre tous les deux?May 10, 2025 am 12:01 AM

Oui, vous émeuble-chouchoudion-dimensionnal, flexiblelayAndavigationMenus.2)

Mécanique orbitale (ou comment j'ai optimisé une animation de clés CSS)Mécanique orbitale (ou comment j'ai optimisé une animation de clés CSS)May 09, 2025 am 09:57 AM

À quoi cela ressemble-t-il de refactor votre propre code? John Rhea sépare une vieille animation CSS qu'il a écrite et traverse le processus de réflexion pour l'optimiser.

Animations CSS: est-il difficile de les créer?Animations CSS: est-il difficile de les créer?May 09, 2025 am 12:03 AM

CSSANIMATIONSARENOTINÉMENT HAUTS BUTREQUIREPRACTICIT ENCRIPTION DES PROFESSIONS DESPROPERTIES ET TROUVEMENT

@KeyFrames CSS: les astuces les plus utilisées@KeyFrames CSS: les astuces les plus utiliséesMay 08, 2025 am 12:13 AM

@ KeyframeSispopulardUetOtsSversatity andpowerCreatingsMoothcSSanimations.KeyTrickSinclude: 1) DefiingsMoothTransitionsBetwean

Compteurs CSS: un guide complet de la numérotation automatiqueCompteurs CSS: un guide complet de la numérotation automatiqueMay 07, 2025 pm 03:45 PM

CSSCOUNTERSAREUSEUSTTOMAGAUTAMAMATALUMENTSINDWEBDESIGNS.1) Ils ont été des cas de contenu, des listitems et de la forme.

Ombres de défilement moderne à l'aide d'animations axées sur le défilementOmbres de défilement moderne à l'aide d'animations axées sur le défilementMay 07, 2025 am 10:34 AM

L'utilisation d'ombres de défilement, en particulier pour les appareils mobiles, est un peu de UX subtil que Chris a couvert auparavant. Geoff a couvert une approche plus récente qui utilise la propriété d'animation-timeline. Voici encore une autre façon.

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

<🎜>: Bubble Gum Simulator Infinity - Comment obtenir et utiliser les clés royales
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
Nordhold: Système de fusion, expliqué
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Comment déverrouiller le grappin
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

MantisBT

MantisBT

Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

SublimeText3 version anglaise

SublimeText3 version anglaise

Recommandé : version Win, prend en charge les invites de code !

MinGW - GNU minimaliste pour Windows

MinGW - GNU minimaliste pour Windows

Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

DVWA

DVWA

Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

Version crackée d'EditPlus en chinois

Version crackée d'EditPlus en chinois

Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code