@cxm-2016
2016-09-20T12:39:03.000000Z
字数 1288
阅读 2824
android
no
这里我们实现一个自定义的画板,并逐渐完善其功能。当用户在频幕上画线时,实际上依然是利用Canvas的drawLine方法绘制直线,每条直线都是上一次的点到这一次的点之间的连线。
这里我们创建一个PainterView,View的代码如下
class PainterView : View {
constructor(context: Context?) : super(context)
constructor(context: Context?, attrs: AttributeSet?) : super(context, attrs)
constructor(context: Context?, attrs: AttributeSet?, defStyleAttr: Int) : super(context, attrs, defStyleAttr)
private var preX = 0F
private var preY = 0F
private var path = Path()
private var paint = Paint(Paint.DITHER_FLAG)
private var cacheBitmap:Bitmap? = null
private var cacheCanvas = Canvas()
init {
paint.color = Color.BLUE
paint.style = Paint.Style.STROKE
paint.strokeWidth = 2F
paint.isAntiAlias = true
paint.isDither = true
post {
cacheBitmap = Bitmap.createBitmap(width,height,Bitmap.Config.ARGB_8888)
cacheCavas.setBitmap(cacheBitmap)
}
}
override fun onTouchEvent(event: MotionEvent): Boolean {
val x = event.x
val y = event.y
when (event.action) {
MotionEvent.ACTION_DOWN -> {
path.moveTo(x, y)
preX = x
preY = y
}
MotionEvent.ACTION_MOVE -> {
path.quadTo(preX, preY, x, y)
cacheCanvas.drawPath(path,paint)
preX = x
preY = y
}
MotionEvent.ACTION_UP -> {
path.reset()
}
}
invalidate()
return true
}
override fun onDraw(canvas: Canvas) {
canvas.drawBitmap(cacheBitmap,0F,0F,paint)
}
}
通过这个程序我们可以看出,每次手指在屏幕上滑动时都会记录下手指位置,然后通过invalidate()通知View进行重绘。这个View是有缺陷的,我们将View添加到布局中运行。当我们的手指滑动速度过快时,会产生如下的折点
这种问题产生的原因就是