android 验证码 (canvas)

activity:
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    LinearLayout linearLayout = new LinearLayout(this);
    VerifyCodeView vc = new VerifyCodeView(this,6);
    TextView textView = new TextView(this);
    textView.setText("验证码:");
    EditText mInCode = new EditText(this);
    vc.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            v.postInvalidate();//重新调用VerifyCodeView的构造方法,更新验证码
            Toast.makeText(getApplicationContext(),"updat code",Toast.LENGTH_LONG).show();
        }
    });
    linearLayout.addView(textView);
    linearLayout.addView(mInCode);
    linearLayout.addView(vc);
    setContentView(linearLayout);
}

view:

private Character[] codes = {‘q‘,‘w‘,‘e‘,‘r‘,‘t‘,‘y‘,‘u‘,‘i‘
                                ,‘o‘,‘p‘,‘a‘,‘s‘,‘d‘,‘f‘,‘g‘,‘h‘
                                ,‘j‘,‘k‘,‘l‘,‘z‘,‘x‘,‘c‘,‘v‘,‘b‘
                                ,‘n‘,‘m‘,‘1‘,‘2‘,‘3‘,‘4‘,‘5‘,‘6‘
                                ,‘7‘,‘8‘,‘9‘,‘0‘};
private Character[] vcode;

public VerifyCodeView(Context context) {
    super(context);
    vcode = new Character[4];//定义验证码的长度
}

public VerifyCodeView(Context context, int codeSize) {
    super(context);
    vcode = new Character[codeSize];//定义验证码的长度
}

@Override
protected void onDraw(Canvas canvas) {
    super.onDraw(canvas);
    vcode = getCodes(codes);
    Paint pen = new Paint();
    pen.setColor(Color.WHITE);
    int mwidth = getWidth();
    canvas.drawRect(mwidth*2/3,10.0f,mwidth-20,100.0f,pen);
    Random r = new Random(100);
    int padding = 1;
    for (int i = 0; i < vcode.length; i++) {
        pen.setColor(Color.rgb(r.nextInt(),r.nextInt(),r.nextInt()));
        pen.setTextSize(60);
        //canvas.drawText(new char[]{‘a‘,‘c‘,‘b‘,‘d‘,‘1‘,‘2‘,‘e‘},0,7,mwidth*2/3+10,70.0f,pen);
        //String text = "h"+r.nextInt()+"e"+r.nextInt()+"l";
        canvas.drawText(vcode[i].toString(),mwidth*2/3+padding,70.0f,pen);
        padding = padding + 35;
    }
}

public Character[] getCodes(Character[] codes){
    Random rd = new Random();
    for (int i = 0; i < vcode.length; i++) {
        vcode[i] = codes[rd.nextInt(36)];
    }
    return vcode;
}
时间: 2024-12-28 23:12:34

android 验证码 (canvas)的相关文章

Android利用canvas画各种图形

canvas通俗的说就是一张画布,我们可以使用画笔paint,在其上面画任意的图形. 原理: 可以把canvas视为Surface的替身或者接口,图形便是绘制在Surface上的.Canvas封装了所有的绘制调用.通过Canvas, 绘制到Surface上的内容首先存储到一个内存区域(也就是对应的Bitmapz中),该Bitmap最终会呈现到窗口上. 使用: 1.Canvas可以直接new Canvas(): 2.在View中重写OnDraw()方法,里面有一个Canvas,今天讨论的内容. 方

Android中Canvas绘图之Shader使用图文详解

概述 我们在用Android中的Canvas绘制各种图形时,可以通过Paint.setShader(shader)方法为画笔Paint设置shader,这样就可以绘制出多彩的图形.那么Shader是什么呢?做过GPU绘图的同学应该都知道这个词汇,Shader就是着色器的意思.我们可以这样理解,Canvas中的各种drawXXX方法定义了图形的形状,画笔中的Shader则定义了图形的着色.外观,二者结合到一起就决定了最终Canvas绘制的被色彩填充的图形的样子. 类android.graphics

Android中Canvas绘图之PorterDuffXfermode使用及工作原理详解

概述 类android.graphics.PorterDuffXfermode继承自android.graphics.Xfermode.在用Android中的Canvas进行绘图时,可以通过使用PorterDuffXfermode将所绘制的图形的像素与Canvas中对应位置的像素按照一定规则进行混合,形成新的像素值,从而更新Canvas中最终的像素颜色值,这样会创建很多有趣的效果.当使用PorterDuffXfermode时,需要将将其作为参数传给Paint.setXfermode(Xfermo

Android中Canvas绘图基础详解(附源码下载)

Android中,如果我们想绘制复杂的自定义View或游戏,我们就需要熟悉绘图API.Android通过Canvas类暴露了很多drawXXX方法,我们可以通过这些方法绘制各种各样的图形.Canvas绘图有三个基本要素:Canvas.绘图坐标系以及Paint.Canvas是画布,我们通过Canvas的各种drawXXX方法将图形绘制到Canvas上面,在drawXXX方法中我们需要传入要绘制的图形的坐标形状,还要传入一个画笔Paint.drawXXX方法以及传入其中的坐标决定了要绘制的图形的形状

Android利用canvas画画板

首先新建一个项目工程,建立文件,如下图所示 首先配置页面布局文件activity_main.xml,如下图所示: 1 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 2 xmlns:tools="http://schemas.android.com/tools" 3 android:layout_width="match_parent" 4 a

Android之canvas详解

首先说一下canvas类: Class Overview The Canvas class holds the "draw" calls. To draw something, you need 4 basic components: A Bitmap to hold the pixels, a Canvas to host the draw calls (writing into the bitmap), a drawing primitive (e.g. Rect, Path, t

Android自定义控件 -Canvas绘制折线图(实现动态报表效果)

有时候我们在项目中会遇到使用折线图等图形,Android的开源项目中为我们提供了很多插件,但是很多时候我们需要根据具体项目自定义这些图表,这一篇文章我们一起来看看如何在Android中使用Canvas绘制折线图.先看看绘制的效果: 代码: public class MyView extends View { //坐标轴原点的位置 private int xPoint=60; private int yPoint=260; //刻度长度 private int xScale=8;  //8个单位构

android 高级Canvas绘图

Canvas是图形编程中很实用的一个概念.通常有3个基本部分组成: 1.Canvas 提供了绘图方法,可以向底层的位图绘制基本图形.(我觉得这个解释很好,比解释成画布要好的多) 2.Paint 称为画笔或者刷子,Paint可以指定如何将基本图形绘制到位图上. 3.Bitmap 绘图的表面. Android绘图API支持透明度,渐变填充,圆角矩形和抗锯齿. 1.可以绘制的内容 Canvase类封装了用作绘图表面的位图,它还提供了draw*方法来实现设计. 2.最大限度的利用Paint Pain相当

Android中Canvas绘图基础详解

原文:http://blog.csdn.net/iispring/article/details/49770651 Android中,如果我们想绘制复杂的自定义View或游戏,我们就需要熟悉绘图API.Android通过Canvas类暴露了很多drawXXX方法,我们可以通过这些方法绘制各种各样的图形.Canvas绘图有三个基本要素:Canvas.绘图坐标系以及Paint.Canvas是画布,我们通过Canvas的各种drawXXX方法将图形绘制到Canvas上面,在drawXXX方法中我们需要