SlideDayTimePicker


Source link: https://github.com/jjobes/SlideDayTimePicker

SlideDayTimePicker

SlideDayTimePicker is an Android library that displays a single DialogFragment in which the user can select a day of week and a time. The user can swipe between the day picker and time picker, and the tab underline will gradually animate as the user swipes. The colors of the tab indicator and divider lines are customizable to fit your project's theme. Tested on Android 4.0+.

Setup

To add this library to your project, add the following to your build.gradle:

dependencies {

  compile project(':slideDayTimePicker') 
}

How to Use

(See SampleActivity for a more complete example)

First create a listener object:

final SlideDayTimeListener listener = new SlideDayTimeListener() {

@Override
  public void onDayTimeSet(int day, int hour, int minute)
  {

// Do something with the day, hour and minute

// the user has selected.
  
}

@Override
  public void onDayTimeCancel()
  {

// The user has canceled the dialog.

// This override is optional.
  
}
 
}
;

Then pass the listener into the builder and show the dialog:

new SlideDayTimePicker.Builder(getSupportFragmentManager())
  .setListener(listener)
  .setInitialDay(1)
  .setInitialHour(13)
  .setInitialMinute(30)
  .build()
  .show();

To set the initial day of week to display

.setInitialDay(int)

The integer that you pass in to setInitialDay() should correspond to a java.util.Calendar day of week constant. So either 1 or Calendar.SUNDAY would be acceptable arguments to setInitialDay(). (However, if you specify a custom days array with setCustomDaysArray(), pass in the raw index instead.)

To set the initial hour to display:

.setInitialHour(int)

Acceptable range of values: 0-23

To set the initial minute to display:

.setInitialMinute(int)

Acceptable range of values: 0-59

The default time format is the current device's default, but you can force a 24-hour or 12-hour time format:

To force 24-hour time:

.setIs24HourTime(true)

To force 12-hour time:

.setIs24HourTime(false)

To display a custom days array: By default, the dialog will display the normal seven days of the week. However, if you want to customize the days to display, you can pass in your own String array.

.setCustomDaysArray(String[])

The default theme is Holo Light, but you can specify either Holo Light or Dark explicitly:

.setTheme(SlideDayTimePicker.HOLO_LIGHT)

or

.setTheme(SlideDayTimePicker.HOLO_DARK)

To specify the color for the sliding tab underline (indicator):

.setIndicatorColor(Color.parseColor("#FF0000"))

To specify the color of the horizontal divider lines in the day picker and TimePicker: You can also set a custom color for the horizontal divider lines in the day picker and TimePicker, but for this you have to paste your own version of selection_divider.9.png into the the library's drawable-xxxx folders that has your desired color. To do this, open selection_divider.9.png in a graphics editor, change the color, then paste your new files into the drawable-xxxx folders.

Note on Reflection

To allow for the modification of the horizontal dividers in the NumberPicker and TimePicker, this library uses reflection in the CustomNumberPicker and CustomTimePicker classes.

Contributing

Contributions are welcome. Please open up an issue in GitHub or submit a PR.

Translations are especially needed in strings.xml

Changelog

v1.0.2

  • Update build.gradle

v1.0.1

  • Changed to Android Studio / Gradle project

v1.0.0

  • First release

License

Licensed under the Apache License, Version 2.0

The following files:

  • SlidingTabLayout.java
  • SlidingTabStrip.java

are Copyright (C) 2013 The Android Open Source Project and are licensed under the Apache License, Version 2.0.

Acknowledgements

Thanks to Arman Pagilagan's blog post for the initial idea.

Resources

Gradle plugin for Github releases. You can fully automate releases via gradle-github-plugin.

Modification of ZXING Barcode Scanner project for easy Android QR-Code detection in portrait mode and AR purposes.

This project implements an Android view which show camera and notify when there's a QR code inside the preview.

LoadingView is easy to implement loading indicators for your views or layouts.

An in-memory data store backed by shared preferences, for Android.

Easy to use inline @Keep annotation to keep class.

A UI widget that allows for headers and footers on lists backed by RecyclerView.

Topics


2D Engines   3D Engines   9-Patch   Action Bars   Activities   ADB   Advertisements   Analytics   Animations   ANR   AOP   API   APK   APT   Architecture   Audio   Autocomplete   Background Processing   Backward Compatibility   Badges   Bar Codes   Benchmarking   Bitmaps   Bluetooth   Blur Effects   Bread Crumbs   BRMS   Browser Extensions   Build Systems   Bundles   Buttons   Caching   Camera   Canvas   Cards   Carousels   Changelog   Checkboxes   Cloud Storages   Color Analysis   Color Pickers   Colors   Comet/Push   Compass Sensors   Conferences   Content Providers   Continuous Integration   Crash Reports   Credit Cards   Credits   CSV   Curl/Flip   Data Binding   Data Generators   Data Structures   Database   Database Browsers   Date &   Debugging   Decompilers   Deep Links   Dependency Injections   Design   Design Patterns   Dex   Dialogs   Distributed Computing   Distribution Platforms   Download Managers   Drawables   Emoji   Emulators   EPUB   Equalizers &   Event Buses   Exception Handling   Face Recognition   Feedback &   File System   File/Directory   Fingerprint   Floating Action   Fonts   Forms   Fragments   FRP   FSM   Functional Programming   Gamepads   Games   Geocaching   Gestures   GIF   Glow Pad   Gradle Plugins   Graphics   Grid Views   Highlighting   HTML   HTTP Mocking   Icons   IDE   IDE Plugins   Image Croppers   Image Loaders   Image Pickers   Image Processing   Image Views   Instrumentation   Intents   Job Schedulers   JSON   Keyboard   Kotlin   Layouts   Library Demos   List View   List Views   Localization   Location   Lock Patterns   Logcat   Logging   Mails   Maps   Markdown   Mathematics   Maven Plugins   MBaaS   Media   Menus   Messaging   MIME   Mobile Web   Native Image   Navigation   NDK   Networking   NFC   NoSQL   Number Pickers   OAuth   Object Mocking   OCR Engines   OpenGL   ORM   Other Pickers   Parallax List   Parcelables   Particle Systems   Password Inputs   PDF   Permissions   Physics Engines   Platforms   Plugin Frameworks   Preferences   Progress Indicators   ProGuard   Properties   Protocol Buffer   Pull To   Purchases   Push/Pull   QR Codes   Quick Return   Radio Buttons   Range Bars   Ratings   Recycler Views   Resources   REST   Ripple Effects   RSS   Screenshots   Scripting   Scroll Views   SDK   Search Inputs   Security   Sensors   Services   Showcase Views   Signatures   Sliding Panels   Snackbars   SOAP   Social Networks   Spannable   Spinners   Splash Screens   SSH   Static Analysis   Status Bars   Styling   SVG   System   Tags   Task Managers   TDD &   Template Engines   Testing   Testing Tools   Text Formatting   Text Views   Text Watchers   Text-to   Toasts   Toolkits For   Tools   Tooltips   Trainings   TV   Twitter   Updaters   USB   User Stories   Utils   Validation   Video   View Adapters   View Pagers   Views   Watch Face   Wearable Data   Wearables   Weather   Web Tools   Web Views   WebRTC   WebSockets   Wheel Widgets   Wi-Fi   Widgets   Windows   Wizards   XML   XMPP   YAML   ZIP Codes