تبلیغات
تبلیغات

کتابخانه Persian Material DateTime Picker اندروید – انتخاب تاریخ شمسی

کتابخانه Persian Material DateTime Picker اندروید
دیت تایم پیکر شمسی برای اندروید + انتخابگر زمان
تقومی شمسی اندروید


یکی از معظلات اصلی برنامه نویسان ایرانی این است که باید با تاریخ شمسی دست و پنجه نرم کنند! که البته چیز بدی نیست و این گونه موارد برای ایرانیان باعث می‌شود تا با مدیریت پیچدگی‌های بیشتر، توانایی برنامه نویسیشان افزایش یابد 🙂

کتابخانه‌ی PersianMaterialDateTimePicker، یکی از کتابخانه‌های فارسی اندروید می‌باشد که برای کار با تاریخ شمسی نوشته شده است و با استفاده از آن می‌توانید به سادگی دیالوگ انتخاب تاریخ و زمان را به کاربر نمایش داده و سپس مقادیر انتخاب شده توسط کاربر را دریافت کنید.

روش استفاده از کتابخانه

اولین قدم این است که کتابخانه را به پروژه‌ی خود اضافه کنید! شما بهتر است فایل پروژه‌ی این کتابخانه را از انتهای مطلب دانلود کرده و آن را به عنوان یک ماژول به پروژه‌ی خود اضافه کنید تا در صورت نیاز، تغییراتی در آن اعمال کنیدو هم‌چنین، با روند کار آن آشنا شده و به دانش خود بیافزایید! اما می‌توانید از طریق گریدل (Gradle) نیز این کار را انجام دهید:

کدهای زیر بافرض نوشته شدن در یک اکتیویتی می‌باشند.

نمایش یک تایم پیکر (انتخاب زمان)

برای این‌که به کاربر امکان انتخاب یک زمان (ساعت و دقیقه‌ی) دلخواهش را بدهیم، می‌توانیم از کد زیر استفاده کنیم! البته گرچه برای انتخاب ساعت نیازی به کتابخانه‌ی جانبی نیست، ولی خب این امکان را هم دارد:

ابتدا یک آبجکت از کلاس PersianCalendar می‌سازیم و اگر هیچ مقداری را برای آن تنظیم نکنیم، تاریخ و زمان حال را نمایش می‌دهد!
سپس یک دیالوگ انتخاب زمان از کلاس TimePickerDialog ای که مربوط به این کتابخانه (نه کتابخانه‌ی خود اندروید) است را با استفاده از متد استایتک newInstance می‌سازیم که به ترتیب ورودی‌های زیر را دریافت می‌کند:

  • ورودی اول:
    رویداد OnTimeSetListener را برای آن تنظیم می‌کنیم که داخل آن زمان انتخاب شده بعد از کلیک کاربر روی دکمه‌ی تایید دیالوگ، ارسال می‌شود.
    داخل متد onTimeSet این رویداد، ساعت و دقیقه را بعد از دریافت شدن بررسی می‌کنیم که اگر مقدارشان کم‌تر 0 بود، یک 0 نیز به سمت چپ آن اضافه شود تا به صورت دو رقمی نمایش داده شود. البته این مورد کاملا دلخواه بوده و اجباری نیست.؛ مگر در شرایطی خاص مثل ارسال DateTime به سمت سرور و ذخیره‌ی آن در دیتابیس که باید حتما دو رقمی باشند.
  • ورودی دوم
    ساعت پیش‌فرض را از آبجکت now می‌گیریم که همان ساعت فعلی سیستم است.
  • ورودی سوم:
    دقیقه‌ی پیش‌فرض را از آبجکت now می‌گیریم که همان دقیقه‌ی فعلی سیستم است.
  • ورودی سوم:
    مشخص می‌کنیم که زمان به صورت 24 ساعتی می‌باشد یا 12 ساعتی! که در کد بالا ما 24 ساعتی را با ارسال true تنظیم کرده‌ایم و بدیهی است که برای 12 ساعتی هم باید false را به داخل آن ارسال کنیم.

متد setThemeDark:
تنظیم تم دیالوگ (مقدار true یعنی تم تاریک و مقدار false یعنی تم پبش‌فرض)


متد setOnCancelListener:
تنظیم رویداد برای زمانی که روی دکمه‌ی لغو دیالوگ کلیک شود.


متد show:
نمایش دیالوگ با استفاده از getFragmentManager
می‌توانید سورس پروژه را ویرایش کرده و DialogFragment را از android.support.v4.app.DialogFragment ایمپورت کنید تا به جای getFragmentManager از getSupportFragmentManager استفاده کنید.
ورودی دوم، “FuLLKade” می‌باشد که به عنوان تگ برای Log های کتابخانه استفاده می‌شود.

نمایش یک انتخاب گر تاریخ

در مورد انتخابگر تاریخ نیز به صورت زیر عمل می‌کنیم:

تمام موارد همانند انتخاب گر زمان است با این تفاوت که در این‌جا از DatePickerDialog استفاده می‌کنیم و در ورودی‌ها نیز رویداد OnDateSetListener و تاریخ پیش‌فرض را تنظیم می‌کنیم.
در نهایت پس از انتخاب تاریخ توسط کاربر و تایید کردن دیالوگ، می‌توانید موارد انتخاب شده را در متد onDateSet رویداد OnDateSetListener مدیریت کنید.

ظاهرا کتابخانه یک مشکلی دارد و آن این است که مقدار ماه، یک رقم کم‌تر برگردانده می‌شود! برای حل این مورد، مقدار ماه را + 1 کنید تا مشکل حل شود و این احتمالا به خاطر این است که از ایندکس آرایه‌ای برای آن استفاده شده است؛ که  البته می‌توانید با مطالعه‌ی سورس پروژه، آن را خودتان تغییر دهید.

غیرفعال کردن تاریخ های گذشته

با استفاده از متد زیر می‌توانید تاریخ را برای گذشته غیرفعال کنید تا کاربر نتواند تاریخ‌های گذشته را انتخاب کند:

متد setMinDate برای تنظیم حداقل تاریخ مجاز برای انتخاب استفاده شده و تاریخ‌های ماقبل آن غیرفعال می‌شوند.
با این حساب، متد setMaxDate نیز برای برعکس آن استفاده می‌شود که یعنی حدکاثر تاریخ مجازی که کاربر می‌تواند آن را انتخاب کند و بعتد از این تاریخ، بقیه غیرفعال شده و تنها نمایش داده می‌شوند.

مطالب مرتبط

مشخصات فایل و دانلود

  • نسخه فایل 3.1.3
  • پسورد (در صورت نیاز) www.fullkade.com
کانال تلگرام فول کده
تبلیغات

درباره نویسنده

هادی اکبرزاده

[ مدیر فول کده ]

علاقه‌مند به اشتراک‌گذاری اطلاعات در هر زمینه‌ای
برنامه‌نویس فول استک

پاسخ دهید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *

نظرات ثبت شده ۱ دیدگاه

    1. شیرازی کاربر مهمان گفت:

      سلام ایا در این افزونه میتوان تنها ماه و سال را نمایش‌داد و روز را غیر فعال کرد

      10