android简单登录自定义密码,android 自定义密码框

1.自定义view

import android.content.Context

import android.graphics.Canvas

import android.graphics.Color

import android.graphics.Paint

import android.graphics.Rect

import android.util.AttributeSet

import android.view.View

import java.lang.StringBuilder

/**

* @author wellJan

* 自定义密码框

*/

class TestView : View {

constructor(context: Context?) :super(context,null,0)

constructor(context: Context?, attrs: AttributeSet?) :super(context, attrs,0)

constructor(context: Context?, attrs: AttributeSet?, defStyleAttr: Int) :super(

context,

attrs,

defStyleAttr

)

private var paint = Paint()

private var pointPaint = Paint()

//单个密码框的宽度

private var itemW =0

//item的间隔

private var itemPadding =20;

private var size =6

init {

paint.color = (Color.BLACK)

paint.isAntiAlias =true

paint.style = Paint.Style.STROKE

setBackgroundColor(Color.WHITE)

pointPaint.color = (Color.BLACK)

pointPaint.isAntiAlias =true

pointPaint.style = Paint.Style.FILL

}

override fun onDraw(canvas: Canvas?) {

super.onDraw(canvas)

//先绘制size个密码框框

itemW = (measuredWidth-paddingLeft-paddingRight-(size-1)*itemPadding)/size;

canvas!!.translate(paddingLeft.toFloat(),0f)

canvas.save()

var rect = Rect(0,0,itemW,measuredHeight)

for (iin 0 until size){

canvas!!.drawRect(rect,paint)

if (i

//画实心圆

canvas.drawCircle(itemW/2.toFloat(),measuredHeight/2.toFloat(),itemW/size.toFloat(),pointPaint)

}

canvas.translate(itemPadding.toFloat()+itemW,0f)

}

canvas!!.restore()

}

var stringBuilder = StringBuilder()

public fun addNumber(number:String){

if (stringBuilder.length ==size)

return

stringBuilder.append(number)

invalidate()

}

public fun delNumber(){

if (stringBuilder.isEmpty())

return

stringBuilder.deleteAt(stringBuilder.length-1)

invalidate()

}

public fun getNumber():String{

return stringBuilder.toString()

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值