Android از کتابخانه ICU و پروژه CLDR برای ارائه یونیکد و سایر پشتیبانی های بین المللی استفاده می کند. بحث این صفحه در مورد پشتیبانی از یونیکد و بین المللی سازی به دو بخش تقسیم می شود: Android 6.0 (سطح API 23) و پایین تر، و Android 7.0 (سطح API 24) و بالاتر.
پشتیبانی از یونیکد و بین المللی سازی از طریق Android 6.0 (سطح API 23)
پلتفرم اندروید از ICU و CLDR برای پیادهسازی کلاسهای مختلف برای مدیریت املای لاتین و غیر لاتین، نمایش کلاسهایی مانند Locale
، Character
و بسیاری از زیرکلاسهای java.text
استفاده میکند. برنامهای که به عملکردهای بینالمللی فراتر از کلاسهای در معرض نیاز دارد و نسخههای پلتفرم را از طریق Android 6.0 (سطح API 23) هدف قرار میدهد، باید شامل کتابخانه ICU باشد.
نسخه سازی
نسخه های متوالی پلتفرم اندروید با نسخه های جدیدتر ICU و نسخه های CLDR و Unicode مربوطه مطابقت دارد. جدول 1 این مطابقت را از طریق Android 6.0 (سطح API 23) نشان می دهد.
پلتفرم (سطح API) | آی سی یو | CLDR | یونیکد |
---|---|---|---|
Android 1.5–2.0 (سطوح API 3–7) | 3.8 | 1.5 | 5.0 |
Android 2.2 (API سطح 8) | 4.2 | 1.7 | 5.1 |
Android 2.3–3.0 (سطوح API 9-13) | 4.4 | 1.8 | 5.2 |
Android 4.0 (سطوح API 14-15) | 4.6 | 1.9 | 6.0 |
Android 4.1 (سطوح API 16-17) | 4.8 | 2.0 | 6.0 |
Android 4.3 (سطح API 18) | 50 | 22.1 | 6.2 |
Android 4.4 (سطوح API 19-20) | 51 | 23 | 6.2 |
Android 5.0 (سطوح API 21–22) | 53 | 25 | 6.3 |
Android 6.0 (سطح API 23) | 55.1 | 27.0.1 | 7.0 |
چارچوب Android پشتیبانی جامعتری از Unicode و بینالمللیسازی برنامههایی را که Android 7.0 (سطح API 24) و بالاتر را هدف قرار میدهند، ارائه میکند. بخش بعدی این صفحه جزئیات مربوط به آن پشتیبانی را ارائه می دهد.
پشتیبانی از یونیکد و بین المللی سازی در اندروید 7.0 (سطح API 24) و بالاتر
برای Android 7.0 (سطح API 24) و بالاتر، پلتفرم Android زیرمجموعهای از APIهای ICU4J را در اختیار توسعهدهندگان برنامه قرار میدهد تا تحت بسته android.icu
از آن استفاده کنند. ICU4J مجموعه ای منبع باز و پرکاربرد از کتابخانه های جاوا است که از یونیکد و پشتیبانی بین المللی برای برنامه های نرم افزاری پشتیبانی می کند.
API های ICU4J از داده های محلی سازی موجود در دستگاه استفاده می کنند. در نتیجه، می توانید با کامپایل نکردن کتابخانه های ICU4J در برنامه خود، ردپای برنامه خود را کاهش دهید. در عوض، میتوانید با آنها در چارچوب تماس بگیرید. اگر این کار را انجام میدهید، ممکن است بخواهید چندین نسخه از APK خود را ارائه دهید، بنابراین کاربرانی که از نسخههای Android پایینتر از Android 7.0 (سطح API 24) استفاده میکنند، میتوانند نسخهای از برنامه را دانلود کنند که شامل کتابخانههای ICU4J است.
این بخش با ارائه برخی اطلاعات اولیه در مورد حداقل سطوح API Android مورد نیاز برای پشتیبانی از این کتابخانه ها آغاز می شود. سپس آنچه را که باید در مورد پیاده سازی ICU4J مخصوص اندروید بدانید، توضیح می دهد. در نهایت به شما می گوید که چگونه از API های ICU4J در چارچوب اندروید استفاده کنید.
ICU4J در اندروید
Android زیرمجموعه ای از API های ICU4J را از طریق بسته android.icu
به جای com.ibm.icu
در معرض دید قرار می دهد. برخی از APIهای ICU4J به دلایلی مانند منسوخ شدن یا عدم ثبات APIها توسط چارچوب Android در معرض نمایش قرار نمی گیرند. از آنجایی که تیم ICU در آینده API ها را منسوخ می کند، اندروید نیز آنها را به عنوان منسوخ شده علامت گذاری می کند اما همچنان آنها را شامل می شود.
در اینجا چند یادآوری وجود دارد:
- APIهای چارچوب Android ICU4J شامل همه APIهای ICU4J نیستند.
- APIهای موجود در چارچوب Android جایگزین پشتیبانی Android برای بومیسازی با منابع نمیشوند.
- در برخی موارد، چارچوب Android از کاراکترهای بیشتری نسبت به کتابخانه های ICU پشتیبانی می کند. برای مثال، این موضوع در مورد پشتیبانی کلاس
android.text
از ایموجی صادق است.
از com.ibm.icu به بسته android.icu مهاجرت کنید
اگر قبلاً از APIهای ICU4J در برنامه خود استفاده میکنید و APIهای android.icu
نیازهای شما را برآورده میکنند، پس مهاجرت به APIهای فریمورک از شما میخواهد تا واردات جاوا خود را از com.ibm.icu
به android.icu
تغییر دهید. سپس می توانید کپی فایل های ICU4J خود را از برنامه حذف کنید.
توجه : APIهای چارچوب ICU4J از فضای نام android.icu
به جای com.ibm.icu
استفاده می کنند. این برای جلوگیری از تداخل فضای نام در برنامههایی است که دارای کتابخانههای com.ibm.icu
خود هستند.
از دیگر APIهای Android SDK به APIهای android.icu مهاجرت کنید
برخی از کلاسها در بستههای java
و android
دارای معادلهایی با کلاسهای ICU4J هستند. با این حال، ICU4J اغلب پشتیبانی گسترده تری از استانداردها و زبان ها ارائه می کند.
جدول 2 چند نمونه از این معادل ها را برای شروع کار نشان می دهد:
کلاس | جایگزین ها |
---|---|
java.lang.Character | android.icu.lang.UCharacter |
java.text.BreakIterator | android.icu.text.BreakIterator |
java.text.DecimalFormat | android.icu.text.DecimalFormat |
java.util.Calendar | android.icu.util.Calendar |
android.text.BidiFormatter | android.icu.text.Bidi |
android.text.format.DateFormat | android.icu.text.DateFormat |
android.text.format.DateUtils | android.icu.text.DateFormat android.icu.text.RelativeDateTimeFormatter |
ICU4C در اندروید
Android زیرمجموعهای از APIهای ICU4C را از طریق کتابخانه libicu.so
به جای libicuuc.so
یا libicui18n.so
نشان میدهد. APIها با اندروید 12 (سطح API 31) در دسترس هستند. هدرهای NDK با نسخه NDK r22b در دسترس هستند. هیچ C++ API از طریق Android NDK نمایش داده نمی شود. برخی از C API در دسترس نیستند.
نسخه سازی
نسخه های متوالی پلتفرم اندروید با نسخه های جدیدتر ICU و نسخه های CLDR و Unicode مربوطه مطابقت دارد. جدول 3 این مطابقت را از Android 7.0 (سطح API 24) نشان می دهد. از VersionInfo.ICU_VERSION
API (از Android 7.0 موجود است) برای به دست آوردن اطلاعات نسخه ICU در زمان اجرا استفاده کنید.
پلتفرم (سطح API) | آی سی یو | CLDR | یونیکد |
---|---|---|---|
Android 7.0 - 7.1 (سطوح API 24 - 25) | 56 | 28 | 8.0 |
Android 8.0 - 8.1 (سطوح API 26 - 27) | 58.2 | 30.0.3 | 9.0 |
Android 9 (سطح API 28) | 60.2 | 32.0.1 | 10.0 |
Android 10 (سطح API 29) | 63.2 | 34 | 11.0 |
Android 11 (سطح API 30) | 66.1 | 36 | 13.0 |
Android 12 (سطح API 31 - 32) | 68.2 | 38.1 | 13.0 |
Android 13 (سطح API 33) | 70.1 | 40 | 14.0 |
Android 14 (سطح API 34) | 72.1 | 42 | 15.0 |
Android 15 (سطح API 35) | 75.1 | 45 | 15.1 |
تنظیم فرمت زمان 24h/12h
ICU در Android تنظیمات قالب ساعت 24/12 ساعت کاربر را که ازDateFormat.is24HourFormat()
بدست آمده است، رعایت نمی کند. برای مشاهده این تنظیم، از روشهای قالببندی زمان DateFormat
یا DateUtils
استفاده کنید یا از الگوهای قالببندی زمان ICU با نمادهای الگوی ساعت مناسب ('h' برای 12h، 'H' برای 24h) برای مقادیر مختلف is24HourFormat()
استفاده کنید. به عنوان مثال، این کد یک رشته با زمان فعلی تولید می کند که تنظیمات 12h/24h کاربر را مشاهده می کند: کاتلین
val skeleton: String = if (DateFormat.is24HourFormat(context)) "Hm" else "hm" val formattedTime: String = android.icu.text.DateFormat.getInstanceForSkeleton( skeleton, Locale.getDefault()).format(Date() )
جاوا
String skeleton = DateFormat.is24HourFormat(context) ? "Hm" : "hm"; String formattedTime = android.icu.text.DateFormat.getInstanceForSkeleton(skeleton, Locale.getDefault()).format(new Date());
پایداری Transliterator
با شروع از Android 10 (سطح API 29)،Transliterator
برای نویسهگردانی متن از یک قالب به فرمت دیگر ارائه شده است. مجموعه شناسههای نویسهگردانی موجود در نسخهها و دستگاههای Android ناپایدار است. سازندگان دستگاه ممکن است شناسههای نویسهگردانی اضافی اضافه کنند. توسعهدهندگان باید شناسههای موجود را که از Transliterator.getAvailableIDs()
گرفتهاند، قبل از نویسهگردانی متن بررسی کنند.صدور مجوز
ICU4J تحت مجوز ICU منتشر شده است. برای جزئیات، به راهنمای کاربر ICU مراجعه کنید.