DatePickerDialog说白了就是AlertDialog上放了一个DatePicker和两个button。
布局文件
系统的DatePickerDialog是指定了主题的,我希望能自定义button的样式,所以照着源码重写了DatePickerDialog,给他添加自己的布局文件。
闲话少说,上代码。
MyDatePickerDialog.java
此处的MyDatePickerDialog等同于DatePickerDialog使用。
package com.example.datepickerdemo.datepickerdemo;
import android.app.AlertDialog;
import android.app.DatePickerDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.graphics.Color;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.text.format.DateUtils;
import android.util.TypedValue;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.Button;
import android.widget.DatePicker;
import java.util.Calendar;
public class MyDatePickerDialog extends AlertDialog implements
DatePicker.OnDateChangedListener {
private static final String YEAR = "year";
private static final String MONTH = "month";
private static final String DAY = "day";
private final DatePicker mDatePicker;
private final OnDateSetListener mDateSetListener;
private final Calendar mCalendar;
private boolean mTitleNeedsUpdate = true;
private View view;
/**
* The callback used to indicate the user is done filling in the date.
*/
public interface OnDateSetListener {
/**
* @param view The view associated with this listener.
* @param year The year that was set.
* @param monthOfYear The month that was set (0-11) for compatibility
* with {@link java.util.Calendar}.
* @param dayOfMonth The day of the month that was set.
*/
void onDateSet(DatePicker view, int year, int monthOfYear, int dayOfMonth);
}
/**
* @param context The context the dialog is to run in.
* @param callBack How the parent is notified that the date is set.
* @param year The initial year of the dialog.
* @param monthOfYear The initial month of the dialog.
* @param dayOfMonth The initial day of the dialog.
*/
public MyDatePickerDialog(Context context,
OnDateSetListener callBack,
int year,
int monthOfYear,
int dayOfMonth) {
this(context, 0, callBack, year, monthOfYear, dayOfMonth);
}
/**
* @param context The context the dialog is to run in.
* @param theme the theme to apply to this dialog
* @param listener How the parent is notified that the date is set.
* @param year The initial year of the dialog.
* @param monthOfYear The initial month of the dialog.
* @param dayOfMonth The initial day of the dialog.
*/
public MyDatePickerDialog(Context context, int theme, OnDateSetListener listener, int year,
int monthOfYear, int dayOfMonth) {
super(context, theme);
mDateSetListener = listener;
mCalendar = Calendar.getInstance();
Context themeContext = getContext();
LayoutInflater inflater = LayoutInflater.from(themeContext);
view = inflater.inflate(R.layout.date_picker_dialog, null);
view.setBackgroundColor(Color.BLUE);
//setView(view);
// setButton(BUTTON_POSITIVE, themeContext.getString(R.string.ok), this);
// setButton(BUTTON_NEGATIVE, themeContext.getString(R.string.cancel), this);
// setButtonPanelLayoutHint(LAYOUT_HINT_SIDE);
mDatePicker = (DatePicker) view.findViewById(R.id.datePicker);
mDatePicker.init(year, monthOfYear, dayOfMonth, this);
// mDatePicker.setValidationCallback(mValidationCallback);
//实现自己的标题和ok按钮
//setTitle("选择日期:");
setButton();
}
// private void setTitle(String title) {
// //获取自己定义的title布局并赋值。
// ((TextView) view.findViewById(R.id.date_picker_title)).setText(title);
// }
private void setButton() {
//获取自己定义的响应按钮并设置监听,直接调用构造时传进来的CallBack接口(为了省劲,没有自己写接口,直接用之前本类定义好的)同时关闭对话框。
view.findViewById(R.id.date_picker_ok).setOnClickListener(
new View.OnClickListener() {
@Override
public void onClick(View v) {
if (mDateSetListener != null) {
// Clearing focus forces the dialog to commit any pending
// changes, e.g. typed text in a NumberPicker.
mDatePicker.clearFocus();
mDateSetListener.onDateSet(mDatePicker, mDatePicker.getYear(),
mDatePicker.getMonth(), mDatePicker.getDayOfMonth());
}
}
});
view.findViewById(R.id.date_picker_cancle).setOnClickListener(
new View.OnClickListener() {
@Override
public void onClick(View v) {
cancel();
}
});
}
public void myShow() {
//自己实现show方法,主要是为了把setContentView方法放到show方法后面,否则会报错。
show();
setContentView(view);
}
@Override
public void onDateChanged(DatePicker view, int year, int month, int day) {
mDatePicker.init(year, month, day, this);
}
/**
* Gets the {@link DatePicker} contained in this dialog.
*
* @return The calendar view.
*/
public DatePicker getDatePicker() {
return mDatePicker;
}
/**
* Sets the current date.
*
* @param year The date year.
* @param monthOfYear The date month.
* @param dayOfMonth The date day of month.
*/
public void updateDate(int year, int monthOfYear, int dayOfMonth) {
mDatePicker.updateDate(year, monthOfYear, dayOfMonth);
}
@Override
public Bundle onSaveInstanceState() {
final Bundle state = super.onSaveInstanceState();
state.putInt(YEAR, mDatePicker.getYear());
state.putInt(MONTH, mDatePicker.getMonth());
state.putInt(DAY, mDatePicker.getDayOfMonth());
return state;
}
@Override
public void onRestoreInstanceState(Bundle savedInstanceState) {
super.onRestoreInstanceState(savedInstanceState);
final int year = savedInstanceState.getInt(YEAR);
final int month = savedInstanceState.getInt(MONTH);
final int day = savedInstanceState.getInt(DAY);
mDatePicker.init(year, month, day, this);
}
}
布局文件
dare_picker_dialog.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<DatePicker
android:id="@+id/datePicker"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:calendarViewShown="false"
/>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<TextView
android:id="@+id/date_picker_ok"
android:layout_weight="1"
android:layout_width="wrap_content"
android:layout_height="50dp"
android:gravity="center"
android:text="test OK"
android:textColor="#000000" />
<TextView
android:id="@+id/date_picker_cancle"
android:layout_weight="1"
android:layout_width="wrap_content"
android:layout_height="50dp"
android:gravity="center"
android:text="test cancle"
android:textColor="#000000" />
</LinearLayout>
</LinearLayout>
使用:
package com.example.datepickerdemo.datepickerdemo;
import android.app.Activity;
import android.app.DatePickerDialog;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.View;
import android.widget.Button;
import android.widget.DatePicker;
import android.widget.Toast;
import java.util.Calendar;
public class MainActivity extends AppCompatActivity {
Calendar calendar = Calendar.getInstance();
int year = calendar.get(Calendar.YEAR);
int monthOfYear = calendar.get(Calendar.MONTH);
int dayOfMonth = calendar.get(Calendar.DAY_OF_MONTH);
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
Button test1= (Button) findViewById(R.id.test1);
test1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
showDatePicker2();
}
});
}
public void showDatePicker2(){
MyDatePickerDialog myDatePickerDialog=new MyDatePickerDialog(this,android.R.style.Theme_Holo_Light_Dialog_NoActionBar,
new MyDatePickerDialog.OnDateSetListener(){
@Override
public void onDateSet(DatePicker view, int year, int monthOfYear, int dayOfMonth) {
int month=monthOfYear+1;
Toast.makeText(
MainActivity.this,
year + "-" + month + "-" + dayOfMonth,
Toast.LENGTH_SHORT).show();
}
},year,monthOfYear,dayOfMonth);
myDatePickerDialog.myShow();
}
}
具体的按钮的样式我还没改,但是既然能通过xml写那就能改。本篇文章参考了以下作者,但是在使用的时候他写错了一个地方导致不成功,我给改了,还是很感谢他!!