Android實現(xiàn)畫板功能(一)
本文實例為大家分享了Android實現(xiàn)畫板功能的具體代碼,供大家參考,具體內(nèi)容如下
前言
最近看到了一些Android手寫相關(guān)的功能,比如說:
釘釘手寫簽名功能,輸入法手寫功能,筆記類App的手寫記錄功能等。最近在工作中也遇到了類似的需求,其實實現(xiàn)畫板功能并不復(fù)雜,所以我就打算在這里簡單記錄一下。實現(xiàn)畫板功能比較常用的方法有兩種,一是自定義view的方式在canvas上畫軌跡,另一個是在imageview上畫bitmap。今天就講一下第一種方式吧。
效果圖

界面布局
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="55dp"
android:background="@color/colorPrimary">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="我的畫板"
android:layout_marginStart="10dp"
android:layout_centerVertical="true"
android:textColor="@android:color/white"
android:textSize="16sp"/>
<TextView
android:id="@+id/text_clear"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="清除"
android:layout_alignParentEnd="true"
android:layout_marginEnd="10dp"
android:layout_centerVertical="true"
android:textColor="@android:color/white"
android:textSize="16sp"/>
</RelativeLayout>
<com.example.drawline.LineView
android:id="@+id/lineView"
android:layout_marginTop="55dp"
android:layout_width="match_parent"
android:layout_height="match_parent">
</com.example.drawline.LineView>
</RelativeLayout>
代碼是用kotlin寫的,但是實現(xiàn)方法和java是一樣的。新建一個自定義view類,繼承自View。kotlin不需要寫View的三個重載方法。只需把三個參數(shù)傳給父類即可。
然后是初始化Paint,Path,設(shè)置畫筆顏色等。
關(guān)鍵代碼是在onTouchEvent里面,這里需要獲取到手指的位置。在移動手指時調(diào)用Path的lineTo(x,y)方法記錄一下軌跡,然后調(diào)用invalidate()方法實時更新畫面即可,invalidate()方法會調(diào)用onDraw方法,onDraw方法里面調(diào)用Canvas的drawPath方法就可以畫出手指劃過的軌跡了。
清除軌跡要調(diào)用reset()方法,調(diào)用invalidate()方法。
自定義view類
package com.example.drawline
import android.annotation.SuppressLint
import android.content.Context
import android.graphics.*
import android.util.AttributeSet
import android.view.MotionEvent
import android.view.View
class LineView @JvmOverloads constructor(
context: Context,
attrs: AttributeSet? = null,
defStyleAttr: Int = 0
) : View(context, attrs, defStyleAttr) {
private val defaultPath: Path
private val defaultPaint: Paint
init {
defaultPath = Path()
defaultPaint = Paint(Paint.ANTI_ALIAS_FLAG or Paint.DITHER_FLAG)
defaultPaint.style = Paint.Style.STROKE
defaultPaint.strokeWidth = 5f
defaultPaint.color = Color.RED
}
override fun onDraw(canvas: Canvas) {
super.onDraw(canvas)
canvas.drawPath(defaultPath, defaultPaint)
}
@SuppressLint("ClickableViewAccessibility")
override fun onTouchEvent(event: MotionEvent): Boolean {
val x = event.x
val y = event.y
when (event.action) {
MotionEvent.ACTION_DOWN -> defaultPath.moveTo(x, y)
MotionEvent.ACTION_MOVE -> defaultPath.lineTo(x, y)
MotionEvent.ACTION_UP -> defaultPath.lineTo(x, y)
}
invalidate()
return true
}
fun clear(){
defaultPath.reset()
invalidate()
}
}
MainActivity
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
text_clear.setOnClickListener { lineView.clear() }
}
}
本篇文章中介紹了自定義view的一些基礎(chǔ)知識,適合剛學(xué)習(xí)自定義view的同學(xué)們。后面幾篇文章中將會繼續(xù)深入講解Android自定義view相關(guān)知識。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android Studio一直處于Building的兩種解決方法
很多朋友都遇到過打開別人的項目一直處于Building‘XXX’Gradle project info的情況。下面小編給大家?guī)砹薃ndroid Studio一直處于Building的解決方法,感興趣的朋友一起看看吧2018-08-08
分析CmProcess跨進(jìn)程通信的實現(xiàn)
CmProcess是Android一個跨進(jìn)程通信框架,無需進(jìn)行bindService()操作,不用定義Service,也不需要定義aidl。 支持IPC級的 Callback,并且支持跨進(jìn)程的事件總線,可同步獲取服務(wù),采用面向接口方式進(jìn)行服務(wù)注冊與調(diào)用,服務(wù)調(diào)用方和使用者完全解耦2021-06-06
Android基于自帶的DownloadManager實現(xiàn)下載功能示例
這篇文章主要介紹了Android基于自帶的DownloadManager實現(xiàn)下載功能,結(jié)合實例形式分析了DownloadManager實現(xiàn)下載功能的具體操作步驟與相關(guān)注意事項,需要的朋友可以參考下2017-08-08
Android那兩個你碰不到但是很重要的類之ViewRootImpl
這兩個類就是ActivityThread和ViewRootImpl,之所以說碰不到是因為我們無法通過正常的方式引用這兩個類或者其類的對象,本文就嘗試從幾個我們經(jīng)常接觸的方面先談?wù)刅iewRootImpl,感興趣的可以參考閱讀下2023-05-05
BroadcastReceiver靜態(tài)注冊案例詳解
這篇文章主要為大家詳細(xì)介紹了BroadcastReceiver靜態(tài)注冊案例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-08-08
Android中捕獲TTextView文本中的鏈接點擊事件方法
這篇文章主要介紹了Android中捕獲TTextView文本中的鏈接點擊事件方法,本文給出了實現(xiàn)代碼和使用方法以及實現(xiàn)自己控制的方法,需要的朋友可以參考下2015-01-01
Android自定義View實現(xiàn)QQ運(yùn)動積分轉(zhuǎn)盤抽獎功能
這篇文章主要為大家詳細(xì)介紹了Android自定義View實現(xiàn)QQ運(yùn)動積分轉(zhuǎn)盤抽獎功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10

