Android开源:SelectDateAndTime - 一款自定义日期时间选择器

jsbfuture 8年前
   <p>日期选择器是很多应用所具备的,比如设置一些任务的开始和结束时间。为了方便用户的同时也为了界面的好看,很多都是采用日期选择器,我在网上看了一下。很多的日期选择器个人感觉不是很好看,但是修改起来也有点麻烦,于是自己就写了一个demo。至于界面效果个人感觉也是很low,毕竟鄙人不是搞UI的,所以也就凑合着看吧。这些都不重要,因为这些是可以修改的。</p>    <p>如果想实现具有年月日的请看下面的注意里面的内容,下图是实现的分钟为00 15 30 45的如果想要0-59的请看下面的注意里面的内容</p>    <p>如果需要的是仿 iOS 的带有星期几的</p>    <h2 style="text-align:center"><img src="https://simg.open-open.com/show/f63d04b60c68bcb0a7e48cfd9afec574.gif"></h2>    <h2>首先界面弹出PopupWindow动画的实现,具体的代码如下</h2>    <p>进入动画</p>    <pre>  <code class="language-java"><?xml version="1.0" encoding="utf-8"?>  <set xmlns:android="http://schemas.android.com/apk/res/android" >        <translate          android:duration="500"          android:fromYDelta="100.0%p"          android:toYDelta="45" />    </set></code></pre>    <p>退出动画</p>    <pre>  <code class="language-java"><?xml version="1.0" encoding="utf-8"?>  <set xmlns:android="http://schemas.android.com/apk/res/android" >        <translate          android:duration="500"          android:fromYDelta="0.0"          android:toYDelta="100.0%p" />    </set></code></pre>    <p>主要界面的内容</p>    <pre>  <code class="language-java">public class MainActivity extends Activity implements View.OnClickListener{      private TextView tv_house_time;      private TextView tv_center;      private WheelMain wheelMainDate;      private String beginTime;        @Override      protected void onCreate(Bundle savedInstanceState) {          // TODO Auto-generated method stub          super.onCreate(savedInstanceState);          setContentView(R.layout.activity_main);          initView();          initEvent();      }        private void initEvent() {          tv_house_time.setOnClickListener(this);      }        private void initView() {          tv_house_time = (TextView) findViewById(R.id.tv_house_time);          tv_center = (TextView) findViewById(R.id.tv_center);      }        private java.text.DateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");      public void showBottoPopupWindow() {          WindowManager manager = (WindowManager)getSystemService(Context.WINDOW_SERVICE);          Display defaultDisplay = manager.getDefaultDisplay();          DisplayMetrics outMetrics = new DisplayMetrics();          defaultDisplay.getMetrics(outMetrics);          int width = outMetrics.widthPixels;                  View menuView = LayoutInflater.from(this).inflate(R.layout.show_popup_window,null);          final PopupWindow mPopupWindow = new PopupWindow(menuView, (int)(width*0.8),                  ActionBar.LayoutParams.WRAP_CONTENT);          ScreenInfo screenInfoDate = new ScreenInfo(this);          wheelMainDate = new WheelMain(menuView, true);          wheelMainDate.screenheight = screenInfoDate.getHeight();          String time = DateUtils.currentMonth().toString();          Calendar calendar = Calendar.getInstance();          if (JudgeDate.isDate(time, "yyyy-MM-DD")) {              try {                  calendar.setTime(new Date(time));              } catch (Exception e) {                  e.printStackTrace();              }          }          int year = calendar.get(Calendar.YEAR);          int month = calendar.get(Calendar.MONTH);          int day = calendar.get(Calendar.DAY_OF_MONTH);          int hours = calendar.get(Calendar.HOUR_OF_DAY);          int minute = calendar.get(Calendar.MINUTE);          wheelMainDate.initDateTimePicker(year, month, day, hours,minute);          final String currentTime = wheelMainDate.getTime().toString();          mPopupWindow.setAnimationStyle(R.style.AnimationPreview);          mPopupWindow.setTouchable(true);          mPopupWindow.setFocusable(true);          mPopupWindow.setBackgroundDrawable(new BitmapDrawable());          mPopupWindow.showAtLocation(tv_center, Gravity.CENTER, 0, 0);          mPopupWindow.setOnDismissListener(new poponDismissListener());          backgroundAlpha(0.6f);          TextView tv_cancle = (TextView) menuView.findViewById(R.id.tv_cancle);          TextView tv_ensure = (TextView) menuView.findViewById(R.id.tv_ensure);          TextView tv_pop_title = (TextView) menuView.findViewById(R.id.tv_pop_title);          tv_pop_title.setText("选择起始时间");          tv_cancle.setOnClickListener(new View.OnClickListener() {              @Override              public void onClick(View arg0) {                  mPopupWindow.dismiss();                  backgroundAlpha(1f);              }          });          tv_ensure.setOnClickListener(new View.OnClickListener() {                @Override              public void onClick(View arg0) {                  beginTime = wheelMainDate.getTime().toString();                  try {                      Date begin = dateFormat.parse(currentTime);                      Date end = dateFormat.parse(beginTime);                      tv_house_time.setText(DateUtils.currentTimeDeatil(begin));                  } catch (ParseException e) {                      e.printStackTrace();                  }                  mPopupWindow.dismiss();                  backgroundAlpha(1f);              }          });      }        public void backgroundAlpha(float bgAlpha) {          WindowManager.LayoutParams lp = getWindow().getAttributes();          lp.alpha = bgAlpha;          getWindow().setAttributes(lp);      }        @Override      public void onClick(View v) {          switch (v.getId()){              case R.id.tv_house_time:                  showBottoPopupWindow();                  break;          }      }        class poponDismissListener implements PopupWindow.OnDismissListener {          @Override          public void onDismiss() {              backgroundAlpha(1f);          }        }  }</code></pre>    <p>布局内容的</p>    <pre>  <code class="language-java"><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"      android:id="@+id/rel_select"      android:layout_width="wrap_content"      android:layout_height="wrap_content"      android:layout_centerInParent="true"      android:layout_margin="10dp"      android:background="@drawable/border_circle_radius"      android:orientation="vertical" >  <TextView      android:background="#2F0F9980"      android:padding="10dp"      android:id="@+id/tv_pop_title"      android:textSize="18sp"      android:gravity="center"      android:textColor="#301616"      android:layout_width="match_parent"      android:layout_height="wrap_content" />      <LinearLayout          android:id="@+id/timePicker1"          android:layout_width="match_parent"          android:layout_height="wrap_content"          android:orientation="horizontal" >          <liuyongxiang.robert.com.testtime.wheelview.WheelView              android:id="@+id/year"              android:layout_width="wrap_content"              android:layout_weight="1"              android:layout_height="wrap_content" />          <liuyongxiang.robert.com.testtime.wheelview.DashedLineView              android:layout_width="1dp"              android:gravity="center_vertical"              android:layout_gravity="center"              android:background="@drawable/dotted_line"              android:layout_height="match_parent" />          <liuyongxiang.robert.com.testtime.wheelview.WheelView              android:id="@+id/month"              android:layout_width="wrap_content"              android:layout_weight="1"              android:layout_height="wrap_content" />          <liuyongxiang.robert.com.testtime.wheelview.DashedLineView              android:layout_width="1dp"              android:gravity="center_vertical"              android:layout_gravity="center"              android:background="@drawable/dotted_line"              android:layout_height="match_parent" />          <liuyongxiang.robert.com.testtime.wheelview.WheelView              android:id="@+id/day"              android:layout_width="wrap_content"              android:layout_weight="1"              android:layout_height="wrap_content" />          <liuyongxiang.robert.com.testtime.wheelview.DashedLineView              android:layout_width="1dp"              android:background="@drawable/dotted_line"              android:layout_height="match_parent" />          <liuyongxiang.robert.com.testtime.wheelview.WheelView              android:id="@+id/hour"              android:layout_width="wrap_content"              android:layout_weight="1"              android:layout_height="wrap_content" />          <liuyongxiang.robert.com.testtime.wheelview.DashedLineView              android:layout_width="1dp"              android:background="@drawable/dotted_line"              android:layout_height="match_parent" />          <liuyongxiang.robert.com.testtime.wheelview.WheelView              android:id="@+id/mins"              android:layout_width="wrap_content"              android:layout_weight="1"              android:layout_height="wrap_content" />      </LinearLayout>      <LinearLayout          android:layout_width="match_parent"          android:layout_height="wrap_content"          android:background="#2F0F9980"          android:padding="10dp"          android:orientation="horizontal" >            <TextView              android:id="@+id/tv_cancle"              android:layout_width="0dp"              android:layout_height="wrap_content"              android:gravity="center"              android:paddingLeft="20dp"              android:paddingRight="20dp"              android:padding="5dp"              android:textSize="18sp"              android:textColor="#ff0000"              android:layout_weight="1"              android:background="@drawable/btn_pop"              android:text="取消" />            <TextView              android:layout_width="0dp"              android:layout_height="wrap_content"              android:layout_weight="3" />            <TextView              android:id="@+id/tv_ensure"              android:layout_width="0dp"              android:layout_height="wrap_content"              android:gravity="center"              android:textColor="#414341"              android:padding="5dp"              android:paddingLeft="20dp"              android:paddingRight="20dp"              android:layout_weight="1"              android:textSize="18sp"              android:background="@drawable/btn_pop"              android:text="确定" />      </LinearLayout>    </LinearLayout></code></pre>    <h2>请注意</h2>    <p>MainActivity里面的显示时间的 tv_house_time.setText(DateUtils.currentTimeDeatil(begin));需要更改为</p>    <p>tv_house_time.setText(DateUtils.formateStringH(beginTime,DateUtils.yyyyMMddHHmm));否则现实的额时间为00:00</p>    <p>修改后的</p>    <p style="text-align:center"><img src="https://simg.open-open.com/show/a93d4e05cf6f1c422e46a148c12f16dc.gif"></p>    <p>将WheelMain里面的以下代码</p>    <p>wv_mins.setAdapter(adapter);</p>    <p>wv_mins.setCyclic(true);// 可循环滚动</p>    <p>wv_mins.setLabel(“分”);// 添加文字</p>    <p>int min = setMinute(m);</p>    <p>wv_mins.setCurrentItem(min);</p>    <p>更换为</p>    <p>wv_mins.setAdapter(new NumericWheelAdapter(</p>    <p>0, 59));</p>    <p>wv_mins.setCyclic(true);// 可循环滚动</p>    <p>wv_mins.setLabel(“分”);// 添加文字</p>    <p>wv_mins.setCurrentItem(m);</p>    <p>还需要将</p>    <p>int minute = Integer.valueOf(adapter.getItem(wv_mins.getCurrentItem()));</p>    <p>改为</p>    <p>int minute = wv_mins.getCurrentItem();</p>    <p>会将分钟更改为从0到59</p>    <p style="text-align:center"><img src="https://simg.open-open.com/show/5da16fae8df0a29a66d28438c0dd4c38.gif"></p>    <p>如果不想要时间只想要年月日的话只需要</p>    <p>if (hasSelectTime) {</p>    <p>wv_hours.setVisibility(View.GONE);</p>    <p>wv_mins.setVisibility(View.GONE);</p>    <pre>  <code class="language-java">} else {          wv_hours.setVisibility(View.GONE);          wv_mins.setVisibility(View.GONE);          wv_day.setVisibility(View.GONE);      }      将这段代码放开就可以了还要将以下绿色区域内的代码去掉</code></pre>    <p style="text-align:center"><img src="https://simg.open-open.com/show/9fbab7d54043d3347ad1e269ffa8454c.png"> <img src="https://simg.open-open.com/show/d389d4fa70902c01139459508a759ebc.png"></p>    <p>还需要将 MainActivty里的如下代码</p>    <p>wheelMainDate.initDateTimePicker(year, month, day, hours,minute);</p>    <p>更改为</p>    <p>wheelMainDate.initDateTimePicker(year, month, day);</p>    <p>还有 wheelMain里的</p>    <pre>  <code class="language-java">if (!hasSelectTime) {          sb.append((wv_year.getCurrentItem() + START_YEAR)).append("-")                  .append(strMon).append("-")                  .append(strDay).append("  ").append(strHour).append(":").append(strMin);      }else{          sb.append((wv_year.getCurrentItem() + START_YEAR)).append("-")                  .append(strMon).append("-")                  .append(strDay).append("  ").append(strHour).append(":").append(strMin);      }</code></pre>    <p>需要修改为</p>    <pre>  <code class="language-java">if (!hasSelectTime) {          sb.append((wv_year.getCurrentItem() + START_YEAR)).append("-")                  .append(strMon).append("-")                  .append(strDay);      }else{          sb.append((wv_year.getCurrentItem() + START_YEAR)).append("-")                  .append(strMon).append("-")                  .append(strDay);      }</code></pre>    <p>实现效果如下图</p>    <p style="text-align:center"><img src="https://simg.open-open.com/show/a086616c38ed362a6ec2d532c24bf80f.gif"></p>    <p> </p>    <p> </p>    <p> </p>