Android通過自定義View實現(xiàn)隨機驗證碼
很多的Android入門程序猿來說對于Android自定義View,可能都是比較恐懼的,但是這又是高手進階的必經(jīng)之路,所有準(zhǔn)備在自定義View上面花一些功夫,多寫一些文章。
一、問題描述
熟悉web開發(fā)中童鞋們都知道為了防止惡意破解、惡意提交、刷票等我們在提交表單數(shù)據(jù)時,都會使用隨機驗證碼功能。在Android應(yīng)用中我們同樣需要這一功能,該如何實現(xiàn)呢,下面我們就自定義一個隨機驗證碼View控件實現(xiàn)這一需求,并且具備通用性,需要的時候在界面中直接加入這個View組件即可。
二、案例介紹
案例運行效果

案例所涉及組件
1、CheckView 自定義的驗證碼控件,主要重寫onDraw方法實現(xiàn)圖形繪制
2、Config:用于對驗證碼控件參數(shù)的配置,像畫點點數(shù)、劃線數(shù)、背景顏色的設(shè)置
3、CheckUtil:驗證碼相關(guān)工具類,實現(xiàn)例如隨機的點坐標(biāo)、隨機線段起始和結(jié)束點坐標(biāo)、驗證碼校驗等功能
4、MainActivity:測試應(yīng)用
三、功能實現(xiàn)
1、編寫Config組件
/**
* 功能:用于對驗證碼控件參數(shù)的配置
* */
public class Config {
// 驗證碼更新時間
public static final int PTEDE_TIME = 1200;
// 點數(shù)設(shè)置
public static final int POINT_NUM = 100;
// 線段數(shù)設(shè)置
public static final int LINE_NUM = 2;
//設(shè)置背景顏色
public static final int COLOR=Color.BLUE;
//隨機數(shù)據(jù)長度
public static int TEXT_LENGTH=4;
//設(shè)置驗證碼字體大小
public static int TEXT_SIZE=30;
}
2、CheckUtil組件
/**
* 功能:驗證碼相關(guān)工具類
* */
public class CheckUtil
{
/**
* 產(chǎn)生隨機數(shù)字
* @return
*/
public static int [] getCheckNum(){
int [] tempCheckNum = new int[Config.TEXT_LENGTH];
for(int i = 0; i < Config.TEXT_LENGTH; i++){
tempCheckNum[i] = (int) (Math.random() * 10);
}
return tempCheckNum;
}
/**
* 隨機產(chǎn)生劃線的起始點坐標(biāo)和結(jié)束點坐標(biāo)
* @param height 傳入CheckView的高度值
* @param width 傳入CheckView的寬度值
* @return 起始點坐標(biāo)和結(jié)束點坐標(biāo)
*/
public static int[] getLine(int height, int width){
int [] tempCheckNum = {0,0,0,0};
for(int i = 0; i < 4; i+=2){
tempCheckNum[i] = (int) (Math.random() * width);
tempCheckNum[i + 1] = (int) (Math.random() * height);
}
return tempCheckNum;
}
/**
* 隨機產(chǎn)生點的圓心點坐標(biāo)
* @param height 傳入CheckView的高度值
* @param width 傳入CheckView的寬度值
* @return
*/
public static int[] getPoint(int height, int width){
int [] tempCheckNum = {0,0,0,0};
tempCheckNum[0] = (int) (Math.random() * width);
tempCheckNum[1] = (int) (Math.random() * height);
return tempCheckNum;
}
/**
* 驗證是否正確
* @param userCheck 用戶輸入的驗證碼
* @param checkNum 驗證控件產(chǎn)生的隨機數(shù)
* @return
*/
public static boolean checkNum(String userCheck, int[] checkNum){
if(userCheck.length() != 4 ){
return false;
}
String checkString = "";
for (int i = 0; i < 4; i++) {
checkString += checkNum[i];
}
if(userCheck.equals(checkString)){
return true;
}
else {
return false;
}
}
/**
* 計算驗證碼的繪制y點位置
* @param height 傳入CheckView的高度值
* @return
*/
public static int getPositon(int height){
int tempPositoin = (int) (Math.random() * height);
if(tempPositoin < 20){
tempPositoin += 20;
}
return tempPositoin;
}
}
3、自定義驗證碼控件CheckView
public class CheckView extends View{
Context mContext;
int [] CheckNum = null;
Paint mTempPaint = new Paint();
// 驗證碼
public CheckView(Context context, AttributeSet attrs) {
super(context, attrs);
mContext = context;
mTempPaint.setAntiAlias(true);
mTempPaint.setTextSize(Config.TEXT_SIZE);
mTempPaint.setStrokeWidth(3);
}
public void onDraw(Canvas canvas){
canvas.drawColor(Config.COLOR);
final int height = getHeight();//獲得CheckView控件的高度
final int width = getWidth();//獲得CheckView控件的寬度
int dx = 40;
for(int i = 0; i < 4; i ++){//繪制驗證控件上的文本
canvas.drawText("" + CheckNum[i], dx, CheckUtil.getPositon(height), mTempPaint);
dx += width/ 5;
}
int [] line;
for(int i = 0; i < Config.LINE_NUM; i ++){//劃線
line = CheckUtil.getLine(height, width);
canvas.drawLine(line[0], line[1], line[2], line[3], mTempPaint);
}
// 繪制小圓點
int [] point;
for(int i = 0; i < Config.POINT_NUM; i ++) {//畫點
point=CheckUtil.getPoint(height, width);
canvas.drawCircle(point[0], point[1], 1, mTempPaint);
}
}
public void setCheckNum(int [] chenckNum) {//設(shè)置驗證碼
CheckNum = chenckNum;
}
public int[] getCheckNum() {//獲得驗證碼
return CheckNum;
}
public void invaliChenkNum() {
invalidate();
}
}
4、編寫MainActivity測試代碼
public class MainActivity extends Activity implements View.OnClickListener{
private CheckAction mCheckView ;
private TextView mShowPassViwe;
private EditText mEditPass;
private Button mSubmit;
private Button mRef;
// 驗證碼:
private int [] checkNum =null;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
initView();
initCheckNum();
}
public void initView(){
mCheckView = (CheckView) findViewById(R.id.checkView);
mShowPassViwe = (TextView) findViewById(R.id.checkpass);
mEditPass = (EditText) findViewById(R.id.checkTest);
mSubmit = (Button) findViewById(R.id.submit);
mRef = (Button) findViewById(R.id.ref);
mSubmit.setOnClickListener(this);
mRef.setOnClickListener(this);
}
// 初始化驗證碼并且刷新界面
public void initCheckNum(){
checkNum = CheckUtil.getCheckNum();
mCheckView.setCheckNum(checkNum);
mCheckView.invaliChenkNum();
}
public void onClick(View v) {
switch (v.getId()){
case R.id.submit:
String userInput = mEditPass.getText().toString();
if(CheckUtil.checkNum(userInput, checkNum)){
setPassString("通過");
Toast.makeText(this, "通過", 1200).show();
}else{
setPassString("未通過");
Toast.makeText(this, "未通過", 1200).show();
}
break;
case R.id.ref:
initCheckNum();
break;
default:
break;
}
}
public void setPassString(String passString) {
mShowPassViwe.setText(passString);
}
}
以上所述是針對Android通過自定義View實現(xiàn)隨機驗證碼的相關(guān)知識,希望對大家有所幫助!
相關(guān)文章
Android仿微信菜單(Menu)(使用C#和Java分別實現(xiàn))
這篇文章主要介紹了Android仿微信菜單(Menu)(使用C#和Java分別實現(xiàn)),本文分別給出C#和Java版的運行效果及實現(xiàn)代碼,需要的朋友可以參考下2015-06-06
android獲取及監(jiān)聽手機網(wǎng)絡(luò)狀態(tài)
大家好,本篇文章主要講的是android獲取及監(jiān)聽手機網(wǎng)絡(luò)狀態(tài),感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽2022-01-01
詳細(xì)介紹Android中回調(diào)函數(shù)機制
這篇文章主要介紹了Android中回調(diào)函數(shù)機制,有需要的朋友可以參考一下2014-01-01
Android ScrollView只能添加一個子控件問題解決方法
這篇文章主要介紹了Android ScrollView只能添加一個子控件問題解決方法,涉及Android界面布局的相關(guān)技巧,需要的朋友可以參考下2016-02-02
Android使用OKHttp庫實現(xiàn)視頻文件的上傳到服務(wù)器功能
這篇文章主要介紹了Android使用OKHttp庫實現(xiàn)視頻文件的上傳到服務(wù)器功能,需要的朋友可以參考下2018-03-03
Android之ArcSlidingHelper制作圓弧滑動效果
這篇文章主要介紹了Android之ArcSlidingHelper制作圓弧滑動效果,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-08-08
Android獲取WebView加載url的請求錯誤碼 【推薦】
這篇文章主要介紹了Android獲取WebView加載url的請求錯誤碼 ,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-06-06

