Simple Android Library that provide you a custom dialog that allow you to set a start time and end time.
Screenshot |
---|
Add this to your project build.gradle
allprojects {
repositories {
maven { url 'https://jitpack.io' }
}
}
Add this to your module build.gradle
dependencies {
implementation 'com.github.PuffoCyano:Range-Time-Picker-Dialog:v1.8'
}
In your activity (Default method "newInstance()"):
// Create an instance of the dialog fragment and show it
RangeTimePickerDialog dialog = new RangeTimePickerDialog();
dialog.newInstance();
dialog.setRadiusDialog(20); // Set radius of dialog (default is 50)
dialog.setIs24HourView(true); // Indicates if the format should be 24 hours
dialog.setColorBackgroundHeader(R.color.colorPrimary); // Set Color of Background header dialog
dialog.setColorTextButton(R.color.colorPrimaryDark); // Set Text color of button
FragmentManager fragmentManager = getFragmentManager();
dialog.show(fragmentManager, "");
You can instantiate the dialog with more parameters:
// Create an instance of the dialog fragment and show it
RangeTimePickerDialog dialog = new RangeTimePickerDialog();
dialog.newInstance(R.color.CyanWater, R.color.White, R.color.Yellow, R.color.colorPrimary, true);
FragmentManager fragmentManager = getFragmentManager();
dialog.show(fragmentManager, "");
To read parameter from Dialog your activity have to implements the interface ISelectedTime:
public class MainActivity extends AppCompatActivity implements RangeTimePickerDialog.ISelectedTime
Then you have to override the method "onSelectedTime":
@Override
public void onSelectedTime(int hourStart, int minuteStart, int hourEnd, int minuteEnd)
{
// Use parameters provided by Dialog
Toast.makeText(this, "Start: "+hourStart+":"+minuteStart+"\nEnd: "+hourEnd+":"+minuteEnd, Toast.LENGTH_SHORT).show();
}
In your fragment:
// Create an instance of the dialog fragment and show it
RangeTimePickerDialog dialog = new RangeTimePickerDialog();
dialog.newInstance(R.color.CyanWater, R.color.White, R.color.Yellow, R.color.colorPrimary, true);
FragmentManager fragmentManager = getFragmentManager();
dialog.setTargetFragment(this, MY_FRAGMENT_ID); // MY_FRAGMENT_ID is a personal identifier that allow you to get parameter from dialog into onActivityResult
dialog.show(fragmentManager, "");
When you have to read parameter provided by Dialog you have to override onResultActivity in your fragment:
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data)
{
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == MY_FRAGMENT_ID)
{
if (resultCode == Activity.RESULT_OK)
{
if (data.getExtras().containsKey(RangeTimePickerDialog.HOUR_START))
{
int hourStart = data.getExtras().getInt(RangeTimePickerDialog.HOUR_START);
int hourEnd = data.getExtras().getInt(RangeTimePickerDialog.HOUR_END);
int minuteStart = data.getExtras().getInt(RangeTimePickerDialog.MINUTE_START);
int minuteEnd = data.getExtras().getInt(RangeTimePickerDialog.MINUTE_END);
// Use the returned value
Toast.makeText(getActivity(), "Time start:"+hourStart+":"+minuteStart+"\nUntil: "+hourEnd+":"+minuteEnd, Toast.LENGTH_SHORT).show();
}
}
}
}
setColorTabUnselected(int colorTabUnselected)
: Set color of tab item when it is unselectedsetColorTabSelected(int colorTabSelected)
: Set color of tab item when it is selectedsetColorTextButton(int colorTextButton)
: Set button text colorsetColorBackgroundHeader(int colorBackgroundHeader)
: Set background color of header dialogsetIs24HourView(boolean is24HourView)
: Set true if you want see time into 24 hour formatsetMessageErrorRangeTime(String messageErrorRangeTime)
: Set message error that appears when you select a end time greater than start time (only if "validateRange" is true)setTextBtnPositive(String textBtnPositive)
: Set positive button textsetTextBtnNegative(String textBtnNegative)
: Set negative button textsetRadiusDialog(int radiusDialog)
: Set dialog radius (default is 50)setTextTabStart(String textTabStart)
: Set tab start textsetTextTabEnd(String textTabEnd)
: Set tab end textsetValidateRange(boolean validateRange)
:Set true if you want validate the range time (start time < end time). Set false if you want select any timesetColorBackgroundTimePickerHeader(int colorBackgroundTimePickerHeader)
: Set background color of header timePickerenableMinutes(boolean value)
: Enable or disable minutes clocksetInitialStartClock(int hour, int minute)
: Method to set initial start clocksetInitialEndClock(int hour, int minute)
: Method to set initial end clocksetStartTabIcon(int startTabIcon)
: Method to change start tab iconsetEndTabIcon(int endTabIcon)
: Method to change end tab iconsetInitialOpenedTab(InitialOpenedTab initialOpenedTab)
: Method to select which tab are selected on open (START_CLOCK_TAB or END_CLOCK_TAB)setInputKeyboardAsDefault(boolean inputKeyboardAsDefault)
: Method to set keyboard input as default (Only on Oreo device)
Copyright 2018 Alessandro Marino
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.