国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Rumah applet WeChat pembangunan WeChat Android 高仿微信支付數(shù)字鍵盤功能

Android 高仿微信支付數(shù)字鍵盤功能

Mar 27, 2017 pm 01:44 PM
android

現(xiàn)在很多app的支付、輸入密碼功能,都是使用自定義數(shù)字鍵盤,方便實用。下面本文給大家?guī)砹?a href=">http://m.miracleart.cn/wiki/1502.html" target="_blank">Android 高仿微信支付數(shù)字鍵盤功能,非常不錯,感興趣的朋友一起學(xué)習(xí)吧

下面帶著大家學(xué)習(xí)下,如何高仿微信的數(shù)字鍵盤,可以拿來直接用在自身的項目中。

先看下效果圖:

Android 高仿微信支付數(shù)字鍵盤功能

1. 自定義布局

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<!-- 輸入鍵盤 -->
<GridView
android:id="@+id/gv_keybord"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:background="#bdbdbd"
android:horizontalSpacing="1px"
android:numColumns="3"
android:verticalSpacing="1px" />
<View
android:id="@+id/line"
android:layout_width="match_parent"
android:layout_height="1px"
android:layout_above="@id/gv_keybord"
android:background="#bdbdbd" />
<RelativeLayout
android:id="@+id/layoutBack"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_above="@id/line"
android:background="#f5f5f5"
android:padding="10dp">
<ImageView
android:id="@+id/imgBack"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:src="@mipmap/keyboard_back_img" />
</RelativeLayout>
<View
android:layout_width="match_parent"
android:layout_height="1px"
android:layout_above="@id/layoutBack"
android:layout_marginTop="1dp"
android:background="#bdbdbd" />
</RelativeLayout>

鍵盤的布局,實質(zhì)就是一個4X3網(wǎng)格布局的GridView。

2.實現(xiàn)數(shù)字鍵盤內(nèi)容

import?android.content.Context;
import?android.util.AttributeSet;
import?android.view.View;
import?android.widget.GridView;
import?android.widget.RelativeLayout;
import?com.lnyp.pswkeyboard.R;
import?com.lnyp.pswkeyboard.adapter.KeyBoardAdapter;
import?java.util.ArrayList;
import?java.util.HashMap;
import?java.util.Map;
/**
*?虛擬鍵盤
*/
public?class?VirtualKeyboardView?extends?RelativeLayout?implements?View.OnClickListener?{
Context?context;
private?GridView?gridView;?
private?RelativeLayout?layoutBack;
private?ArrayList<Map<String, String>>?valueList;?
public?VirtualKeyboardView(Context?context)?{
this(context,?null);
}
public?VirtualKeyboardView(Context?context,?AttributeSet?attrs)?{
super(context,?attrs);
this.context?=?context;
View?view?=?View.inflate(context,?R.layout.layout_virtual_keyboard,?null);
valueList?=?new?ArrayList<>();
layoutBack?=?(RelativeLayout)?view.findViewById(R.id.layoutBack);
layoutBack.setOnClickListener(this);
gridView?=?(GridView)?view.findViewById(R.id.gv_keybord);
setView();
addView(view);?
}
public?RelativeLayout?getLayoutBack()?{
return?layoutBack;
}
public?ArrayList<Map<String, String>>?getValueList()?{
return?valueList;
}
public?GridView?getGridView()?{
return?gridView;
}
private?void?setView()?{
/*?初始化按鈕上應(yīng)該顯示的數(shù)字?*/
for?(int?i?=?1;?i?< 13; i++) {
Map<String, String>?map?=?new?HashMap<String, String>();
if?(i?<?10)?{
map.put("name",?String.valueOf(i));
}?else?if?(i?==?10)?{
map.put("name",?".");
}?else?if?(i?==?11)?{
map.put("name",?String.valueOf(0));
}?else?if?(i?==?12)?{
map.put("name",?"");
}
valueList.add(map);
}
KeyBoardAdapter?keyBoardAdapter?=?new?KeyBoardAdapter(context,?valueList);
gridView.setAdapter(keyBoardAdapter);
}
@Override
public?void?onClick(View?v)?{
}
}

看下適配器如何處理:KeyBoardAdapter .java

import?android.content.Context;
import?android.graphics.Color;
import?android.view.View;
import?android.view.ViewGroup;
import?android.widget.BaseAdapter;
import?android.widget.RelativeLayout;
import?android.widget.TextView;
import?com.lnyp.pswkeyboard.R;
import?java.util.ArrayList;
import?java.util.Map;
/**
*?九宮格鍵盤適配器
*/
public?class?KeyBoardAdapter?extends?BaseAdapter?{
private?Context?mContext;
private?ArrayList<Map<String, String>>?valueList;
public?KeyBoardAdapter(Context?mContext,?ArrayList<Map<String, String>>?valueList)?{
this.mContext?=?mContext;
this.valueList?=?valueList;
}
@Override
public?int?getCount()?{
return?valueList.size();
}
@Override
public?Object?getItem(int?position)?{
return?valueList.get(position);
}
@Override
public?long?getItemId(int?position)?{
return?position;
}
@Override
public?View?getView(int?position,?View?convertView,?ViewGroup?parent)?{
ViewHolder?viewHolder;
if?(convertView?==?null)?{
convertView?=?View.inflate(mContext,?R.layout.grid_item_virtual_keyboard,?null);
viewHolder?=?new?ViewHolder();
viewHolder.btnKey?=?(TextView)?convertView.findViewById(R.id.btn_keys);
viewHolder.imgDelete?=?(RelativeLayout)?convertView.findViewById(R.id.imgDelete);
convertView.setTag(viewHolder);
}?else?{
viewHolder?=?(ViewHolder)?convertView.getTag();
}
if?(position?==?9)?{
viewHolder.imgDelete.setVisibility(View.INVISIBLE);
viewHolder.btnKey.setVisibility(View.VISIBLE);
viewHolder.btnKey.setText(valueList.get(position).get("name"));
viewHolder.btnKey.setBackgroundColor(Color.parseColor("#e0e0e0"));
}?else?if?(position?==?11)?{
viewHolder.btnKey.setBackgroundResource(R.mipmap.keyboard_delete_img);
viewHolder.imgDelete.setVisibility(View.VISIBLE);
viewHolder.btnKey.setVisibility(View.INVISIBLE);
}?else?{
viewHolder.imgDelete.setVisibility(View.INVISIBLE);
viewHolder.btnKey.setVisibility(View.VISIBLE);
viewHolder.btnKey.setText(valueList.get(position).get("name"));
}
return?convertView;
}
/**
*?存放控件
*/
public?final?class?ViewHolder?{
public?TextView?btnKey;
public?RelativeLayout?imgDelete;
}
}

在看Adapter之前,我們先看下grid_item_virtual_keyboard是如何實現(xiàn)的:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#e0e0e0">
<TextView
android:id="@+id/btn_keys"
android:layout_width="match_parent"
android:layout_height="60dp"
android:layout_centerInParent="true"
android:background="@drawable/selector_gird_item"
android:gravity="center"
android:includeFontPadding="false"
android:textColor="#333333"
android:textSize="26sp" />
<RelativeLayout
android:id="@+id/imgDelete"
android:layout_width="wrap_content"
android:layout_height="60dp"
android:layout_centerInParent="true">
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:src="@mipmap/keyboard_delete_img" />
</RelativeLayout>
</RelativeLayout>

可以看到,我們在item布局文件中,指定了兩個view,一個是普通顯示數(shù)字的TextView, 一個是顯示最后刪除鍵的RelativeLayout。
然后,在KeyBoardAdapter 的getView方法中,我們根據(jù)position位置,對布局進行不同的處理。當(dāng)position為9,也就是倒數(shù)第三個按鍵,它的按鈕顏色要單獨設(shè)置。 當(dāng)position為12也就是最后一個按鈕時,需要控制刪除按鈕顯示,數(shù)字按鈕隱藏。 其余情況則是刪除按鈕隱藏,數(shù)字按鈕顯示。

3.使用并實現(xiàn)鍵盤事件邏輯

布局中,可以直接使用自己定義的數(shù)字鍵盤:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#efefef"
tools:context="com.lnyp.pswkeyboard.NormalKeyBoardActivity">
<EditText
android:id="@+id/textAmount"
android:layout_width="match_parent"
android:layout_height="50dp"
android:background="#FFFFFF"
android:inputType="numberDecimal"
android:padding="14dp"
android:textColor="#333333"
android:textSize="16sp" />
<com.lnyp.pswkeyboard.widget.VirtualKeyboardView
android:id="@+id/virtualKeyboardView"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom" />
</RelativeLayout>

我們在Activity中,操作數(shù)字鍵盤:

import?android.os.Bundle;
import?android.support.v7.app.AppCompatActivity;
import?android.text.Editable;
import?android.view.View;
import?android.view.animation.Animation;
import?android.view.animation.AnimationUtils;
import?android.widget.AdapterView;
import?android.widget.EditText;
import?android.widget.GridView;
import?com.lnyp.pswkeyboard.widget.VirtualKeyboardView;
import?java.util.ArrayList;
import?java.util.Map;
public?class?NormalKeyBoardActivity?extends?AppCompatActivity?{
private?VirtualKeyboardView?virtualKeyboardView;
private?GridView?gridView;
private?ArrayList<Map<String, String>>?valueList;
private?EditText?textAmount;
private?Animation?enterAnim;
private?Animation?exitAnim;
@Override
protected?void?onCreate(Bundle?savedInstanceState)?{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_normal_key_board);
valueList?=?virtualKeyboardView.getValueList();
initAnim();
initView();
}
private?void?initAnim()?{
enterAnim?=?AnimationUtils.loadAnimation(this,?R.anim.push_bottom_in);
exitAnim?=?AnimationUtils.loadAnimation(this,?R.anim.push_bottom_out);
}
private?void?initView()?{
virtualKeyboardView?=?(VirtualKeyboardView)?findViewById(R.id.virtualKeyboardView);
textAmount?=?(EditText)?findViewById(R.id.textAmount);
virtualKeyboardView.getLayoutBack().setOnClickListener(new?View.OnClickListener()?{
@Override
public?void?onClick(View?v)?{
virtualKeyboardView.startAnimation(exitAnim);
virtualKeyboardView.setVisibility(View.GONE);
}
});
gridView?=?virtualKeyboardView.getGridView();
gridView.setOnItemClickListener(onItemClickListener);
textAmount.setOnClickListener(new?View.OnClickListener()?{
@Override
public?void?onClick(View?v)?{
virtualKeyboardView.setFocusable(true);
virtualKeyboardView.setFocusableInTouchMode(true);
virtualKeyboardView.startAnimation(enterAnim);
virtualKeyboardView.setVisibility(View.VISIBLE);
}
});
}
private?AdapterView.OnItemClickListener?onItemClickListener?=?new?AdapterView.OnItemClickListener()?{
@Override
public?void?onItemClick(AdapterView<?>?adapterView,?View?view,?int?position,?long?l)?{
if?(position?< 11 && position != 9) { //點擊0~9按鈕
String amount = textAmount.getText().toString().trim();
amount = amount + valueList.get(position).get("name");
textAmount.setText(amount);
Editable ea = textAmount.getText();
textAmount.setSelection(ea.length());
} else {
if (position == 9) { //點擊退格鍵
String amount = textAmount.getText().toString().trim();
if (!amount.contains(".")) {
amount = amount + valueList.get(position).get("name");
textAmount.setText(amount);
Editable ea = textAmount.getText();
textAmount.setSelection(ea.length());
}
}
if (position == 11) { //點擊退格鍵
String amount = textAmount.getText().toString().trim();
if (amount.length() >?0)?{
amount?=?amount.substring(0,?amount.length()?-?1);
textAmount.setText(amount);
Editable?ea?=?textAmount.getText();
textAmount.setSelection(ea.length());
}
}
}
}
};}

Atas ialah kandungan terperinci Android 高仿微信支付數(shù)字鍵盤功能. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial PHP
1502
276
Laporan baharu memberikan penilaian yang memberatkan terhadap khabar angin tentang peningkatan kamera Samsung Galaxy S25, Galaxy S25 Plus dan Galaxy S25 Ultra Laporan baharu memberikan penilaian yang memberatkan terhadap khabar angin tentang peningkatan kamera Samsung Galaxy S25, Galaxy S25 Plus dan Galaxy S25 Ultra Sep 12, 2024 pm 12:23 PM

Dalam beberapa hari kebelakangan ini, Ice Universe terus mendedahkan butiran mengenai Galaxy S25 Ultra, yang secara meluas dipercayai sebagai telefon pintar utama Samsung yang seterusnya. Antara lain, pembocor itu mendakwa bahawa Samsung hanya merancang untuk membawa satu peningkatan kamera

Samsung Galaxy S25 Ultra bocor dalam imej paparan pertama dengan perubahan reka bentuk khabar angin didedahkan Samsung Galaxy S25 Ultra bocor dalam imej paparan pertama dengan perubahan reka bentuk khabar angin didedahkan Sep 11, 2024 am 06:37 AM

OnLeaks kini telah bekerjasama dengan Android Headlines untuk memberikan pandangan pertama pada Galaxy S25 Ultra, beberapa hari selepas percubaan gagal untuk menjana lebih daripada $4,000 daripada pengikut X (dahulunya Twitter). Untuk konteks, imej pemaparan yang dibenamkan di bawah h

IFA 2024 | NXTPAPER 14 TCL tidak akan sepadan dengan prestasi Galaxy Tab S10 Ultra, tetapi ia hampir sepadan dengan saiznya IFA 2024 | NXTPAPER 14 TCL tidak akan sepadan dengan prestasi Galaxy Tab S10 Ultra, tetapi ia hampir sepadan dengan saiznya Sep 07, 2024 am 06:35 AM

Di samping mengumumkan dua telefon pintar baharu, TCL juga telah mengumumkan tablet Android baharu yang dipanggil NXTPAPER 14, dan saiz skrinnya yang besar adalah salah satu nilai jualannya. NXTPAPER 14 menampilkan versi 3.0 jenama tandatangan TCL panel LCD matte

Vivo Y300 Pro mempunyai bateri 6,500 mAh dalam badan 7.69 mm yang tipis Vivo Y300 Pro mempunyai bateri 6,500 mAh dalam badan 7.69 mm yang tipis Sep 07, 2024 am 06:39 AM

Vivo Y300 Pro baru sahaja didedahkan sepenuhnya, dan ia merupakan salah satu telefon Android jarak pertengahan paling tipis dengan bateri yang besar. Tepatnya, telefon pintar ini hanya tebal 7.69 mm tetapi mempunyai bateri 6,500 mAh. Ini adalah kapasiti yang sama seperti yang dilancarkan baru-baru ini

Samsung Galaxy S24 FE dibilkan untuk melancarkan kurang daripada yang dijangkakan dalam empat warna dan dua pilihan memori Samsung Galaxy S24 FE dibilkan untuk melancarkan kurang daripada yang dijangkakan dalam empat warna dan dua pilihan memori Sep 12, 2024 pm 09:21 PM

Samsung belum menawarkan sebarang petunjuk lagi tentang bila ia akan mengemas kini siri telefon pintar Edisi Peminat (FE). Seperti sedia ada, Galaxy S23 FE kekal sebagai edisi terbaharu syarikat, telah dibentangkan pada awal Oktober 2023. Walau bagaimanapun, banyak

Laporan baharu memberikan penilaian yang memberatkan terhadap khabar angin tentang peningkatan kamera Samsung Galaxy S25, Galaxy S25 Plus dan Galaxy S25 Ultra Laporan baharu memberikan penilaian yang memberatkan terhadap khabar angin tentang peningkatan kamera Samsung Galaxy S25, Galaxy S25 Plus dan Galaxy S25 Ultra Sep 12, 2024 pm 12:22 PM

Dalam beberapa hari kebelakangan ini, Ice Universe terus mendedahkan butiran mengenai Galaxy S25 Ultra, yang secara meluas dipercayai sebagai telefon pintar utama Samsung yang seterusnya. Antara lain, pembocor itu mendakwa bahawa Samsung hanya merancang untuk membawa satu peningkatan kamera

iQOO Z9 Turbo Plus: Tempahan bermula untuk siri perdana yang berpotensi dipertingkatkan iQOO Z9 Turbo Plus: Tempahan bermula untuk siri perdana yang berpotensi dipertingkatkan Sep 10, 2024 am 06:45 AM

Jenama OnePlus iQOO mempunyai kitaran produk 2023-4 yang mungkin hampir tamat; Namun begitu, jenama itu telah mengisytiharkan bahawa ia belum selesai dengan siri Z9nya. Varian Turbo+yang terakhir, dan mungkin paling akhir, baru sahaja diumumkan seperti yang diramalkan. T

Xiaomi Redmi Note 14 Pro Plus tiba sebagai telefon pintar Qualcomm Snapdragon 7s Gen 3 pertama dengan kamera Light Hunter 800 Xiaomi Redmi Note 14 Pro Plus tiba sebagai telefon pintar Qualcomm Snapdragon 7s Gen 3 pertama dengan kamera Light Hunter 800 Sep 27, 2024 am 06:23 AM

Redmi Note 14 Pro Plus kini rasmi sebagai pengganti langsung kepada Redmi Note 13 Pro Plus tahun lepas (sekira $375 di Amazon). Seperti yang dijangkakan, Redmi Note 14 Pro Plus mengetuai siri Redmi Note 14 bersama Redmi Note 14 dan Redmi Note 14 Pro. Li

See all articles