Путь к этому будет следующим:
Определите интерфейс для представления (действия)
public interface MyView {
public void setDateText (String date);
public void displayDatePickerDialog(int year, int month, int day);
}
ЗатемДокладчик будет выглядеть так:
public class MyPresenter {
MyView view;
public MyPresenter (MyView view){
this.view = view;
}
public void onDateSet(int year, int month, int dayOfMonth){
month = month + 1;
String date = dayOfMonth + "/" + month + "/" + year;
view.setDateText(date);
}
public void onDateClicked (){
Calendar calendar = Calendar.getInstance();
int year = calendar.get(Calendar.YEAR);
int month = calendar.get(Calendar.MONTH);
int day = calendar.get(Calendar.DAY_OF_MONTH);
view.displayDatePickerDialog(year, month, day);
}
А ваша деятельность должна выглядеть примерно так:
public class MainActivity extends AppCompatActivity implements MyView{
MyPresenter myPresenter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_login);
myPresenter = new MyPresenter(this);
}
@OnClick(R.id.date_text)
public void onClickDate() {
myPresenter.onDateClicked();
}
mDateSetListener = new DatePickerDialog.OnDateSetListener() {
@Override
public void onDateSet(DatePicker view, int year, int month, int dayOfMonth) {
myPresenter.onDateSet(year, month, dayOfMonth);
}
};
@Override
public void setDateText (String date){
dateText.setText(date);
}
@Override
public void displayDatePickerDialog(int year, int month, int day){
DatePickerDialog dialog = new DatePickerDialog(getActivity(), android.R.style.Theme_Holo_Light_Dialog_MinWidth, mDateSetListener,
year, month, day);
dialog.getWindow().setBackgroundDrawable(new ColorDrawable(Color.TRANSPARENT));
dialog.show();
}
}