SingleClick:
@Retention(AnnotationRetention.RUNTIME)
@Target(AnnotationTarget.FUNCTION)
annotation class SingleClick(
val value: Long = 500
)
SingleClickAspect:
import android.os.SystemClock
import org.aspectj.lang.ProceedingJoinPoint
import org.aspectj.lang.annotation.Around
import org.aspectj.lang.annotation.Aspect
import org.aspectj.lang.annotation.Pointcut
import org.aspectj.lang.reflect.MethodSignature
@Aspect
class SingleClickAspect {
@Pointcut("execution(@你的包名.SingleClick * *(..))")
fun methodAnnotated() { }
@Around("methodAnnotated()")
@Throws(Throwable::class)
fun aroundJoinPoint(joinPoint: ProceedingJoinPoint) {
try {
val signature = joinPoint.signature as MethodSignature
val method = signature.method
val hasAnnotation = method != null && method.isAnnotationPresent(SingleClick::class.java)
if (hasAnnotation) {
val singleClick = method.getAnnotation(SingleClick::class.java)
val interval = singleClick.value
if (canClick(interval)) {
joinPoint.proceed()
}
} else {
joinPoint.proceed()
}
} catch (e: Exception) {
joinPoint.proceed()
}
}
private fun canClick(interval: Long): Boolean {
val time = SystemClock.elapsedRealtime()
val timeInterval = Math.abs(time - mLastClickTime)
if (timeInterval > interval) {
mLastClickTime = time
return true
}
return false
}
companion object {
private var mLastClickTime: Long = 0
}
}
build.gradle(项目):
buildscript {
dependencies {
classpath 'com.hujiang.aspectjx:gradle-android-plugin-aspectjx:2.0.4'
}
}
build.gradle(APP):
plugins {
id 'android-aspectjx'
}
使用:
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<TextView
android:onClick="onTextClick"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello World!"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
}
@SingleClick(800)
fun onTextClick(view: View) {
}
}