• (五十一)生成图片验证码的代码如下所示


    1、程序的结构如下所示:

    2、LoginImageViewCode.java的代码如下所示

    package com.app.code;
    import java.util.Random;
    import android.content.Context;
    import android.graphics.Bitmap;
    import android.graphics.Bitmap.Config;
    import android.graphics.Canvas;
    import android.graphics.Color;
    import android.graphics.Paint;
    
    public class LoginImageViewCode {
    
        private static Context context;
    
        private static final char[] CHARS = { '0', '1', '2', '3', '4', '5', '6',
                '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j',
                'k', 'l', 'm', 'n', 'o', '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', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W',
                'X', 'Y', 'Z' };
    
        private static LoginImageViewCode bpUtil;
    
        private LoginImageViewCode(Context context) {
            this.context = context;
        };
    
        public static LoginImageViewCode getInstance(Context context) {
            if (bpUtil == null)
                bpUtil = new LoginImageViewCode(context);
            return bpUtil;
        }
    
        // default settings
        private static final int DEFAULT_CODE_LENGTH = 4;// 验证码的长度 这里是4位
        private static final int DEFAULT_FONT_SIZE = 60;// 字体大小
        private static final int DEFAULT_LINE_NUMBER = 4;// 多少条干扰线
        private static final int BASE_PADDING_LEFT = 20; // 左边距
        private static final int RANGE_PADDING_LEFT = 15;// 左边距范围值
        private static final int BASE_PADDING_TOP = 42;// 上边距
        private static final int RANGE_PADDING_TOP = 28;// 上边距范围值
        private static final int DEFAULT_WIDTH = 210;// 默认宽度.图片的总宽
        private static final int DEFAULT_HEIGHT = 92;// 默认高度.图片的总高
    
        private static final int DEFAULT_POINT_NUMBER = 20;
        private final int DEFAULT_COLOR = 0xff;// 默认背景颜色值
    
        // settings decided by the layout xml
        // canvas width and height
    
        private int width = DEFAULT_WIDTH;
        private int height = DEFAULT_HEIGHT;
    
        // random word space and pading_top
        private int base_padding_left = BASE_PADDING_LEFT;
        private int range_padding_left = RANGE_PADDING_LEFT;
        private int base_padding_top = BASE_PADDING_TOP;
        private int range_padding_top = RANGE_PADDING_TOP;
    
        // number of chars, lines; font size
        private int codeLength = DEFAULT_CODE_LENGTH;
        private int line_number = DEFAULT_LINE_NUMBER;
        private int point_number = DEFAULT_POINT_NUMBER;
        private int font_size = DEFAULT_FONT_SIZE;
    
        // variables
        private String code;// 保存生成的验证码
        private int padding_left, padding_top;
        private Random random = new Random();
    
        private Bitmap createBitmap() {
            padding_left = 0;
            // 产生一个相同大小的画布
            Bitmap bp = Bitmap.createBitmap(width, height, Config.ARGB_8888);
            Canvas c = new Canvas(bp);
    
            code = createCode();
    
            Paint paint = new Paint();
    
            for (int i = 0; i < code.length(); i++) {
                paint.setTextSize(font_size);
                randomTextStyle(paint);
                randomPadding();
                c.drawText(code.charAt(i) + "", padding_left, padding_top, paint);// 以(padding_left,padding_top)为原点,使用画笔绘制文本code.charAt(i)
                                                                                    // //
                                                                                    // +
                                                                                    // ""
            }
            int redColor = context.getResources().getColor(
                    R.color.login_promt_text_red); // 设置线条的颜色为红色
            for (int i = 0; i < line_number; i++) {
                drawLine(c, paint, redColor);
            }
    
            for (int i = 0; i < point_number; i++) {
                drawPoint(c, paint);
            }
    
            c.save(Canvas.ALL_SAVE_FLAG);// 保存
            c.restore();//
            return bp;
        }
    
        public String getCode() {
            return code.toLowerCase();
        }
    
        public Bitmap getBitmap() {
            return createBitmap();
        }
    
        private String createCode() {
            StringBuilder buffer = new StringBuilder();
            for (int i = 0; i < codeLength; i++) {
                buffer.append(CHARS[random.nextInt(CHARS.length)]);
            }
            return buffer.toString();
        }
    
        private void drawPoint(Canvas canvas, Paint paint) {
    
            int color = context.getResources().getColor(R.color.login_text_gray); // 设置字体的颜色为红色
            int x = random.nextInt(width);
            int y = random.nextInt(height);
            paint.setStrokeWidth(3);
            paint.setColor(color);
            canvas.drawPoint(x, y, paint);
        }
    
        private void drawLine(Canvas canvas, Paint paint, int color) {
            // int color = randomColor();
    
            int startX = random.nextInt(width);
            int startY = random.nextInt(height);
            int stopX = random.nextInt(width);
            int stopY = random.nextInt(height);
    //        int startX = (Math.abs(random.nextInt(width)))%(width+1)+width;
    //        int startY = (Math.abs(random.nextInt(height)))%(height+1)+height;
    //        int startX = 0;
    //        int startY = random.nextInt(height);
    //        int stopX = (Math.abs(random.nextInt(width)))%(width+1)+width;
    //        int stopY = (Math.abs(random.nextInt(height)))%(height+1)+height;
            paint.setStrokeWidth(3);
            paint.setColor(color);
            canvas.drawLine(startX, startY, stopX, stopY, paint);
        }
    
        private int randomColor() {
            return randomColor(1);
        }
    
        private int randomColor(int rate) {
            int red = random.nextInt(256) / rate;
            int green = random.nextInt(256) / rate;
            int blue = random.nextInt(256) / rate;
            return Color.rgb(red, green, blue);
        }
    
        private void randomTextStyle(Paint paint) {
            // int color = randomColor();
            int color = context.getResources().getColor(
                    R.color.login_promt_text_red); // 设置字体的颜色为红色
            paint.setColor(color);
            paint.setFakeBoldText(random.nextBoolean()); // true为粗体,false为非粗体
            float skewX = random.nextInt(11) / 10;
            skewX = random.nextBoolean() ? skewX : -skewX;
            paint.setTextSkewX(skewX); // float类型参数,负数表示右斜,整数左斜
            // paint.setUnderlineText(true); //true为下划线,false为非下划线
            // paint.setStrikeThruText(true); //true为删除线,false为非删除线
        }
    
        private void randomPadding() {
            padding_left += base_padding_left + random.nextInt(range_padding_left);
            padding_top = base_padding_top + random.nextInt(range_padding_top);
        }
    }

    2、MainActivity.java的代码如下所示

    package com.app.code;
    
    
    import android.os.Bundle;
    import android.app.Activity;
    import android.util.Log;
    import android.view.Menu;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;
    import android.widget.EditText;
    import android.widget.ImageView;
    import android.widget.Toast;
    
    public class MainActivity extends Activity {
        
        ImageView vc_image;
        Button vc_shuaixi,vc_ok;
        String getCode=null;
        EditText vc_code;
        
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            
            vc_image=(ImageView)findViewById(R.id.vc_image);
            vc_image.setImageBitmap(LoginImageViewCode.getInstance(MainActivity.this).getBitmap());
            vc_code=(EditText) findViewById(R.id.vc_code);
            
            getCode=LoginImageViewCode.getInstance(MainActivity.this).getCode(); //获取显示的验证码
            Log.e("info", getCode+"----");
            vc_shuaixi=(Button)findViewById(R.id.vc_shuaixi);
            vc_shuaixi.setOnClickListener(new OnClickListener() {
                
                @Override
                public void onClick(View v) {
                    // TODO Auto-generated method stub
                    vc_image.setImageBitmap(LoginImageViewCode.getInstance(MainActivity.this).getBitmap());
                    getCode=LoginImageViewCode.getInstance(MainActivity.this).getCode();
                }
            });
            
            vc_ok=(Button)findViewById(R.id.vc_ok);
            vc_ok.setOnClickListener(new OnClickListener() {
                
                @Override
                public void onClick(View v) {
                    // TODO Auto-generated method stub
                String    v_code=vc_code.getText().toString().trim();
                if(v_code==null||v_code.equals("")){
                    Toast.makeText(MainActivity.this, "没有填写验证码", 2).show();
                }else if(!v_code.equals(getCode)){
                    Toast.makeText(MainActivity.this, "验证码填写不正确", 2).show();
                }else{
                    Toast.makeText(MainActivity.this, "操作成功", 2).show();
                }
                
                }
            });
            
        }
    
        @Override
        public boolean onCreateOptionsMenu(Menu menu) {
            // Inflate the menu; this adds items to the action bar if it is present.
            getMenuInflater().inflate(R.menu.main, menu);
            return true;
        }
    
    }

    3、activity_main.xml的代码如下所示

    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context=".MainActivity" >
    
        <LinearLayout
            android:id="@+id/yh"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal" >
    
            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="用户名:" />
    
            <EditText
                android:layout_width="fill_parent"
                android:layout_height="wrap_content" />
        </LinearLayout>
    
        <LinearLayout
            android:id="@+id/pwd"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_below="@id/yh"
            android:orientation="horizontal" >
    
            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="密码:" />
    
            <EditText
                android:layout_width="fill_parent"
                android:layout_height="wrap_content" />
        </LinearLayout>
    
        <LinearLayout
            android:id="@+id/code"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_below="@id/pwd"
            android:layout_marginTop="4dp"
            android:gravity="center_vertical"
            android:orientation="horizontal" >
    
            <LinearLayout
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginBottom="10dp"
                android:layout_marginLeft="10dp"
                android:layout_marginRight="10dp"
                android:layout_marginTop="5dp"
                android:orientation="horizontal" >
    
                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_marginLeft="20dp"
                    android:layout_marginRight="5dp"
                    android:text="验 证 码:"
                    android:textColor="#000000" />
    
                <EditText
                    android:id="@+id/vc_code"
                    android:layout_width="60dp"
                    android:layout_height="wrap_content"
                    android:layout_weight="1"
                    android:background="#0000"
                    android:maxLength="4"
                    android:paddingBottom="10dp"
                    android:paddingLeft="10dp"
                    android:paddingTop="10dp"
                    android:textColor="#000000"
                    android:textSize="14sp" />
            </LinearLayout>
    
            <ImageView
                android:id="@+id/vc_image"
                android:layout_width="600dp"
                android:layout_height="600dp"
                android:layout_marginBottom="10dp"
                android:layout_marginTop="5dp"
                android:layout_weight="1" />
    
            <Button
                android:id="@+id/vc_shuaixi"
                android:layout_width="40dp"
                android:layout_height="wrap_content"
                android:layout_gravity="center_vertical"
                android:layout_marginBottom="10dp"
                android:layout_marginLeft="5dp"
                android:layout_marginRight="5dp"
                android:layout_marginTop="5dp"
                android:background="@android:color/transparent"
                android:text="刷新验证码"
                android:textColor="#7f7f7f"
                android:textSize="12sp"
                android:textStyle="italic" />
        </LinearLayout>
    
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_below="@id/code"
            android:orientation="horizontal" >
    
            <Button
                android:id="@+id/vc_ok"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="确定" />
        </LinearLayout>
    
    </RelativeLayout>

    4、color.xml的代码如下所示

    <?xml version="1.0" encoding="utf-8"?>
    <resources>
    
        <color name="login_promt_text_red">#eb271c</color>
        <color name="login_text_gray">#a8a8a8</color>
    
    </resources>
  • 相关阅读:
    VM环境安装Linux系统
    设置ShowDialog
    sqlserver同步表的脚本
    C#winform设置DateTimePicker的时间格式
    C#winform解析marc显示在datagridview中以及marc卡片显示
    C#实现图书馆程序导入ISO-2709格式(MARC)功能
    时间格式转换+固定字段加空格
    sqlserver 保留小数方法
    winform的datagridview单元格输入限制和右键单击datagridview单元格焦点跟着改变
    怎么查看那个端口被占用
  • 原文地址:https://www.cnblogs.com/fuyanan/p/4422410.html
Copyright © 2020-2023  润新知