Android UI设计之<五>自定义DrawView组件,实现数字签名效果

本文介绍了如何在Android应用中实现数字签名功能,通过自定义DrawView组件,利用View的绘图原理捕捉手指移动轨迹,并将轨迹转化为图片。详细讲述了DrawView的执行逻辑,包括onDraw()和onTouchEvent()方法的使用。此外,还分享了一个关于在布局文件中使用<tt>标签为汉字加粗的小技巧。最后展示了运行效果和源码下载链接。
摘要由CSDN通过智能技术生成

最近项目中有个新的需求,用户在完交易需要进行输入支付密码付款的时候,要让用户签下自己的签名,提起到数字签名这个东西,感觉有点高大上,后来想想数字签名的原理也不是太复杂,主要实现原理就是利用了View的绘图原理,把用户在屏幕上的手指移动轨迹显示在屏幕上,接着把在屏幕上显示的轨迹View转换成一张图片,最后把图片保存到本地或者上传到服务器...

还是老规矩,首先看一下工程目录吧:


public class DrawView extends View {

	/**
	 * 签名画笔
	 */
	private Paint paint;
	/**
	 * 签名画布
	 */
	private Canvas cacheCanvas;
	/**
	 * 画笔路径
	 */
	private Path path;
	/**
	 * 缓存图片
	 */
	private Bitmap cacheBitmap;
	/**
	 * 图片宽度
	 */
	private int width;
	/**
	 * 图片高度
	 */
	private int height;
	/**
	 * 手指触摸屏幕时的X,Y坐标
	 */
	private float xDown, yDown;
	/**
	 * 是否正在绘制
	 */
	private boolean isDrawing = false;

	/**
	 * 默认画笔颜色
	 */
	private int paintColor = Color.CYAN;

	/**
	 * 默认画板背景色
	 */
	private int canvasColor = Color.parseColor("#bbccaa");

	public DrawView(Context context, int width, int height) {
		super(context);
		this.width = width;
		this.height = height;
		initWedgits();
	}

	/**
	 * 初始化组件
	 */
	private void initWedgits() {
		try {
			paint = new Paint(Paint.DITHER_FLAG);
			// 设置抗锯齿
			paint.setAntiAlias(true);
			// 设置画笔宽度
			paint.setStrokeWidth(3);
			paint.setDither(true);
			// 设置样式
			paint.setStyle(Paint.Style.STROKE);
			paint.setStrokeJoin(Paint.Join.ROUND);
			paint.setStrokeCap(Paint.Cap.ROUND);
			// 画笔颜色
			paint.setColor(paintColor);
			// 绘制路径
			path = new Path();
			// 创建空缓存图片
			cacheBitmap =
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值