Android高仿IOS 滾輪選擇控制項_Android

來源:互聯網
上載者:User

最近根據項目需要,整理了一個相對比較全面的 WheelView 使用控制項,借用之前看到的一句話來說,就是站在巨人肩膀上,進行了一些小調整。
這裡先貼上效果圖

一般常用的時間選擇格式,,單項選擇,以及城市聯動,這裡基本都可以滿足了。

這裡把 單項選擇,和 日期時間選擇 給提出到 Util 類中,代碼如下:

public class Util { /**  * 時間選擇回調  */ public interface TimerPickerCallBack {  void onTimeSelect(String date); } /**  * 彈出時間選擇  *  * @param context  * @param type  TimerPickerView 中定義的 選擇時間類型  * @param format 時間格式化  * @param callBack 時間選擇回調  */ public static void alertTimerPicker(Context context, TimePickerView.Type type, final String format, final TimerPickerCallBack callBack) {  TimePickerView pvTime = new TimePickerView(context, type);  //控制時間範圍  //  Calendar calendar = Calendar.getInstance();  //  pvTime.setRange(calendar.get(Calendar.YEAR) - 20, calendar.get(Calendar.YEAR));  pvTime.setTime(new Date());  pvTime.setCyclic(false);  pvTime.setCancelable(true);  //時間選擇後回調  pvTime.setOnTimeSelectListener(new TimePickerView.OnTimeSelectListener() {   @Override   public void onTimeSelect(Date date) {//      tvTime.setText(getTime(date));    SimpleDateFormat sdf = new SimpleDateFormat(format);    callBack.onTimeSelect(sdf.format(date));   }  });  pvTime.setTextSize(16);  //彈出時間選取器  pvTime.show(); } /**  * 底部滾輪點擊事件回調  */ public interface OnWheelViewClick {  void onClick(View view, int postion); } /**  * 彈出底部滾輪選擇  *  * @param context  * @param list  * @param click  */ public static void alertBottomWheelOption(Context context, ArrayList<?> list, final OnWheelViewClick click) {  final PopupWindow popupWindow = new PopupWindow();  View view = LayoutInflater.from(context).inflate(R.layout.layout_bottom_wheel_option, null);  TextView tv_confirm = (TextView) view.findViewById(R.id.btnSubmit);  final WheelView wv_option = (WheelView) view.findViewById(R.id.wv_option);  wv_option.setAdapter(new ArrayWheelAdapter(list));  wv_option.setCyclic(false);  wv_option.setTextSize(16);  tv_confirm.setOnClickListener(new View.OnClickListener() {   @Override   public void onClick(View view) {    popupWindow.dismiss();    click.onClick(view, wv_option.getCurrentItem());   }  });  view.findViewById(R.id.btnCancel).setOnClickListener(new View.OnClickListener() {   @Override   public void onClick(View view) {    // TODO: 2016/8/11 0011 取消    popupWindow.dismiss();   }  });  view.setOnTouchListener(new View.OnTouchListener() {   @Override   public boolean onTouch(View view, MotionEvent motionEvent) {    int top = view.findViewById(R.id.ll_container).getTop();    if (motionEvent.getAction() == MotionEvent.ACTION_UP) {     int y = (int) motionEvent.getY();     if (y < top) {      popupWindow.dismiss();     }    }    return true;   }  });  popupWindow.setContentView(view);  popupWindow.setOutsideTouchable(true);  popupWindow.setFocusable(true);  popupWindow.setBackgroundDrawable(new BitmapDrawable());  popupWindow.setWidth(ViewGroup.LayoutParams.MATCH_PARENT);  popupWindow.setHeight(ViewGroup.LayoutParams.MATCH_PARENT);  popupWindow.showAtLocation(((ViewGroup) ((Activity) context).findViewById(android.R.id.content)).getChildAt(0), Gravity.CENTER, 0, 0); }}

 •單項選擇

這裡是類比傳入 ArrayList 形式的 String 類型 :

 // 單項選擇  for (int i = 0; i <= 10; i++) {   mList.add("類比資料" + i);  }  tv_single_option.setOnClickListener(new View.OnClickListener() {   @Override   public void onClick(View v) {    Util.alertBottomWheelOption(MainActivity.this, mList, new Util.OnWheelViewClick() {     @Override     public void onClick(View view, int postion) {      Toast.makeText(MainActivity.this, mList.get(postion), Toast.LENGTH_SHORT).show();     }    });   }  });

補充:我們實際項目中用法可能是傳入一個實體物件,那麼我們到 WheelView 中找到設定顯示內容的方法:

/**  * 根據傳進來的對象反射出getPickerViewText()方法,來擷取需要顯示的值  * @param item  * @return  */ private String getContentText(Object item) {  String contentText = item.toString();  try {   Class<?> clz = item.getClass();   Method m = clz.getMethod(GETPICKERVIEWTEXT);   contentText = m.invoke(item, new Object[0]).toString();  } catch (NoSuchMethodException e) {  } catch (InvocationTargetException e) {  } catch (IllegalAccessException e) {  } catch (Exception e){  }  return contentText; }

根據以上代碼,可以看到如果是一個實體物件,那麼就是通過對象內部定義的一個方法名為 GETPICKERVIEWTEXT(靜態常量=”getPickerViewText”)的傳回值來作為顯示內容,

所以在建立對象的時候,要注意在對象內部添加一個 getPickerViewText()方法,代碼如下:

public class TypeBean { private int id; private String name; public TypeBean(int id, String name) {  this.id = id;  this.name = name; } public int getId() {  return id; } public void setId(int id) {  this.id = id; } public String getName() {  return name; } public void setName(String name) {  this.name = name; } //這個用來顯示在PickerView上面的字串,PickerView會通過反射擷取getPickerViewText方法顯示出來。 public String getPickerViewText() {  //這裡還可以判斷文字超長截斷再提供顯示  return name; }}

 •日期選擇
這裡是傳入 選擇日期類型,和 回調時間格式 就能直接得到想要的結果,

 @Override public void onClick(View v) {  String format = "";  TimePickerView.Type type = null;  switch (v.getId()) {   case R.id.btn_ymdhm:    type = TimePickerView.Type.ALL;    format = "yyyy-MM-dd HH:mm";    break;   case R.id.btn_ymdh:    type = TimePickerView.Type.YEAR_MONTH_DAY_HOUR;    format = "yyyy-MM-dd HH";    break;   case R.id.btn_ymd:    type = TimePickerView.Type.YEAR_MONTH_DAY;    format = "yyyy-MM-dd";    break;   case R.id.btn_mdhm:    type = TimePickerView.Type.MONTH_DAY_HOUR_MIN;    format = "MM-dd HH:mm";    break;   case R.id.btn_hm:    type = TimePickerView.Type.HOURS_MINS;    format = "HH:mm";    break;   case R.id.btn_ym:    type = TimePickerView.Type.YEAR_MONTH;    format = "yyyy-MM";    break;  }  Util.alertTimerPicker(this, type, format, new Util.TimerPickerCallBack() {   @Override   public void onTimeSelect(String date) {    Toast.makeText(TestActivity.this, date, Toast.LENGTH_SHORT).show();   }  }); }

 •條件選擇 

private ArrayList<ProvinceBean> options1Items = new ArrayList<ProvinceBean>();private ArrayList<ArrayList<String>> options2Items = new ArrayList<ArrayList<String>>();private ArrayList<ArrayList<ArrayList<String>>> options3Items = new ArrayList<ArrayList<ArrayList<String>>>();OptionsPickerView pvOptions;private void showOptions(){  //選項選取器  pvOptions = new OptionsPickerView(this);  // 初始化三個列表資料  DataModel.initData(options1Items, options2Items, options3Items);  //三級聯動效果  pvOptions.setPicker(options1Items, options2Items, options3Items, true);  //設定選擇的三級單位//  pwOptions.setLabels("省", "市", "區");  pvOptions.setTitle("選擇城市");  pvOptions.setCyclic(false, false, false);  //設定預設選中的三級項目  //監聽確定選擇按鈕  pvOptions.setSelectOptions(1, 1, 1);  pvOptions.setTextSize(18);  pvOptions.setOnoptionsSelectListener(new OptionsPickerView.OnOptionsSelectListener() {   @Override   public void onOptionsSelect(int options1, int option2, int options3) {    //返回的分別是三個層級的選中位置    String tx = options1Items.get(options1).getPickerViewText()      + options2Items.get(options1).get(option2)      + options3Items.get(options1).get(option2).get(options3);    tvOptions.setText(tx);    vMasker.setVisibility(View.GONE);   }  });  //點擊彈出選項選取器  tvOptions.setOnClickListener(new View.OnClickListener() {   @Override   public void onClick(View v) {    pvOptions.show();   }  }); }

基本使用就這些了,也沒什麼技術含量,只是作為常用工具整理,也希望能給大家帶來方便。

點擊下載:源碼

以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援雲棲社區。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.