Android 仿微信自定義數(shù)字鍵盤的實(shí)現(xiàn)代碼
本文介紹了Android 仿微信自定義數(shù)字鍵盤的實(shí)現(xiàn)代碼,分享給大家,希望對(duì)大家有幫助
最終效果:
實(shí)現(xiàn)這個(gè)自定義鍵盤的思路很簡(jiǎn)單:
- 要寫出一個(gè)數(shù)字鍵盤的布局;
- 與 Edittext 結(jié)合使用,對(duì)每個(gè)按鍵的點(diǎn)擊事件進(jìn)行處理;
- 禁用系統(tǒng)軟鍵盤。
有了思路,實(shí)現(xiàn)起來就不難了。
1. 實(shí)現(xiàn)鍵盤的 xml 布局
網(wǎng)格樣式的布局用 GridView 或者 RecyclerView 都可以實(shí)現(xiàn),其實(shí)用 GridView 更方便一些,不過我為了多熟悉 RecyclerView 的用法,這里選擇用了 RecyclerView。
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical"> <View android:layout_width="match_parent" android:layout_height="2px" android:background="@color/btn_gray"/> <RelativeLayout android:id="@+id/rl_back" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@color/iv_back_bg" android:padding="10dp"> <ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerInParent="true" android:src="@mipmap/keyboard_back"/> </RelativeLayout> <View android:layout_width="match_parent" android:layout_height="1px" android:background="@color/btn_gray"/> <android.support.v7.widget.RecyclerView android:id="@+id/recycler_view" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@color/keyboard_bg" android:overScrollMode="never"></android.support.v7.widget.RecyclerView> </LinearLayout>
RecyclerView 用來實(shí)現(xiàn)鍵盤布局,上面的 RelativeLayout 則是為了實(shí)現(xiàn)收起鍵盤的點(diǎn)擊事件。
2. 在代碼中實(shí)現(xiàn)鍵盤布局,填充數(shù)據(jù)、增加點(diǎn)擊事件
我們新建類 KeyboardView 繼承自 RelativeLayout,關(guān)聯(lián)上面的布局文件,然后做一些初始化操作:對(duì) RecyclerView 填充數(shù)據(jù)、設(shè)置適配器,設(shè)置出現(xiàn)和消失的動(dòng)畫效果,寫一些會(huì)用到的方法等。
public class KeyboardView extends RelativeLayout { private RelativeLayout rlBack; private RecyclerView recyclerView; private List<String> datas; private KeyboardAdapter adapter; private Animation animationIn; private Animation animationOut; public KeyboardView(Context context) { this(context, null); } public KeyboardView(Context context, AttributeSet attrs) { this(context, attrs, 0); } public KeyboardView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); init(context, attrs, defStyleAttr); } private void init(Context context, AttributeSet attrs, int defStyleAttr) { LayoutInflater.from(context).inflate(R.layout.layout_key_board, this); rlBack = findViewById(R.id.rl_back); rlBack.setOnClickListener(new OnClickListener() { @Override public void onClick(View view) { // 點(diǎn)擊關(guān)閉鍵盤 dismiss(); } }); recyclerView = findViewById(R.id.recycler_view); initData(); initView(); initAnimation(); } // 填充數(shù)據(jù) private void initData() { datas = new ArrayList<>(); for (int i = 0; i < 12; i++) { if (i < 9) { datas.add(String.valueOf(i + 1)); } else if (i == 9) { datas.add("."); } else if (i == 10) { datas.add("0"); } else { datas.add(""); } } } // 設(shè)置適配器 private void initView() { recyclerView.setLayoutManager(new GridLayoutManager(getContext(), 3)); adapter = new KeyboardAdapter(getContext(), datas); recyclerView.setAdapter(adapter); } // 初始化動(dòng)畫效果 private void initAnimation() { animationIn = AnimationUtils.loadAnimation(getContext(), R.anim.keyboard_in); animationOut = AnimationUtils.loadAnimation(getContext(), R.anim.keyboard_out); } // 彈出軟鍵盤 public void show() { startAnimation(animationIn); setVisibility(VISIBLE); } // 關(guān)閉軟鍵盤 public void dismiss() { if (isVisible()) { startAnimation(animationOut); setVisibility(GONE); } } // 判斷軟鍵盤的狀態(tài) public boolean isVisible() { if (getVisibility() == VISIBLE) { return true; } return false; } public void setOnKeyBoardClickListener(KeyboardAdapter.OnKeyboardClickListener listener) { adapter.setOnKeyboardClickListener(listener); } public List<String> getDatas() { return datas; } public RelativeLayout getRlBack() { return rlBack; } }
Adapter 里面都是很簡(jiǎn)單的代碼,這里就不貼出了,文章末尾我會(huì)給出源碼下載地址。
到這里為止,自定義數(shù)字鍵盤基本就算寫好了,不過最重要的還是要和 Edittext 結(jié)合使用。
3. 與 Edittext 結(jié)合使用
1. 禁用系統(tǒng)軟鍵盤
if (Build.VERSION.SDK_INT <= 10) { etInput.setInputType(InputType.TYPE_NULL); } else { getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_ALWAYS_HIDDEN); try { Class<EditText> cls = EditText.class; Method setShowSoftInputOnFocus = cls.getMethod("setShowSoftInputOnFocus", boolean.class); setShowSoftInputOnFocus.setAccessible(true); setShowSoftInputOnFocus.invoke(etInput, false); } catch (Exception e) { e.printStackTrace(); } }
在網(wǎng)上找了一些方法,但是點(diǎn)擊 Edittext 的時(shí)候系統(tǒng)軟鍵盤依然會(huì)彈出。最后找到了這個(gè)方法,利用反射強(qiáng)制不彈出軟鍵盤,效果不錯(cuò)。
2. 處理各個(gè)按鍵的點(diǎn)擊事件
@Override public void onKeyClick(View view, RecyclerView.ViewHolder holder, int position) { switch (position) { case 9: // 按下小數(shù)點(diǎn) String num = etInput.getText().toString().trim(); if (!num.contains(datas.get(position))) { num += datas.get(position); etInput.setText(num); etInput.setSelection(etInput.getText().length()); } break; default: // 按下數(shù)字鍵 if ("0".equals(etInput.getText().toString().trim())) { // 第一個(gè)數(shù)字按下0的話,第二個(gè)數(shù)字只能按小數(shù)點(diǎn) break; } etInput.setText(etInput.getText().toString().trim() + datas.get(position)); etInput.setSelection(etInput.getText().length()); break; } } @Override public void onDeleteClick(View view, RecyclerView.ViewHolder holder, int position) { // 點(diǎn)擊刪除按鈕 String num = etInput.getText().toString().trim(); if (num.length() > 0) { etInput.setText(num.substring(0, num.length() - 1)); etInput.setSelection(etInput.getText().length()); } }
邏輯也非常簡(jiǎn)單,看代碼就明白了。最終的效果就是第一張圖的樣子。
這個(gè)鍵盤很簡(jiǎn)單,打算之后寫一個(gè)模仿微信或者支付寶的支付密碼輸入布局。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android彈出dialog后無法捕捉back鍵的解決方法
這篇文章主要為大家詳細(xì)介紹了Android彈出dialog后無法捕捉back鍵的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-09-09android實(shí)現(xiàn)一鍵鎖屏和一鍵卸載的方法實(shí)例
這篇文章主要給大家介紹了關(guān)于android如何實(shí)現(xiàn)一鍵鎖屏和一鍵卸載的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-05-05Android中實(shí)現(xiàn)EditText圓角的方法
Android中實(shí)現(xiàn)EditText圓角的方法,需要的朋友可以參考一下2013-03-03Android程序開發(fā)之使用Design包實(shí)現(xiàn)QQ動(dòng)畫側(cè)滑效果和滑動(dòng)菜單導(dǎo)航
這篇文章主要介紹了Android程序開發(fā)之使用Design包實(shí)現(xiàn)QQ動(dòng)畫側(cè)滑效果和滑動(dòng)菜單導(dǎo)航的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-07-07Android控件Tween動(dòng)畫(補(bǔ)間動(dòng)畫)實(shí)現(xiàn)方法示例
這篇文章主要介紹了Android控件Tween動(dòng)畫(補(bǔ)間動(dòng)畫)實(shí)現(xiàn)方法,結(jié)合具體實(shí)例形式分析了Android補(bǔ)間動(dòng)畫的原理、功能實(shí)現(xiàn)與布局相關(guān)操作技巧,需要的朋友可以參考下2017-08-08解決Android TabLayout 在寬屏幕上tab不能平均分配的問題
這篇文章主要介紹了解決Android TabLayout 在寬屏幕上tab不能平均分配的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-08-08Kotlin協(xié)程操作之創(chuàng)建啟動(dòng)掛起恢復(fù)詳解
本文的定位是協(xié)程的創(chuàng)建、啟動(dòng)、掛起、恢復(fù),也會(huì)示例一些簡(jiǎn)單的使用,這里不對(duì)suspend講解,,也不對(duì)協(xié)程的高級(jí)用法做闡述(熱數(shù)據(jù)通道Channel、冷數(shù)據(jù)流Flow...),本文主要講協(xié)程稍微深入的全面知識(shí)2022-08-08Android實(shí)戰(zhàn)打飛機(jī)游戲之子彈生成與碰撞以及爆炸效果(5)
這篇文章主要為大家詳細(xì)介紹了Android實(shí)戰(zhàn)打飛機(jī)游戲之子彈生成與碰撞以及爆炸效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-07-07