技术文章

第二篇:初识Android基础控件 第6章、日期DatePicker与时间TimePicker控件

第6章、日期DatePicker与时间TimePicker控件


在Android App应用中,设置日期和时间时间也是经常遇见的,下面我们一起学习一下。

  我们需要学习Android中的基本控件:(1)日期选择控件DatePicker (2)时间选择控件TimePicker。

image.png

一、设计登录窗口

  打开“res/layout/activity_main.xml”文件。

   1、分别从工具栏向activity拖出1个日期选择控件DatePicker、 1个时间选择控件TimePicker、1个按钮Button。控件来自Time&Date、Form Widgets。

image.png

2、打开activity_main.xml文件。

  我们把自动生成的代码修改成如下代码,具体为:

  (1)DatePicker的id修改为tody。

  (2)TimePicker的id修改为now;

  (3)Button的id修改为save,其文本修改为"保存"。

image.png

3、界面如下:

image.png

二、单击事件 

  打开“src/com.genwoxue.datepickertimepicker/MainActivity.java”文件。

  然后输入以下代码:

image.png

我们着重分析一下带有浅蓝色背景部分。

  1、第①部分

  导入与DatePicker与TimePicker相关的2个包。

  2、第②部分

  声明3个控件变量。

  3、第③部分

  (1)findViewById()方法完成3个控件的捕获。

  (2)“保存”按钮添加单击监听事件:btnSave.setOnClickListener(new SaveOnClickListener())。

  4、第④部分

  getYear()、getMonth()、getDayOfMonth()方法获取年、月、日。

  5、第⑤部分

  getCurrentHour()、getCurrentMinute()方法获取时、分。

  6、第⑥部分

  使用Toast显示日期DatePicker、时间TimePicker控件选择的日期与时间。

  效果如下:

image.png

三、附代码

  1、activity_main.xml源码 

TextPrint

1. 

2.      xmlns:tools="http://schemas.android.com/tools"  

3.      android:layout_width="match_parent"  

4.      android:layout_height="match_parent"  

5.      tools:context=".MainActivity" >  

6.    

7.      

8.          android:id="@+id/today"  

9.          android:layout_width="wrap_content"  

10.         android:layout_height="wrap_content"  

11.         android:layout_alignParentLeft="true"  

12.         android:layout_alignParentTop="true" />  

13.   

14.     

15.         android:id="@+id/now"  

16.         android:layout_width="wrap_content"  

17.         android:layout_height="wrap_content"  

18.         android:layout_alignParentLeft="true"  

19.         android:layout_below="@+id/today" />  

20.   

21.     

22.         android:id="@+id/save"  

23.         android:layout_width="wrap_content"  

24.         android:layout_height="wrap_content"  

25.         android:layout_below="@+id/now"  

26.         android:text="保存" />  

27.   

28.   

2、MainActivity.java源码


TextPrint

1.  package com.genwoxue.datepickertimepicker;  

2.    

3.  import android.os.Bundle;  

4.  import android.app.Activity;  

5.  import android.view.View;  

6.  import android.widget.DatePicker;  

7.  import android.widget.TimePicker;  

8.  import android.widget.Button;  

9.  import android.widget.Toast;  

10. import android.view.View.OnClickListener;  

11.   

12. public class MainActivity extends Activity {  

13.   

14.     private DatePicker dpToday=null;  

15.     private TimePicker tpNow=null;  

16.     private Button btnSave=null;  

17.       

18.     @Override  

19.     protected void onCreate(Bundle savedInstanceState) {  

1.          super.onCreate(savedInstanceState);  

2.          setContentView(R.layout.activity_main);  

3.            

4.          dpToday=(DatePicker)super.findViewById(R.id.today);  

5.          tpNow=(TimePicker)super.findViewById(R.id.now);  

6.          btnSave=(Button)super.findViewById(R.id.save);  

7.          btnSave.setOnClickListener(new SaveOnClickListener());  

8.      }  

9.        

10.     private class SaveOnClickListener implements OnClickListener{  

11.         public void onClick(View view){  

12.             int iYear=0;  

13.             int iMonth=0;  

14.             int iDay=0;  

15.             String sDate="";  

16.             iYear=dpToday.getYear();  

17.             iMonth=dpToday.getMonth()+1;  

18.             iDay=dpToday.getDayOfMonth();  

19.             sDate="日期:"+String.valueOf(iYear)+"年"+String.valueOf(iMonth)+"月"+String.valueOf(iDay)+"日";  

20.               

21.             int iHour=0;  

22.             int iMin=0;  

23.             String sTime="";  

24.             iHour=tpNow.getCurrentHour();  

25.             iMin=tpNow.getCurrentMinute();  

26.             sTime="时间:"+String.valueOf(iHour)+"时"+String.valueOf(iMin)+"分";  

27.               

28.             Toast.makeText(getApplicationContext(), sDate+sTime,Toast.LENGTH_LONG).show();            

29.         }  

30.     }  

}  

作者:蒋老师