Android開發中實現IOS風格底部選取器(支援時間 日期 自訂)_Android

來源:互聯網
上載者:User

本文Github代碼連結

https://github.com/AndroidMsky/AndoirdIOSPicker

先上圖吧:

這是筆者最近一個項目一直再用的一個選取器庫,自己也在其中做了修改,並決定持續維護下去。

先看使用方法:

日期選擇:

private void showDateDialog(List<Integer> date) {DatePickerDialog.Builder builder = new DatePickerDialog.Builder(this);builder.setOnDateSelectedListener(new DatePickerDialog.OnDateSelectedListener() {@Overridepublic void onDateSelected(int[] dates) {mTextView.setText(dates[0] + "-" + (dates[1] > 9 ? dates[1] : ("0" + dates[1])) + "-"+ (dates[2] > 9 ? dates[2] : ("0" + dates[2])));}@Overridepublic void onCancel() {}}).setMinYear(1900).setMaxYear(2050).setSelectYear(date.get(0) - 1).setSelectMonth(date.get(1) - 1).setSelectDay(date.get(2) - 1);builder.setMaxYear(DateUtil.getYear());builder.setMaxMonth(DateUtil.getDateForString(DateUtil.getToday()).get(1));builder.setMaxDay(DateUtil.getDateForString(DateUtil.getToday()).get(2));dateDialog = builder.create();dateDialog.show();}

比較簡單就不解釋了

自訂選擇:

先搞一個list

private List<String> list = new ArrayList<>();

然後調用時候傳入這個list就可以了

/*** chooseDialog*/private void showChooseDialog(List<String> mlist) {DataPickerDialog.Builder builder = new DataPickerDialog.Builder(this);chooseDialog = builder.setData(mlist).setSelection(1).setTitle("取消").setOnDataSelectedListener(new DataPickerDialog.OnDataSelectedListener() {@Overridepublic void onDataSelected(String itemValue, int position) {mTextView.setText(itemValue);}@Overridepublic void onCancel() {}}).create();chooseDialog.show();}

接下來我們就那timepick開刀簡單分析下其中的原理,也方便我們做自訂的擴充。

首先開啟TimePickerDialog可見繼承自Dialog對自訂Dialog還不熟悉的可以看:

安卓下Builder模式解析+自訂Dialog實戰演練

http://blog.csdn.net/androidmsky/article/details/52982815

public class TimePickerDialog extends Dialog

肯定這中Dialog都會使用Builder模式,接下來看裡面的欄位

private static final class Params {private boolean shadow = true;private boolean canCancel = true;private LoopView loopHour, loopMin;private OnTimeSelectedListener callback;}

看到主力軍是兩個LoopView來表示小時和分鐘,接下來我們就要看LoopView這類了,進去會發現比較龐大有一臉的參數。不用怕,我們直接來到它的兩個最關鍵的方法,

protected void onDraw(Canvas canvas) 

可以看到就是在把文字畫出來也不要怕反反覆複就那麼幾個方法:

核心就是它canvas.drawText(as[j1], startX, h, paintB);

在幾種情況下調用它,肯定就是12345個位置數字不同的樣式

if (i2 <= n && h + i2 >= n) {canvas.save();canvas.clipRect(0, 0, v, n - i2);canvas.drawText(as[j1], startX, h, paintA);canvas.restore();canvas.save();canvas.clipRect(0, n - i2, v, (int) ((float) h * l));canvas.drawText(as[j1], startX, h, paintB);canvas.restore();} else if (i2 <= o && h + i2 >= o) {canvas.save();canvas.clipRect(0, 0, v, o - i2);canvas.drawText(as[j1], startX, h, paintB);canvas.restore();canvas.save();canvas.clipRect(0, o - i2, v, (int) ((float) h * l));canvas.drawText(as[j1], startX, h, paintA);canvas.restore();} else if (i2 >= n && h + i2 <= o) {canvas.clipRect(0, 0, v, (int) ((float) h * l));canvas.drawText(as[j1], startX, h, paintB);mSelectItem = arrayList.indexOf(as[j1]);} else {canvas.clipRect(0, 0, v, (int) ((float) h * l));canvas.drawText(as[j1], startX, h, paintA);}canvas.restore();

下一個關鍵方法就是:

public boolean onTouchEvent(MotionEvent motionevent)

通過手指的移動改變繪製的位移值:

case MotionEvent.ACTION_MOVE:y = motionevent.getRawY();z = x - y;x = y;totalScrollY = (int) ((float) totalScrollY + z);if (!isLoop) {if (totalScrollY > (int) ((float) (-positon) * (l * (float) h))) {break; /* Loop/switch isn't completed */}totalScrollY = (int) ((float) (-positon) * (l * (float) h));}break;

大概就是這種姿勢去看開源自訂view了。

以上所述是小編給大家介紹的Android開發中實現IOS風格底部選取器(支援時間 日期 自訂),希望對大家有所協助,如果大家有任何疑問請給我留言,小編會及時回複大家的。在此也非常感謝大家對雲棲社區網站的支援!

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.