Android学习笔记---使用TimePickerDialog打造时间选择器
今天看到一个新的控件,觉得不错 日后肯定会有大用,于是先记录下来
一个时间选择器,上张图吧
那具体是怎么实现的呢?
首先在bulie.gradle中依赖compile 'com.jzxiang.pickerview:TimePickerDialog:0.9.2'
我们下来看代码
先来看下布局代码
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/activity_main" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" android:orientation="vertical" tools:context="baidutu.ht.sks.timepicde.MainActivity"> <Button android:id="@+id/button1" android:text="显示年月日时分" android:layout_gravity="center" android:layout_width="wrap_content" android:layout_height="wrap_content" /> <Button android:id="@+id/button2" android:text="显示年月日" android:layout_gravity="center" android:layout_width="wrap_content" android:layout_height="wrap_content" /> <Button android:id="@+id/button3" android:text="显示时分" android:layout_gravity="center" android:layout_width="wrap_content" android:layout_height="wrap_content" /> <Button android:id="@+id/button4" android:text="显示月日时分" android:layout_gravity="center" android:layout_width="wrap_content" android:layout_height="wrap_content" /> <Button android:id="@+id/button5" android:text="显示年月" android:layout_gravity="center" android:layout_width="wrap_content" android:layout_height="wrap_content" /> </LinearLayout>
Mainactivity.java
package baidutu.ht.sks.timepicde; import android.net.Uri; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.View; import android.widget.Button; import android.widget.Toast; import com.google.android.gms.appindexing.Action; import com.google.android.gms.appindexing.AppIndex; import com.google.android.gms.appindexing.Thing; import com.google.android.gms.common.api.GoogleApiClient; import com.jzxiang.pickerview.TimePickerDialog; import com.jzxiang.pickerview.data.Type; import com.jzxiang.pickerview.listener.OnDateSetListener; import java.text.SimpleDateFormat; import java.util.Date; import static android.icu.lang.UCharacter.GraphemeClusterBreak.T; public class MainActivity extends AppCompatActivity implements OnDateSetListener, View.OnClickListener { private Button button1, button2, button3, button4, button5; private SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); private TimePickerDialog pickerdialog; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initview(); } /** * 设置样式 */ private void intiTimeDialog(Type claa) { pickerdialog = new TimePickerDialog.Builder() //设置类型 .setType(claa) //设置选择时间监听回调 .setCallBack(this) //设置标题 .setTitleStringId("请选择时间") //设置时间 .setSelectorMillseconds(System.currentTimeMillis()) //设置颜色 .setThemeColor(getResources().getColor(R.color.colorAccent)) //设置 字体大小 .setWheelItemTextSize(15) //完毕 .build(); pickerdialog.show(getSupportFragmentManager(),"abc"); } /* 初始化组件 */ private void initview() { button1 = (Button) findViewById(R.id.button1); button2 = (Button) findViewById(R.id.button2); button3 = (Button) findViewById(R.id.button3); button4 = (Button) findViewById(R.id.button4); button5 = (Button) findViewById(R.id.button5); button5.setOnClickListener(this); button4.setOnClickListener(this); button3.setOnClickListener(this); button2.setOnClickListener(this); button1.setOnClickListener(this); } @Override public void onDateSet(TimePickerDialog timePickerView, long millseconds) { Toast.makeText(this, "你选择的时间:"+getDateToString(millseconds), Toast.LENGTH_SHORT).show(); } //Android时间选择器,支持年月日时分,年月日,年月,月日时分,时分格式,可以设置最小时间(精确到分) public String getDateToString(long time) { Date d = new Date(time); return sf.format(d); } @Override public void onClick(View v) { switch (v.getId()){ case R.id.button1: intiTimeDialog(Type.ALL); break; case R.id.button2: intiTimeDialog(Type.YEAR_MONTH_DAY); break; case R.id.button3: intiTimeDialog(Type.HOURS_MINS); break; case R.id.button4: intiTimeDialog(Type.MONTH_DAY_HOUR_MIN); break; case R.id.button5: intiTimeDialog(Type.YEAR_MONTH); break; } } }