android圖形驗證碼

android圖形驗證碼

標籤: android圖形驗證碼隨機驗證碼
 1102人閱讀 評論(0) 收藏 舉報
 分類:

廢話不多說上效果圖:

給上activity_main.xml佈局代碼:

[java] view plain copy
  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     xmlns:tools="http://schemas.android.com/tools"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent"  
  5.     tools:context="${relativePackage}.${activityClass}" >  
  6.   
  7.     <LinearLayout   
  8.         android:layout_width="match_parent"  
  9.         android:layout_height="match_parent"  
  10.         android:layout_marginLeft="10dp"  
  11.         android:orientation="vertical">  
  12.         <ImageView   
  13.             android:id="@+id/image"  
  14.             android:layout_width="wrap_content"  
  15.             android:layout_height="wrap_content"  
  16.             android:layout_marginTop="10dp"  
  17.             android:src="@drawable/ic_launcher"/>  
  18.         <EditText   
  19.             android:id="@+id/et"  
  20.             android:layout_width="match_parent"  
  21.             android:layout_height="wrap_content"  
  22.             android:layout_marginTop="10dp"  
  23.             android:hint="輸入驗證碼"/>  
  24.         <Button   
  25.             android:id="@+id/btn"  
  26.             android:layout_width="wrap_content"  
  27.             android:layout_height="wrap_content"  
  28.             android:layout_marginTop="10dp"  
  29.             android:text="獲得驗證碼"/>  
  30.         <Button   
  31.             android:id="@+id/btn_submit"  
  32.             android:layout_width="wrap_content"  
  33.             android:layout_height="wrap_content"  
  34.             android:layout_marginTop="10dp"  
  35.             android:text="提交"/>  
  36.     </LinearLayout>  
  37.   
  38. </RelativeLayout>  

再上mainactivity代碼:
[java] view plain copy
  1. package com.example.codedemo;  
  2.   
  3. import android.app.Activity;  
  4. import android.graphics.Bitmap;  
  5. import android.os.Bundle;  
  6. import android.text.TextUtils;  
  7. import android.util.Log;  
  8. import android.view.View;  
  9. import android.view.View.OnClickListener;  
  10. import android.widget.Button;  
  11. import android.widget.EditText;  
  12. import android.widget.ImageView;  
  13. import android.widget.Toast;  
  14.   
  15. public class MainActivity extends Activity implements OnClickListener {  
  16.   
  17.     private ImageView image;  
  18.     private EditText et;  
  19.     private Button btn,submit;  
  20.     private String codeStr;  
  21.     private CodeUtils codeUtils;  
  22.   
  23.     @Override  
  24.     protected void onCreate(Bundle savedInstanceState) {  
  25.         super.onCreate(savedInstanceState);  
  26.         setContentView(R.layout.activity_main);  
  27.           
  28.         initView();  
  29.           
  30.     }  
  31.   
  32.     private void initView() {  
  33.         image = (ImageView) findViewById(R.id.image);  
  34.         et = (EditText) findViewById(R.id.et);  
  35.         btn = (Button) findViewById(R.id.btn);  
  36.         submit = (Button) findViewById(R.id.btn_submit);  
  37.         btn.setOnClickListener(this);  
  38.         submit.setOnClickListener(this);  
  39.           
  40.     }  
  41.   
  42.     @Override  
  43.     public void onClick(View v) {  
  44.         switch (v.getId()) {  
  45.         case R.id.btn:  
  46.             codeUtils = CodeUtils.getInstance();  
  47.             Bitmap bitmap = codeUtils.createBitmap();  
  48.             image.setImageBitmap(bitmap);  
  49.               
  50.             break;  
  51.         case R.id.btn_submit:  
  52.             codeStr = et.getText().toString().trim();  
  53.             Log.e("codeStr", codeStr);  
  54.             if (null == codeStr || TextUtils.isEmpty(codeStr)) {  
  55.                 Toast.makeText(this"請輸入驗證碼"0).show();  
  56.                 return;  
  57.             }  
  58.             String code = codeUtils.getCode();  
  59.             Log.e("code", code);  
  60.             if (code.equalsIgnoreCase(codeStr)) {  
  61.                 Toast.makeText(this"驗證碼正確"0).show();  
  62.             } else {  
  63.                 Toast.makeText(this"驗證碼錯誤"0).show();  
  64.             }  
  65.             break;  
  66.         default:  
  67.             break;  
  68.         }  
  69.           
  70.     }  
  71. }  

最後附上CodeUtils代碼:
[java] view plain copy
  1. package com.example.codedemo;  
  2.   
  3. import android.graphics.Bitmap;    
  4. import android.graphics.Bitmap.Config;    
  5. import android.graphics.Canvas;    
  6. import android.graphics.Color;    
  7. import android.graphics.Paint;    
  8.     
  9. import java.util.Random;    
  10.     
  11. /**  
  12.  * Created by yao  
  13.  * 用於圖片驗證碼的工具類  
  14.  */    
  15. public class CodeUtils {    
  16.     private static final char[] CHARS = {    
  17.             '0''1''2''3''4''5''6''7''8''9',    
  18.             'a''b''c''d''e''f''g''h''i''j''k''l''m',    
  19.             'n''o''p''q''r''s''t''u''v''w''x''y''z',    
  20.             'A''B''C''D''E''F''G''H''I''J''K''L''M',    
  21.             'N''O''P''Q''R''S''T''U''V''W''X''Y''Z'    
  22.     };    
  23.     
  24.     private static CodeUtils mCodeUtils;    
  25.     private int mPaddingLeft, mPaddingTop;    
  26.     private StringBuilder mBuilder = new StringBuilder();    
  27.     private Random mRandom = new Random();    
  28.     
  29.     //Default Settings    
  30.     private static final int DEFAULT_CODE_LENGTH = 6;//驗證碼的長度  這裏是6位    
  31.     private static final int DEFAULT_FONT_SIZE = 60;//字體大小    
  32.     private static final int DEFAULT_LINE_NUMBER = 3;//多少條幹擾線    
  33.     private static final int BASE_PADDING_LEFT = 20//左邊距    
  34.     private static final int RANGE_PADDING_LEFT = 30;//左邊距範圍值    
  35.     private static final int BASE_PADDING_TOP = 70;//上邊距    
  36.     private static final int RANGE_PADDING_TOP = 15;//上邊距範圍值    
  37.     private static final int DEFAULT_WIDTH = 300;//默認寬度.圖片的總寬    
  38.     private static final int DEFAULT_HEIGHT = 100;//默認高度.圖片的總高    
  39.     private static final int DEFAULT_COLOR = 0xDF;//默認背景顏色值    
  40.   
  41.     private String code;  
  42.     
  43.     public static CodeUtils getInstance() {    
  44.         if(mCodeUtils == null) {    
  45.             mCodeUtils = new CodeUtils();    
  46.         }    
  47.         return mCodeUtils;    
  48.     }    
  49.     
  50.     //生成驗證碼圖片    
  51.     public Bitmap createBitmap() {    
  52.         mPaddingLeft = 0//每次生成驗證碼圖片時初始化    
  53.         mPaddingTop = 0;    
  54.     
  55.         Bitmap bitmap = Bitmap.createBitmap(DEFAULT_WIDTH, DEFAULT_HEIGHT, Config.ARGB_8888);    
  56.         Canvas canvas = new Canvas(bitmap);    
  57.     
  58.         code = createCode();    
  59.     
  60.         canvas.drawColor(Color.rgb(DEFAULT_COLOR, DEFAULT_COLOR, DEFAULT_COLOR));    
  61.         Paint paint = new Paint();    
  62.         paint.setTextSize(DEFAULT_FONT_SIZE);    
  63.     
  64.         for (int i = 0; i < code.length(); i++) {    
  65.             randomTextStyle(paint);    
  66.             randomPadding();    
  67.             canvas.drawText(code.charAt(i) + "" , mPaddingLeft, mPaddingTop, paint);    
  68.         }    
  69.     
  70.         //干擾線    
  71.         for (int i = 0; i < DEFAULT_LINE_NUMBER; i++) {    
  72.             drawLine(canvas, paint);    
  73.         }    
  74.     
  75.         canvas.save(Canvas.ALL_SAVE_FLAG);//保存    
  76.         canvas.restore();    
  77.         return bitmap;    
  78.     }    
  79.     /** 
  80.      * 得到圖片中的驗證碼字符串 
  81.      * @return  
  82.      */  
  83.     public String getCode() {  
  84.         return code;  
  85.     }  
  86.     
  87.     //生成驗證碼    
  88.     public String createCode() {    
  89.         mBuilder.delete(0, mBuilder.length()); //使用之前首先清空內容    
  90.     
  91.         for (int i = 0; i < DEFAULT_CODE_LENGTH; i++) {    
  92.             mBuilder.append(CHARS[mRandom.nextInt(CHARS.length)]);    
  93.         }    
  94.     
  95.         return mBuilder.toString();    
  96.     }    
  97.     
  98.     //生成干擾線    
  99.     private void drawLine(Canvas canvas, Paint paint) {    
  100.         int color = randomColor();    
  101.         int startX = mRandom.nextInt(DEFAULT_WIDTH);    
  102.         int startY = mRandom.nextInt(DEFAULT_HEIGHT);    
  103.         int stopX = mRandom.nextInt(DEFAULT_WIDTH);    
  104.         int stopY = mRandom.nextInt(DEFAULT_HEIGHT);    
  105.         paint.setStrokeWidth(1);    
  106.         paint.setColor(color);    
  107.         canvas.drawLine(startX, startY, stopX, stopY, paint);    
  108.     }    
  109.     
  110.     //隨機顏色    
  111.     private int randomColor() {    
  112.         mBuilder.delete(0, mBuilder.length()); //使用之前首先清空內容    
  113.     
  114.         String haxString;    
  115.         for (int i = 0; i < 3; i++) {    
  116.             haxString = Integer.toHexString(mRandom.nextInt(0xFF));    
  117.             if (haxString.length() == 1) {    
  118.                 haxString = "0" + haxString;    
  119.             }    
  120.     
  121.             mBuilder.append(haxString);    
  122.         }    
  123.     
  124.         return Color.parseColor("#" + mBuilder.toString());    
  125.     }    
  126.     
  127.     //隨機文本樣式    
  128.     private void randomTextStyle(Paint paint) {    
  129.         int color = randomColor();    
  130.         paint.setColor(color);    
  131.         paint.setFakeBoldText(mRandom.nextBoolean());  //true爲粗體,false爲非粗體    
  132.         float skewX = mRandom.nextInt(11) / 10;    
  133.         skewX = mRandom.nextBoolean() ? skewX : -skewX;    
  134.         paint.setTextSkewX(skewX); //float類型參數,負數表示右斜,整數左斜    
  135. //        paint.setUnderlineText(true); //true爲下劃線,false爲非下劃線    
  136. //        paint.setStrikeThruText(true); //true爲刪除線,false爲非刪除線    
  137.     }    
  138.     
  139.     //隨機間距    
  140.     private void randomPadding() {    
  141.         mPaddingLeft += BASE_PADDING_LEFT + mRandom.nextInt(RANGE_PADDING_LEFT);    
  142.         mPaddingTop = BASE_PADDING_TOP + mRandom.nextInt(RANGE_PADDING_TOP);    
  143.     }    
  144. }    
其中,在Default Settings中可以設置驗證碼圖形的大小,驗證碼的長度,內邊距,隨機距離等可以根據需要進行調整。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章