最近逛官网发现Android KTX ,Android KTX 是一套扩展插件。它能帮助开发者更为简洁、通顺和优雅地使用 Kotlin 语言开发 Android 应用。目前版本0.2,Google 表示,预览期间 API 可能会发生改变,目前不建议开发者在主要 Android 项目中使用。当 API 稳定且 Google 承诺 API 兼容性时,Android KTX 将作为 Android 支持库的一部分发布。趁有空赶紧look
相关链接
android-ktx github 点我
android-ktx api doc 点我
Android KTX
Android应用程序开发的一套Kotlin扩展。 Android KTX的目标是通过Kotlin使Android开发更加简洁,愉快和习惯。 这个项目的明确目标是不向现有Android API添加任何新功能.Android KTX
使用
要将Android KTX添加到您的项目中,请将以下内容添加到您的应用模块的build.gradle中:
repositories {
google()
}
dependencies {
implementation 'androidx.core:core-ktx:0.2'
}
官方一个例子
Kotlin:
sharedPreferences.edit()
.putBoolean("key", value)
.apply()
Kotlin with Android KTX:
sharedPreferences.edit {
putBoolean("key", value)
}
对于熟悉 kotlin 扩展 的童鞋,十分简单。下面让我们看看它有什么好东西。
animation
content
database
graphics
net
os
preference
text
transition
util
view
widget
以上的是现在的目录结构,包分得十分清晰
Animator.kt 扩展了Animator 各种事件回调
addPauseListener
addListener
doOnPause
doOnResume
doOnCancel
doOnRepeat
doOnStart
doOnEnd
若不封装Animator.AnimatorListener 如下冗余
animator.addListener(object:Animator.AnimatorListener {
override fun onAnimationRepeat(p0: Animator?) {
}
override fun onAnimationEnd(p0: Animator?) {
}
override fun onAnimationCancel(p0: Animator?) {
}
override fun onAnimationStart(p0: Animator?) {
}
})
简洁的Animator监听
animator = ObjectAnimator.ofFloat(fab, "alpha", 1f, 0.1f, 1f)
animator.duration = 2000
animator.doOnStart {
Log.d(TAG,"doOnStart")
}
animator.doOnEnd {
Log.d(TAG,"doOnEnd")
}
animator.addListener(onCancel = {
Log.d(TAG,"onCancel")
})
animator.start()
TypedArray.kt 扩展了原来获取各种属性值的api,没有该属性直接 throw IllegalArgumentException("Attribute not defined in set.")
ContentValues.kt 中contentValuesOf 函数通过一组键值对生成一个新的ContentValues 对象
Log.d(TAG,"hello ${contentValuesOf(Pair("name","ktx"))["name"]}")
Context.kt 扩展了一个通过class获取系统级别 service 的函数 systemService()
,实则是调用 Context.getSystemService()
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M){
val windowManager = systemService<WindowManager>() vs = getSystemService(WindowManager::class.java)
}
没错正是内联函数能有具体化的类型参数(Reified type parameters),用 reified 修饰符来限定类型参数。另外还扩展了withStyledAttributes()
实则调用obtainStyledAttributes
后释放 typedArray
SharedPreferences.kt 扩展了 edit(commit: Boolean = false,action: SharedPreferences.Editor.() -> Unit)
函数,正是高阶函数(将函数用作参数或返回值的函数)。下面看看的实现
@SuppressLint("ApplySharedPref")
inline fun SharedPreferences.edit(
commit: Boolean = false, //默认是apply 操作
action: SharedPreferences.Editor.() -> Unit //接收action 匿名函数以Editor为参数的
) {
val editor = edit()
editor.action()// or action(editor) 调用函数
if (commit) {
editor.commit()
} else {
editor.apply()
}
}
preferences.edit {
//能直接使用类的成员函数或扩展函数且限定
putString("test_key1", "test_value")
putInt("test_key2", 100)
}
利用kotlin 特性能减少千篇一律的代码,如数据库开始事务,提交事务,我们更多关心的是操作数据部分。如 SQLiteDatabase.kt 扩展SQLiteDatabase,原理一样,不说了。 我认为Android KTX 少了Fragment 事务的封装
inline fun FragmentManager.inTransaction(func: FragmentTransaction.() -> FragmentTransaction) {
beginTransaction().func().commitAllowingStateLoss()
}
inline fun Fragment.inTransaction(func: FragmentTransaction.() -> FragmentTransaction) {
this.fragmentManager?.inTransaction(func)
}
inline fun Fragment.inChildTransaction(func: FragmentTransaction.() -> FragmentTransaction) {
this.childFragmentManager?.inTransaction(func)
}
inline fun FragmentActivity.inTransaction(func: FragmentTransaction.() -> FragmentTransaction) {
this.supportFragmentManager?.inTransaction(func)
}
参考链接
https://medium.com/thoughts-overflow/how-to-add-a-fragment-in-kotlin-way-73203c5a450b
Cursor.kt 封装了大量通过Cursor获取value 的方法
BitmapDrawable.kt 扩展了Bitmap 直接转换 BitmapDrawable
inline fun Bitmap.toDrawable(resources: Resources) = BitmapDrawable(resources, this)
graphics 下还扩展了各种简洁的绘图api ,有兴趣可以自行研究
Uri.kt 扩展了“反转”创建uri 统一资源符对象的函数
val intent = Intent(Intent.ACTION_DIAL)
intent.data = "tel:110".toUri() //字符串转 uri
startActivity(intent)
os 下扩展了常用的系统组件的api,如常用的Bundle,Handler
..
preference下扩展了常用的preference View
..
text 下扩展了常用的 String /CharSequence /SpannableStringBuilder api
..
transition 下扩展了Transition(过渡动画) api.
..
util 下扩展了各种工具类,如ArrayMap.kt、ArraySet.kt、Size.kt、SparseArray.kt 、Pair.kt 等
..
view下扩展View,ViewGroup,Menu类
view.isInvisible = true //vs view.visibility = View.VISIBLE
...
Kotlin 的确能让Android API 变得简洁
widget下扩展Toast类
另外 Anko 框架也对Android 作出很多的扩展