cari
Rumahhujung hadapan webtutorial cssMenukar Nada Kulit Emoji Programmatik

Menukar Nada Kulit Emoji Programmatik

Pengubah nada kulit emoji: Panduan Pemprosesan Programatik

Bukan rahsia lagi bahawa emoji mempunyai pelbagai warna kulit. Terutama dalam teks dan media sosial, mereka sangat popular. ✊? (Rising Black Fist) Emojis bahkan dinamakan "Emoji Terbaik 2020" oleh Anugerah Emoji Dunia Emojipedia.

Setiap warna kulit adalah pengubah suai, dan banyak emojis terdiri daripada pengubah dan pengekodan asas yang sesuai dengan aksara tertentu. Malangnya, tidak setiap perpustakaan emoji menyokong pengubah. Tetapi memandangkan popularitinya, pengubah nada kulit emoji lebih banyak daripada ciri "icing on the cake". Selain itu, mereka juga merupakan cara yang bijak untuk bekerja kerana mereka membenarkan kami menulis lebih banyak kod modular dan lebih cekap.

Oleh itu, tujuan artikel ini adalah untuk mengetahui cara memproses pengubah emoji secara programatik. Dengan cara ini, jika anda menghadapi situasi di mana nada kulit tidak disokong, atau ingin membuat varian tersuai emojis lain, anda tahu apa yang perlu dilakukan!

Kaedah penggredan nada kulit fitzpatrick

Pengubah nada kulit secara rasmi ditambah kepada emoji pada tahun 2015 sebagai sebahagian daripada Unicode 8.0. Mereka didasarkan pada kaedah penarafan nada kulit Fitzpatrick, klasifikasi formal nada kulit manusia. Jadual berikut menunjukkan bagaimana watak emoji sepadan dengan jenis Fitzpatrick:

Dalam kes penggunaan yang paling mudah, apabila salah satu daripada watak -watak ini dilampirkan pada emoji yang menyokong pengubah nada kulit, ia mengubah nada kulit emoji.

Dengan kata lain :? ? = ??

Sapukan pengubah warna kulit menggunakan CSS

Untuk beralih antara nada kulit emoji menggunakan CSS, kita akan bermula dengan watak Emoji Asas (?) Dan kemudian pasangkan nada kulit menggunakan ::after pemilih pseudo.

Di samping menggunakan aksara emoji yang diberikan, kita juga boleh menggunakan kod heksadesimal unicode:

Gunakan JavaScript untuk mengeluarkan dan menukar pengubah warna kulit

Bagaimana jika emoji yang diproses telah menggunakan pengubah nada kulit? Untuk melakukan ini, kita perlu melampaui CSS. Berikut adalah contoh menggunakan JavaScript:

Apa yang berlaku di sini? Pertama, kita mulakan dengan emoji bayi dengan Fitzpatrick Type 4. Ia kemudiannya diserahkan kepada fungsi removeModifier , yang mencari pengubah nada kulit dan menghilangkannya dari rentetan. Sekarang kita mempunyai emojis tanpa pengubah, kita boleh menambah sebarang pengubah yang kita suka.

Walaupun pendekatan ini berfungsi untuk banyak emojis, kami mempunyai masalah ketika memperkenalkan pengubah lain. Itulah sebabnya kita perlu berbincang sekarang ...

Memproses urutan ZWJ

Urutan penyambung sifar (ZWJ) adalah seperti perkataan kompaun Unicode. Mereka terdiri daripada dua atau lebih emojis yang dihubungkan dengan penyambung sifar lebar u 200d.

Urutan ZWJ paling biasa digunakan untuk menambah pengubah jantina kepada emojis. Sebagai contoh, weightlifter ditambah ZWJ, ditambah simbol wanita, bersamaan dengan wanita angkat berat (onton? ️ ♀︎ =? Onton ‍♀ ‍♀ ‍♀ ‍♀ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎ ♀︎

Apabila memproses urutan ZWJ, anda perlu memberi perhatian kepada perkara berikut:

  • Urutan ini hanyalah cadangan. Mereka datang dari Perikatan Unicode dan tidak dijamin disokong pada setiap platform. Jika platform tidak menyokong mereka, urutan sandaran emojis biasa akan dipaparkan.
  • Jika pengubah nada kulit hadir, ia mesti dimasukkan selepas emoji tetapi sebelum ZWJ.
  • Sesetengah urutan ZWJ mengandungi pelbagai emojis, masing -masing dengan pengubah nada kulit yang berbeza.

Memandangkan maklumat ini, kita perlu membuat perubahan berikut kepada contoh kod sebelumnya:

  • Pengubah nada kulit perlu dimasukkan selepas mana -mana emoji asas, bukan hanya melekat pada akhir emoji.
  • Sekiranya terdapat banyak emojis dalam urutan ZWJ dengan pengubah nada kulit, anda perlu menggantikan pengubah suai untuk setiap emoji.

had

Dari contoh ini, anda dapat melihat batasan konsistensi. Pandangan editor memaparkan setiap watak dalam urutan ZWJ, kecuali pengubah nada kulit, yang segera digunakan untuk emojis yang sepadan. Sebaliknya, konsol atau paparan hasil akan cuba menjadikan watak -watak keseluruhan urutan.

Sokongan untuk ini berbeza dari platform ke platform. Sesetengah editor mungkin cuba menjadikan urutan ZWJ, dan tidak semua pelayar menyokong set urutan ZWJ yang sama.

Di samping itu, menambah nada kulit ke urutan ZWJ memerlukan mengetahui apa yang digunakan sebagai emoji asas. Walaupun ini agak mudah dalam kes di mana emojis disediakan oleh koleksi yang diketahui, perkara -perkara boleh menjadi lebih sukar jika kita mahu dapat mengendalikan input sewenang -wenang dari pengguna.

Juga, ambil perhatian bahawa penyelesaian CSS dalam artikel ini tidak serasi dengan urutan ZWJ.

Isu membimbing pembangunan

Saya telah menyusun beberapa soalan yang mungkin perlu anda tanyakan kepada diri sendiri semasa merancang sistem yang perlu berurusan dengan pengubah nada kulit emoji:

  • Bolehkah saya mengawal apa emojis sistem saya akan berinteraksi?
  • Adakah perpustakaan emoji saya mengandungi maklumat mengenai emojis yang menyokong pengubah nada kulit?
  • Adakah sistem saya perlu menambah, memadam, atau menukar pengubah?
  • Adakah platform saya menyokong urutan ZWJ? Jika ya, yang mana?
  • Adakah sistem saya perlu menyokong urutan ZWJ dengan pengubah nada kulit berganda?

Mudah -mudahan dengan jawapan kepada soalan -soalan ini dan contoh -contoh yang kita lihat di sini, anda akan mempunyai semua yang anda perlukan untuk menyokong pengubah nada kulit emoji apabila diperlukan.

Atas ialah kandungan terperinci Menukar Nada Kulit Emoji Programmatik. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Flexbox vs Grid: Sekiranya saya belajar kedua -duanya?Flexbox vs Grid: Sekiranya saya belajar kedua -duanya?May 10, 2025 am 12:01 AM

Ya, youdyhouldlearnbothflexboxandgrid.1) flexboxisidealforone-dimensi, flexiblelayoutslikenavigasiMenus.2)

Mekanik Orbital (atau bagaimana saya mengoptimumkan animasi kerangka utama CSS)Mekanik Orbital (atau bagaimana saya mengoptimumkan animasi kerangka utama CSS)May 09, 2025 am 09:57 AM

Apa yang kelihatan seperti refactor kod anda sendiri? John Rhea memisahkan animasi CSS lama yang dia tulis dan berjalan melalui proses pemikiran mengoptimumkannya.

Animasi CSS: Adakah sukar untuk mencipta mereka?Animasi CSS: Adakah sukar untuk mencipta mereka?May 09, 2025 am 12:03 AM

Csanimationsarenotinherenthardbutrequirepracticeandundunderpanderofcsspropertiesandtimingfunctions.1) startwithsimpleanimationslikescalingabuttonhoverusingkeyframes.2)

@KeyFrames CSS: Trik yang paling banyak digunakan@KeyFrames CSS: Trik yang paling banyak digunakanMay 08, 2025 am 12:13 AM

@keyframesispopularduetoitsversatilityAndPowerIncreatingSmoothcsSanimations.KeyTrickSinclude: 1) definisiMoothTransitionSbetweenStates, 2) AnimatingMultiplePropertiSti

Kaunter CSS: Panduan Komprehensif untuk Penomboran AutomatikKaunter CSS: Panduan Komprehensif untuk Penomboran AutomatikMay 07, 2025 pm 03:45 PM

Csscountersareusedtomanageautomaticnumberinginwebdesigns.1) mereka yang boleh dimanfaatkan, listitems, andcustomnumbering.2) AdvancedusesIndenestedNumberingsystems.3) cabaran yang terkandung di dalam cabaran

Bayang-bayang tatal moden menggunakan animasi yang didorong oleh tatalBayang-bayang tatal moden menggunakan animasi yang didorong oleh tatalMay 07, 2025 am 10:34 AM

Menggunakan bayang -bayang skrol, terutamanya untuk peranti mudah alih, adalah sedikit UX yang telah diliputi oleh Chris sebelum ini. Geoff merangkumi pendekatan yang lebih baru yang menggunakan harta animasi-masa. Berikut adalah satu lagi cara.

Mengkaji semula peta imejMengkaji semula peta imejMay 07, 2025 am 09:40 AM

Mari kita lari melalui penyegaran cepat. Peta imej tarikh kembali ke HTML 3.2, di mana, pertama, peta sisi pelayan dan kemudian peta sisi klien yang ditakrifkan di atas imej menggunakan elemen peta dan kawasan.

Negeri Devs: Tinjauan untuk Setiap PemajuNegeri Devs: Tinjauan untuk Setiap PemajuMay 07, 2025 am 09:30 AM

Kajian Negeri Devs kini dibuka untuk penyertaan, dan tidak seperti tinjauan sebelumnya ia meliputi segala -galanya kecuali kod: kerjaya, tempat kerja, tetapi juga kesihatan, hobi, dan banyak lagi. 

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

Versi Mac WebStorm

Versi Mac WebStorm

Alat pembangunan JavaScript yang berguna

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod