


Android hohe Nachahmung der numerischen WeChat-Zahlungstastaturfunktion
Mar 27, 2017 pm 01:44 PMViele Apps verwenden mittlerweile benutzerdefinierte numerische Tastaturen für Zahlungs- und Passworteingabefunktionen, was praktisch und praktisch ist. Der folgende Artikel stellt Ihnen die hochkar?tige WeChat-Zahlungstastaturfunktion vor, die sehr gut ist. Interessierte Freunde, lasst uns gemeinsam lernen Schauen Sie sich zuerst die folgenden Darstellungen an:
1. Benutzerdefiniertes Layout
Das Layout der Tastatur ist im Wesentlichen ein 4X3-Raster-Layout
<?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>
2. Numerische Tastaturinhalte implementieren
Sehen wir uns an, wie der Adapter damit umgeht: KeyBoardAdapter .java
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)?{ } }
Wenn wir uns ?Vor dem Adapter“ ansehen, schauen wir uns zun?chst an, wie Grid_item_virtual_keyboard ist implementiert:
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; } }
Wie Sie sehen k?nnen, haben wir in der Elementlayoutdatei zwei Ansichten angegeben, eine ist eine Textansicht, die normalerweise Zahlen anzeigt, und die andere ist eine Anzeige. L?schen Sie schlie?lich das RelativeLayout von
In der getView-Methode von KeyBoardAdapter verarbeiten wir das Layout entsprechend der Position 9, also der dritten Schaltfl?che von unten Ist 12 die letzte Schaltfl?che, müssen Sie steuern, dass die Schaltfl?che ?L?schen“ angezeigt und die Schaltfl?che ?Nummer“ ausgeblendet wird. In anderen F?llen wird die Schaltfl?che ?L?schen“ ausgeblendet und die Schaltfl?che ?Nummer“ angezeigt ??>3. Im logischen<?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>
-Layout k?nnen Sie direkt Ihre eigene definierte Zifferntastatur verwenden:
Wir bedienen die Zifferntastatur in Activity :
Das obige ist der detaillierte Inhalt vonAndroid hohe Nachahmung der numerischen WeChat-Zahlungstastaturfunktion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Hei?e KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem v?llig kostenlosen KI-Gesichtstausch-Tool aus!

Hei?er Artikel

Hei?e Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

In den letzten Tagen hat Ice Universe immer wieder Details zum Galaxy S25 Ultra enthüllt, von dem allgemein angenommen wird, dass es das n?chste Flaggschiff-Smartphone von Samsung ist. Der Leaker behauptete unter anderem, Samsung plane nur ein Kamera-Upgrade

OnLeaks hat sich nun mit Android Headlines zusammengetan, um einen ersten Blick auf das Galaxy S25 Ultra zu werfen, nur wenige Tage nach dem gescheiterten Versuch, mehr als 4.000 US-Dollar von seinen X-Followern (ehemals Twitter) zu generieren. Für den Kontext sind die unten eingebetteten Renderbilder h

Neben der Ankündigung zweier neuer Smartphones hat TCL auch ein neues Android-Tablet namens NXTPAPER 14 angekündigt, dessen riesige Bildschirmgr??e eines seiner Verkaufsargumente ist. Das NXTPAPER 14 verfügt über Version 3.0 der matten LCD-Panels der Signaturmarke von TCL

Das Vivo Y300 Pro wurde gerade vollst?ndig vorgestellt und ist eines der schlanksten Mittelklasse-Android-Telefone mit einem gro?en Akku. Genauer gesagt ist das Smartphone nur 7,69 mm dick, verfügt aber über einen 6.500 mAh starken Akku. Dies ist die gleiche Kapazit?t wie bei der kürzlich eingeführten Version

Samsung hat noch keine Hinweise darauf gegeben, wann es seine Smartphone-Serie Fan Edition (FE) aktualisieren wird. Derzeit ist das Galaxy S23 FE nach wie vor die jüngste Ausgabe des Unternehmens und wurde Anfang Oktober 2023 vorgestellt

In den letzten Tagen hat Ice Universe immer wieder Details zum Galaxy S25 Ultra enthüllt, von dem allgemein angenommen wird, dass es das n?chste Flaggschiff-Smartphone von Samsung ist. Der Leaker behauptete unter anderem, Samsung plane nur ein Kamera-Upgrade

Die Schwestermarke von OnePlus, iQOO, hat einen Produktzyklus von 2023 bis 2024, der m?glicherweise fast abgeschlossen ist. Dennoch hat die Marke erkl?rt, dass sie mit ihrer Z9-Serie noch nicht fertig sei. Seine letzte und m?glicherweise hochwertigste Turbo+-Variante wurde gerade wie vorhergesagt angekündigt. T

Das Redmi Note 14 Pro Plus ist nun offiziell als direkter Nachfolger des letztj?hrigen Redmi Note 13 Pro Plus (aktuell 375 $ bei Amazon) erh?ltlich. Wie erwartet steht das Redmi Note 14 Pro Plus neben dem Redmi Note 14 und dem Redmi Note 14 Pro an der Spitze der Redmi Note 14-Serie. Li
