학습 노트 - 사용자 정의 암호 입력 상자와 사용자 정의 디지털 암호 소프트 키보드
10965 단어 Android
최근에 프로젝트에 결제 기능이 하나 있는데 사용자 정의 키보드가 필요합니다. 그래서 제가 인터넷에서 검색해 봤는데 이것은 제 수요와 매우 일치합니다. 프로젝트가 완공되면 여러분께 공유하려고 했지만 프로젝트의 블로거를 찾지 못했습니다. 여기는 블로거님께 감사드립니다. 저는 직접 스티커 코드를 여러분께 공유했습니다.
XNumberKeyboardView.java
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Rect;
import android.graphics.drawable.ColorDrawable;
import android.graphics.drawable.Drawable;
import android.inputmethodservice.Keyboard;
import android.inputmethodservice.KeyboardView;
import android.util.AttributeSet;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
/**
* 。
*
* @author wuzhen
*/
public class XNumberKeyboardView extends KeyboardView implements KeyboardView.OnKeyboardActionListener {
//
private static final int KEYCODE_EMPTY = -10;
private int mDeleteWidth;
private int mDeleteHeight;
private int mDeleteBackgroundColor;
private Drawable mDeleteDrawable;
private Rect mDeleteDrawRect;
private IOnKeyboardListener mOnKeyboardListener;
public XNumberKeyboardView(Context context, AttributeSet attrs) {
super(context, attrs);
init(context, attrs, 0);
}
public XNumberKeyboardView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
init(context, attrs, defStyleAttr);
}
private void init(Context context, AttributeSet attrs, int defStyleAttr) {
TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.XNumberKeyboardView,
defStyleAttr, 0);
mDeleteDrawable = a.getDrawable(R.styleable.XNumberKeyboardView_xnkv_deleteDrawable);
mDeleteBackgroundColor = a.getColor(
R.styleable.XNumberKeyboardView_xnkv_deleteBackgroundColor, Color.TRANSPARENT);
mDeleteWidth = a.getDimensionPixelOffset(R.styleable.XNumberKeyboardView_xnkv_deleteWidth,
-1);
mDeleteHeight = a.getDimensionPixelOffset(R.styleable.XNumberKeyboardView_xnkv_deleteHeight,
-1);
a.recycle();
//
Keyboard keyboard = new Keyboard(context, R.xml.keyboard_number);
setKeyboard(keyboard);
setEnabled(true);
setPreviewEnabled(false); //
setOnKeyboardActionListener(this);
}
@Override
public void onDraw(Canvas canvas) {
super.onDraw(canvas);
//
List keys = getKeyboard().getKeys();
for (Keyboard.Key key : keys) {
// ,
if (key.codes[0] == KEYCODE_EMPTY) {
drawKeyBackground(key, canvas, mDeleteBackgroundColor);
}
// , ,
else if (key.codes[0] == Keyboard.KEYCODE_DELETE) {
drawKeyBackground(key, canvas, mDeleteBackgroundColor);
drawDeleteButton(key, canvas);
}
}
}
//
private void drawKeyBackground(Keyboard.Key key, Canvas canvas, int color) {
ColorDrawable drawable = new ColorDrawable(color);
drawable.setBounds(key.x, key.y, key.x + key.width, key.y + key.height);
drawable.draw(canvas);
}
//
private void drawDeleteButton(Keyboard.Key key, Canvas canvas) {
if (mDeleteDrawable == null) {
return;
}
//
if (mDeleteDrawRect == null || mDeleteDrawRect.isEmpty()) {
int drawWidth, drawHeight;
int intrinsicWidth = mDeleteDrawable.getIntrinsicWidth();
int intrinsicHeight = mDeleteDrawable.getIntrinsicHeight();
if (mDeleteWidth > 0 && mDeleteHeight > 0) {
drawWidth = mDeleteWidth;
drawHeight = mDeleteHeight;
} else if (mDeleteWidth > 0 && mDeleteHeight <= 0) {
drawWidth = mDeleteWidth;
drawHeight = drawWidth * intrinsicHeight / intrinsicWidth;
} else if (mDeleteWidth <= 0 && mDeleteHeight > 0) {
drawHeight = mDeleteHeight;
drawWidth = drawHeight * intrinsicWidth / intrinsicHeight;
} else {
drawWidth = intrinsicWidth;
drawHeight = intrinsicHeight;
}
// ,
if (drawWidth > key.width) {
drawWidth = key.width;
drawHeight = drawWidth * intrinsicHeight / intrinsicWidth;
}
if (drawHeight > key.height) {
drawHeight = key.height;
drawWidth = drawHeight * intrinsicWidth / intrinsicHeight;
}
//
int left = key.x + (key.width - drawWidth) / 2;
int top = key.y + (key.height - drawHeight) / 2;
mDeleteDrawRect = new Rect(left, top, left + drawWidth, top + drawHeight);
}
//
if (mDeleteDrawRect != null && !mDeleteDrawRect.isEmpty()) {
mDeleteDrawable.setBounds(mDeleteDrawRect.left, mDeleteDrawRect.top,
mDeleteDrawRect.right, mDeleteDrawRect.bottom);
mDeleteDrawable.draw(canvas);
}
}
@Override
public void onKey(int primaryCode, int[] keyCodes) {
//
//
if (primaryCode == Keyboard.KEYCODE_DELETE) {
if (mOnKeyboardListener != null)
mOnKeyboardListener.onDeleteKeyEvent();
}
//
else if (primaryCode != KEYCODE_EMPTY) {
if (mOnKeyboardListener != null) {
mOnKeyboardListener.onInsertKeyEvent(Character.toString(
(char) primaryCode));
}
}
}
// 0-9 Character
private final List keyCodes = Arrays.asList('0', '1', '2', '3', '4', '5', '6', '7',
'8', '9');
/**
* 。
*/
public void shuffleKeyboard() {
Keyboard keyboard = getKeyboard();
if (keyboard != null && keyboard.getKeys() != null && keyboard.getKeys().size() > 0) {
Collections.shuffle(keyCodes); //
//
List keys = getKeyboard().getKeys();
int index = 0;
for (Keyboard.Key key : keys) {
//
if (key.codes[0] != KEYCODE_EMPTY && key.codes[0] != Keyboard.KEYCODE_DELETE) {
char code = keyCodes.get(index++);
key.codes[0] = code;
key.label = Character.toString(code);
}
}
setKeyboard(keyboard);
}
}
@Override
public void onPress(int primaryCode) {
}
@Override
public void onRelease(int primaryCode) {
}
@Override
public void onText(CharSequence text) {
}
@Override
public void swipeLeft() {
}
@Override
public void swipeRight() {
}
@Override
public void swipeDown() {
}
@Override
public void swipeUp() {
}
/**
* 。
*
* @param listener
*/
public void setIOnKeyboardListener(IOnKeyboardListener listener) {
this.mOnKeyboardListener = listener;
}
/**
* 。
*/
public interface IOnKeyboardListener {
/**
* 。
*
* @param text
*/
void onInsertKeyEvent(String text);
/**
* 。
*/
void onDeleteKeyEvent();
}
}
layout.xml
사용자 정의 속성 파일
res 디렉터리에 새 xml 폴더를 만들고 소프트 키보드 자원 파일 키보드num.xml
코드 안에 키보드 감청하에 자신의 조작을 하면 OK.
그리고 비밀번호 입력 상자 컨트롤 GridPasswordView, 매우 강력하고 Github 주소;사용하기에도 편리하다.
사용자 정의 속성은 다음과 같습니다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Bitrise에서 배포 어플리케이션 설정 테스트하기이 글은 Bitrise 광고 달력의 23일째 글입니다. 자체 또는 당사 등에서 Bitrise 구축 서비스를 사용합니다. 그나저나 며칠 전 Bitrise User Group Meetup #3에서 아래 슬라이드를 발표했...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.