Android畫板開發(fā)之基本畫筆功能
一、簡介
這是畫板系列的第一篇,一步步開始,從簡單的畫板,到功能稍微齊全一點的畫板,例如基本畫筆、橡皮擦、背景、文字、撤銷、反撤銷、保存等
這篇帶大家實現(xiàn)一個最簡單的畫板,前提是需要對自定義View有一定的了解。
用的是kotlin語言

二、實現(xiàn)
分析如何實現(xiàn): 定義了畫筆和Path,然后在觸摸屏幕的時候,手指一邊移動一邊進(jìn)行path的滑動,繪制。這就完成了一個最簡單的畫筆功能。
下面幾十行代碼完成這個
class TPView(context: Context,attr:AttributeSet ) : View(context,attr) {
private var preX: Float = 0.0f //上一次的觸摸點x坐標(biāo)
private var preY: Float = 0.0f //上一次觸摸點y坐標(biāo)
var mPath = Path() //path路徑
//畫筆
private var mPaint = Paint(Paint.ANTI_ALIAS_FLAG or Paint.DITHER_FLAG)
init {
//畫筆為實心
mPaint.style = Paint.Style.STROKE
//顏色
mPaint.color = Color.RED
//筆觸為圓形
mPaint.strokeCap = Paint.Cap.ROUND
//畫筆大小
mPaint.strokeWidth = 10f
//View的背景顏色
setBackgroundColor(Color.WHITE)
}
override fun onDraw(canvas: Canvas) {
super.onDraw(canvas)
//畫線
canvas.drawPath(mPath,mPaint)
}
override fun onTouchEvent(event: MotionEvent): Boolean {
when(event.action){
MotionEvent.ACTION_DOWN -> { //手指按下的時候
//將起始點移動到當(dāng)前坐標(biāo)
mPath.moveTo(event.x,event.y)
//記錄上次觸摸的坐標(biāo),注意ACTION_DOWN方法只會執(zhí)行一次
preX = event.x
preY = event.y
}
MotionEvent.ACTION_MOVE -> { //手指移動的時候
//繪制圓滑曲線,即貝塞爾曲線,貝塞爾曲線這個知識自行了解
mPath.quadTo(preX,preY,event.x,event.y)
preX = event.x
preY = event.y
}
}
//重新繪制,會調(diào)用onDraw方法
invalidate()
return true
}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SafeList?in?Flutter?and?Dart小技巧
這篇文章主要為大家介紹了SafeList?in?Flutter?and?Dart小技巧,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
Kotlin實現(xiàn)Android系統(tǒng)懸浮窗詳解
大家好,本篇文章主要講的是Kotlin實現(xiàn)Android系統(tǒng)懸浮窗詳解,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12
Android編程實現(xiàn)捕獲程序異常退出時的錯誤log信息功能詳解
這篇文章主要介紹了Android編程實現(xiàn)捕獲程序異常退出時的錯誤log信息功能,結(jié)合實例形式分析了Android異常信息捕獲與日志操作相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2017-08-08
Android音視頻開發(fā)之MediaCodec的使用教程
在Android開發(fā)中提供了實現(xiàn)音視頻編解碼工具M(jìn)ediaCodec,針對對應(yīng)音視頻解碼類型通過該類創(chuàng)建對應(yīng)解碼器就能實現(xiàn)對數(shù)據(jù)進(jìn)行解碼操作。本文通過示例詳細(xì)講解了MediaCodec的使用,需要的可以參考一下2022-04-04
Android Studio如何快速導(dǎo)入jar和.so文件
這篇文章主要介紹了Android Studio如何快速導(dǎo)入jar和.so文件的相關(guān)知識,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-12-12

