Android绘制验证码的实例代码

在前面仿华为加载动画、仿网易音乐听歌识曲-麦克风动画中,我们通过绘图的基础知识完成了简单的绘制。在本例中,我们将绘制常见的验证码。

一、效果图

二、知识点与思路分析

通过上面的效果图观察,我们可以看到里面有绘制的随机线条,随机绘制的验证码。

绘制线条,直线或曲线

绘制文本,生成的验证码文本的绘制

绘制圆点。

三、代码编写

/** * Created by Iflytek_dsw on 2017/7/3. */ public class IdentifyCodeUtil { private static final int CODE_NUMBER = 4; private static final int LINE_NUMBER = 5; private static final int POINT_NUMBER = 10; private StringBuffer stringBuffer = null; private Random random = new Random(); //随机数数组 private static final char[] CHARS = { '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'j', 'k', 'm', 'n', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z' }; private static IdentifyCodeUtil instance; public static IdentifyCodeUtil getInstance(){ if(instance == null){ instance = new IdentifyCodeUtil(); } return instance; } public Bitmap createBitmapCode(int width, int height){ Bitmap bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888); Canvas canvas = new Canvas(bitmap); canvas.drawColor(Color.LTGRAY); drawCodeText(canvas, width, height); drawLines(canvas, width, height); drawPoint(canvas, width, height); return bitmap; } /** * 返回验证码 * @return 验证码生成的字符串 */ public String getIdentifyCode(){ if(stringBuffer == null){ return ""; } return stringBuffer.toString(); } /** * 生成验证码 * @return */ private String buildIdentifyCode(){ StringBuffer stringBuffer = new StringBuffer(); for(int i=0; i < CODE_NUMBER;i++){ stringBuffer.append(CHARS[random.nextInt(CHARS.length)]); } Log.d("Code",stringBuffer.toString()); return stringBuffer.toString(); } /** * 绘制文本 * @param canvas 画布 * @param width 宽度 * @param height 高度 */ private void drawCodeText(Canvas canvas,int width, int height){ Paint paint = new Paint(); paint.setTextSize(50); /**构建验证码code*/ String text = buildIdentifyCode(); float textLength = paint.measureText(text); int startMaxLength = (int) ((width - textLength) / 2); /**随机计算验证码绘制每次开头的位置*/ int startPosition = random.nextInt(startMaxLength); //绘制文字 for(int index = 0; index < text.length(); index++){ /**生成旋转的角度*/ int offsetDegree = random.nextInt(15); /**这里只会产生0和1,如果是1那么正旋转正角度,否则旋转负角度*/ offsetDegree = random.nextInt(2) == 1 ? offsetDegree : -offsetDegree; canvas.save(); //设置旋转 canvas.rotate(offsetDegree, width / 2, height / 2); /**生成随机的颜色*/ paint.setARGB(255, random.nextInt(200) + 20, random.nextInt(200) + 20, random.nextInt(200) + 20); char tempChar = text.charAt(index); //给画笔设置随机颜色 canvas.drawText(String.valueOf(tempChar), startPosition +index * textLength / text.length() +15, height * 3 / 5f,paint); canvas.restore(); } } /** * 生成干扰线 * @param canvas * @param width * @param height */ private void drawLines(Canvas canvas,int width, int height){ Paint paint = new Paint(); paint.setStrokeWidth(3); for(int i = 0;i < LINE_NUMBER;i++){ paint.setARGB(255, random.nextInt(200) + 30, random.nextInt(200) + 30, random.nextInt(200) + 30); int startX = random.nextInt(width); int startY = random.nextInt(height); int endX = random.nextInt(width); int endY = random.nextInt(height); canvas.drawLine(startX, startY, endX, endY, paint); } } /** * 生成干扰点 */ private void drawPoint(Canvas canvas, int width, int height) { Paint paint = new Paint(); paint.setStrokeWidth(3); paint.setColor(Color.GRAY); for(int i=0; i< POINT_NUMBER; i++){ PointF pointF = new PointF(random.nextInt(width) + 10, random.nextInt(height) + 10); canvas.drawPoint(pointF.x, pointF.y, paint); } } }

以上所述是小编给大家介绍的Android绘制验证码的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

时间: 2024-10-27 14:10:38

Android绘制验证码的实例代码的相关文章

Android 画一个太极图实例代码_Android

今天练手一下,一起来画个太极图吧~ 最终效果如下: 最终效果 一般都是先讲原理,我就反其道而行,先讲实现吧. 1.继承实现初始化方法 继承View,实现基本的构造函数: public TestView(Context context) { this(context, null); } public TestView(Context context, AttributeSet attrs) { this(context, attrs, 0); } public TestView(Context c

Android字段验证的实例代码_Android

先给大家展示效果图: package com.example.walkerlogin1; import android.app.Activity; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.EditText; import android.widge

Android 画一个太极图实例代码

今天练手一下,一起来画个太极图吧~ 最终效果如下: 最终效果 一般都是先讲原理,我就反其道而行,先讲实现吧. 1.继承实现初始化方法 继承View,实现基本的构造函数: public TestView(Context context) { this(context, null); } public TestView(Context context, AttributeSet attrs) { this(context, attrs, 0); } public TestView(Context c

Webview实现android简单的浏览器实例代码_Android

WebView是Android中一个非常实用的组件,它和Safai.Chrome一样都是基于Webkit网页渲染引擎,可以通过加载HTML数据的方式便捷地展现软件的界面,下面通过本文给大家介绍Webview实现android简单的浏览器实例代码. 实现了浏览器的返回 前进 主页 退出 输入网址的功能 注释的很清楚啦 就不多说了 首先是布局文件 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android&qu

Android字段验证的实例代码

先给大家展示效果图: package com.example.walkerlogin1; import android.app.Activity; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.EditText; import android.widge

Android 动态菜单实现实例代码

Android 动态菜单 先上效果图 比较简单,主要就是属性动画的使用和坐标角度的小细节. 实现 实现效果: 图标按照路径一路缩放渐变过来即可. 核心代码 /** * Item开启动画 * * @param btnItem * @param index * @param total * @param radius */ private void btnItemStartAnimator(View btnItem, int index, int total, int radius) { if (b

Android实现常见的验证码输入框实例代码

前言 验证码输入框是很多APP必不可少的组件,之前在重构注册登录页面的时候,重新设计了UI,所以不能再简单的用EditText来做了,所以这篇文章将分享一下如何实现一个常见的验证码输入框.下面话不多说了,来一起看看详细的介绍吧. 正文 先搂一眼效果吧 不要把注意力都放在头顶的那一抹绿上,重点在输入框,可能大多数APP里都是采用6个方框的UI效果,我这里是按照我们设计的要求,用6根横线来划出6个数字的位置.一开始我想的是直接用6个TextView,然后传递焦点的做法,但是发现实现起来有一定的难度.

Android实现抽奖转盘实例代码_Android

本文详述了android抽奖程序的实现方法,程序为一个抽奖大转盘代码,里面定义了很多图形方法和动画. 实现主要功能的SlyderView.java源代码如下: import android.app.Activity; import android.content.Context; import android.graphics.BlurMaskFilter; import android.graphics.Canvas; import android.graphics.Color; import

Android触屏测试实例代码_Android

本文实例详细描述了Android触屏测试代码,可实现对触屏的点击.移动.离开等事件的处理,对于Android初学者有很好的借鉴价值. 具体功能代码如下: package com.test; import android.app.Activity; import android.os.Bundle; import android.util.DisplayMetrics; import android.util.Log; import android.view.MotionEvent; import