日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

android+canvas+图片,android 开发 View _12_ 用Canvas 绘制一张图片(博客中演示用Canvas画验证码图片)...

發布時間:2025/3/20 93 豆豆
生活随笔 收集整理的這篇文章主要介紹了 android+canvas+图片,android 开发 View _12_ 用Canvas 绘制一张图片(博客中演示用Canvas画验证码图片)... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

packagenet.yt.yuncare.widgets;importandroid.graphics.Bitmap;importandroid.graphics.Canvas;importandroid.graphics.Color;importandroid.graphics.Paint;import java.lang.*;importjava.util.Random;/*** Created by lenovo on 2018/5/14.*/

public classCode {//隨機數數組

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 staticCode bmpCode;public static Code getInstance() { //單例模式

if(bmpCode == null)

bmpCode= newCode();returnbmpCode;

}//default settings//驗證碼默認隨機數的個數

private static final int DEFAULT_CODE_LENGTH = 4;//默認字體大小

private static final int DEFAULT_FONT_SIZE = 35;//默認線條的條數

private static final int DEFAULT_LINE_NUMBER = 2;//padding值

private static final int BASE_PADDING_LEFT = 10, RANGE_PADDING_LEFT = 15, BASE_PADDING_TOP = 15, RANGE_PADDING_TOP = 20;//驗證碼的默認寬高

private static final int DEFAULT_WIDTH = 100, DEFAULT_HEIGHT = 40;//settings decided by the layout xml//canvas width and height

private int width = DEFAULT_WIDTH, height =DEFAULT_HEIGHT;//random word space and pading_top

private int base_padding_left = BASE_PADDING_LEFT, range_padding_left =RANGE_PADDING_LEFT,

base_padding_top= BASE_PADDING_TOP, range_padding_top =RANGE_PADDING_TOP;//number of chars, lines; font size

private int codeLength = DEFAULT_CODE_LENGTH, line_number = DEFAULT_LINE_NUMBER, font_size =DEFAULT_FONT_SIZE;//variables

privateString code;private intpadding_left, padding_top;private Random random = newRandom();//生成驗證碼圖片 在外部Image調用,用setImageBitmap添加圖片到ImageView控件中

publicBitmap createBitmap() {

padding_left= 0;//重點:創建Bt圖片

Bitmap bp = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888); // Canvas c = new Canvas(bp);//創建畫板導入bt圖片

code=createCode();

c.drawColor(Color.WHITE);//添加畫板背景色為白色

Paint paint = new Paint();//創建畫筆

paint.setAntiAlias(true);

paint.setTextSize(font_size);//設置畫筆大小//畫驗證碼

for (int i = 0; i < code.length(); i++) {

randomTextStyle(paint);//畫筆傳入生成隨機樣式

randomPadding();

c.drawText(code.charAt(i)+ "", padding_left, padding_top, paint);

}//畫線條

for (int i = 0; i < line_number; i++) {

drawLine(c, paint);

}

c.save( Canvas.ALL_SAVE_FLAG );//保存

c.restore();// returnbp;

}publicString getCode() {returncode;

}//生成驗證碼

privateString createCode() {

StringBuilder buffer= newStringBuilder();for (int i = 0; i < codeLength; i++) {

buffer.append(CHARS[random.nextInt(CHARS.length)]);

}returnbuffer.toString();

}//畫干擾線

private voiddrawLine(Canvas canvas, Paint paint) {int color =randomColor();int startX =random.nextInt(width);int startY =random.nextInt(height);int stopX =random.nextInt(width);int stopY =random.nextInt(height);

paint.setStrokeWidth(1);

paint.setColor(color);

canvas.drawLine(startX, startY, stopX, stopY, paint);

}//生成隨機顏色

private intrandomColor() {return randomColor(1);

}private int randomColor(intrate) {int red = random.nextInt(256) /rate;int green = random.nextInt(256) /rate;int blue = random.nextInt(256) /rate;returnColor.rgb(red, green, blue);

}//隨機生成文字樣式,顏色,粗細,傾斜度

private voidrandomTextStyle(Paint paint) {int color =randomColor();

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為非刪除線

}//隨機生成padding值

private voidrandomPadding() {

padding_left+= base_padding_left +random.nextInt(range_padding_left);

padding_top= base_padding_top +random.nextInt(range_padding_top);

}

}

總結

以上是生活随笔為你收集整理的android+canvas+图片,android 开发 View _12_ 用Canvas 绘制一张图片(博客中演示用Canvas画验证码图片)...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。