androidx.activity
依赖项
Groovy
dependencies { implementation "androidx.activity:activity-ktx:1.9.2" }
Kotlin
dependencies { implementation("androidx.activity:activity-ktx:1.9.2") }
扩展函数
对于 OnBackPressedDispatcher
OnBackPressedCallback |
OnBackPressedDispatcher.addCallback(owner: LifecycleOwner? = null, enabled: Boolean = true, onBackPressed: OnBackPressedCallback.() -> Unit)
创建并添加新的 OnBackPressedCallback,它会调用 OnBackPressedCallback.handleOnBackPressed 中的 onBackPressed。 |
对于 ComponentActivity
Lazy<VM> |
ComponentActivity.viewModels(noinline factoryProducer: () -> ViewModelProvider.Factory = null)
返回一个延迟委托以访问 ComponentActivity 的 ViewModel。如果已指定 factoryProducer,则它返回的 ViewModelProvider.Factory 将用于首次创建 ViewModel。 |
androidx.benchmark
依赖项
Groovy
dependencies { implementation "androidx.benchmark:benchmark-junit4:1.2.1" }
Kotlin
dependencies { implementation("androidx.benchmark:benchmark-junit4:1.2.1") }
顶级函数
Unit |
beginTraceSection(sectionName: String)
|
Unit |
endTraceSection()
|
androidx.benchmark.junit4
依赖项
Groovy
dependencies { implementation "androidx.benchmark:benchmark-junit4:1.2.1" }
Kotlin
dependencies { implementation("androidx.benchmark:benchmark-junit4:1.2.1") }
扩展函数
对于 BenchmarkRule
Unit |
BenchmarkRule.measureRepeated(crossinline block: BenchmarkRule.Scope.() -> Unit)
对代码块进行基准测试。 |
androidx.collection
依赖项
Groovy
dependencies { implementation "androidx.collection:collection-ktx:1.3.0" }
Kotlin
dependencies { implementation("androidx.collection:collection-ktx:1.3.0") }
扩展函数
对于 LongSparseArray
运算符 Boolean |
LongSparseArray<T>.contains(key: Long)
如果该集合包含 key,则返回 true。 |
Unit |
LongSparseArray<T>.forEach(action: (key: Long, value: T) -> Unit)
针对各个键值对条目执行指定的操作。 |
T |
LongSparseArray<T>.getOrDefault(key: Long, defaultValue: T)
返回与 key 对应的值,如果该值不存在,则返回 defaultValue。 |
T |
LongSparseArray<T>.getOrElse(key: Long, defaultValue: () -> T)
返回与 key 对应的值,如果该值不存在,则返回 defaultValue 中的值。 |
Boolean |
LongSparseArray<T>.isNotEmpty()
当集合中包含多个元素时,返回 true。 |
LongIterator |
LongSparseArray<T>.keyIterator()
针对该集合的键返回迭代器。 |
运算符 LongSparseArray<T> |
LongSparseArray<T>.plus(other: LongSparseArray<T>)
通过添加或替换 other 中的条目来创建一个新集合。 |
Boolean |
LongSparseArray<T>.remove(key: Long, value: T)
|
运算符 Unit |
LongSparseArray<T>.set(key: Long, value: T)
允许使用索引运算符在集合中存储值。 |
Iterator<T> |
LongSparseArray<T>.valueIterator()
针对该集合的值返回迭代器。 |
对于 SparseArrayCompat
运算符 Boolean |
SparseArrayCompat<T>.contains(key: Int)
如果该集合包含 key,则返回 true。 |
Unit |
SparseArrayCompat<T>.forEach(action: (key: Int, value: T) -> Unit)
针对各个键值对条目执行指定的操作。 |
T |
SparseArrayCompat<T>.getOrDefault(key: Int, defaultValue: T)
返回与 key 对应的值,如果该值不存在,则返回 defaultValue。 |
T |
SparseArrayCompat<T>.getOrElse(key: Int, defaultValue: () -> T)
返回与 key 对应的值,如果该值不存在,则返回 defaultValue 中的值。 |
Boolean |
SparseArrayCompat<T>.isNotEmpty()
当集合中包含多个元素时,返回 true。 |
IntIterator |
SparseArrayCompat<T>.keyIterator()
针对该集合的键返回迭代器。 |
运算符 SparseArrayCompat<T> |
SparseArrayCompat<T>.plus(other: SparseArrayCompat<T>)
通过添加或替换 other 中的条目来创建一个新集合。 |
Boolean |
SparseArrayCompat<T>.remove(key: Int, value: T)
|
运算符 Unit |
SparseArrayCompat<T>.set(key: Int, value: T)
允许使用索引运算符在集合中存储值。 |
Iterator<T> |
SparseArrayCompat<T>.valueIterator()
针对该集合的值返回迭代器。 |
扩展属性
对于 LongSparseArray
Int |
LongSparseArray<T>.size()
返回集合中键/值对的数量。 |
对于 SparseArrayCompat
Int |
SparseArrayCompat<T>.size()
返回集合中键/值对的数量。 |
顶级函数
ArrayMap<K, V> |
arrayMapOf()
返回新的空 ArrayMap。 |
ArrayMap<K, V> |
arrayMapOf(vararg pairs: Pair<K, V>)
返回以键值对列表形式提供的具有指定内容的新 ArrayMap,键值对的第一个组成部分是键,第二个组成部分是值。 |
ArraySet<T> |
arraySetOf()
返回新的空 ArraySet。 |
ArraySet<T> |
arraySetOf(vararg values: T)
返回具有指定内容的新 ArraySet。 |
LruCache<K, V> |
lruCache(maxSize: Int, crossinline sizeOf: (key: K, value: V) -> Int = { _, _ -> 1 }, crossinline create: (key: K) -> V? = { null as V? }, crossinline onEntryRemoved: (evicted: Boolean, key: K, oldValue: V, newValue: V?) -> Unit = { _, _, _, _ -> })
创建具有指定参数的 LruCache。 |
androidx.core.animation
依赖项
Groovy
dependencies { implementation "androidx.core:core-ktx:1.13.1" }
Kotlin
dependencies { implementation("androidx.core:core-ktx:1.13.1") }
扩展函数
对于 android.animation.Animator
AnimatorListener |
Animator.addListener(crossinline onEnd: (animator: Animator) -> Unit = {}, crossinline onStart: (animator: Animator) -> Unit = {}, crossinline onCancel: (animator: Animator) -> Unit = {}, crossinline onRepeat: (animator: Animator) -> Unit = {})
使用提供的操作向此 Animator 添加监听器。 |
AnimatorPauseListener |
Animator.addPauseListener(crossinline onResume: (animator: Animator) -> Unit = {}, crossinline onPause: (animator: Animator) -> Unit = {})
使用提供的操作向此 Animator 添加暂停和继续播放监听器。 |
AnimatorListener |
Animator.doOnCancel(crossinline action: (animator: Animator) -> Unit)
添加将在动画取消播放时调用的操作。 |
AnimatorListener |
Animator.doOnEnd(crossinline action: (animator: Animator) -> Unit)
添加将在动画结束播放时调用的操作。 |
AnimatorPauseListener |
Animator.doOnPause(crossinline action: (animator: Animator) -> Unit)
添加将在动画暂停播放时调用的操作。 |
AnimatorListener |
Animator.doOnRepeat(crossinline action: (animator: Animator) -> Unit)
添加将在动画重复播放时调用的操作。 |
AnimatorPauseListener |
Animator.doOnResume(crossinline action: (animator: Animator) -> Unit)
添加将在动画暂停后继续播放时调用的操作。 |
AnimatorListener |
Animator.doOnStart(crossinline action: (animator: Animator) -> Unit)
添加将在动画开始播放时调用的操作。 |
androidx.core.content
依赖项
Groovy
dependencies { implementation "androidx.core:core-ktx:1.13.1" }
Kotlin
dependencies { implementation("androidx.core:core-ktx:1.13.1") }
扩展函数
对于 android.content.Context
T? |
Context.getSystemService()
将句柄按类别返回到系统级服务。 |
Unit |
Context.withStyledAttributes(set: AttributeSet? = null, attrs: IntArray, @AttrRes defStyleAttr: Int = 0, @StyleRes defStyleRes: Int = 0, block: TypedArray.() -> Unit)
在 TypedArray 接收器上执行 block。 |
Unit |
Context.withStyledAttributes(@StyleRes resourceId: Int, attrs: IntArray, block: TypedArray.() -> Unit)
在 TypedArray 接收器上执行 block。 |
对于 android.content.SharedPreferences
Unit |
SharedPreferences.edit(: Boolean = false, : Editor.() -> Unit)
|
顶级函数
ContentValues |
contentValuesOf(vararg pairs: Pair<String, Any?>)
返回以指定键值对作为元素的新 ContentValues。 |
androidx.core.content.res
依赖项
Groovy
dependencies { implementation "androidx.core:core-ktx:1.13.1" }
Kotlin
dependencies { implementation("androidx.core:core-ktx:1.13.1") }
扩展函数
对于 android.content.res.TypedArray
androidx.core.database
依赖项
Groovy
dependencies { implementation "androidx.core:core-ktx:1.13.1" }
Kotlin
dependencies { implementation("androidx.core:core-ktx:1.13.1") }
扩展函数
对于 android.database.Cursor
ByteArray? |
Cursor.getBlobOrNull(index: Int)
返回所请求列的值作为可为 Null 的字节数组。 |
Double? |
Cursor.getDoubleOrNull(index: Int)
返回所请求列的值作为可为 Null 的 double 值。 |
Float? |
Cursor.getFloatOrNull(index: Int)
返回所请求列的值作为可为 Null 的浮点值。 |
Int? |
Cursor.getIntOrNull(index: Int)
返回所请求列的值作为可为 Null 的整数值。 |
Long? |
Cursor.getLongOrNull(index: Int)
返回所请求列的值作为可为 Null 的 long 值。 |
Short? |
Cursor.getShortOrNull(index: Int)
返回所请求列的值作为可为 Null 的 short 值。 |
String? |
Cursor.getStringOrNull(index: Int)
返回所请求列的值作为可为 Null 的字符串。 |
androidx.core.database.sqlite
依赖项
Groovy
dependencies { implementation "androidx.core:core-ktx:1.13.1" }
Kotlin
dependencies { implementation("androidx.core:core-ktx:1.13.1") }
扩展函数
对于 android.database.sqlite.SQLiteDatabase
T |
SQLiteDatabase.transaction(exclusive: Boolean = true, body: SQLiteDatabase.() -> T)
在事务中运行 body,如果顺利完成,则将其标记为“成功”。 |
androidx.core.graphics
依赖项
Groovy
dependencies { implementation "androidx.core:core-ktx:1.13.1" }
Kotlin
dependencies { implementation("androidx.core:core-ktx:1.13.1") }
扩展函数
对于 android.graphics.Bitmap
Bitmap |
Bitmap.applyCanvas(block: Canvas.() -> Unit)
|
运算符 Boolean |
Bitmap.contains(p: Point)
如果指定的点位于该位图内部,则返回 true。 |
运算符 Boolean |
Bitmap.contains(p: PointF)
如果指定的点位于该位图内部,则返回 true。 |
运算符 Int |
Bitmap.get(x: Int, y: Int)
返回指定位置的像素值。 |
Bitmap |
Bitmap.scale(width: Int, height: Int, filter: Boolean = true)
创建一个新的位图,并尽可能通过缩放此位图来创建。 |
运算符 Unit |
Bitmap.set(x: Int, y: Int, color: Int)
将指定的 color int 写入位于指定的 |
对于 android.graphics.Canvas
对于 android.graphics.Color
运算符 Float |
Color.component1()
返回颜色的第一个分量。 |
运算符 Float |
Color.component2()
返回颜色的第二个分量。 |
运算符 Float |
Color.component3()
返回颜色的第三个分量。 |
运算符 Float |
Color.component4()
返回颜色的第四个分量。 |
infix Color! |
Color.convertTo(colorSpace: Named)
将颜色接收器转换为指定颜色空间中的颜色。 |
infix Color! |
Color.convertTo(colorSpace: ColorSpace)
将颜色接收器转换为指定颜色空间中的颜色。 |
运算符 Color |
Color.plus(c: Color)
将两种半透明颜色混合在一起。 |
对于 android.graphics.ImageDecoder.Source
Bitmap |
Source.decodeBitmap(crossinline action: ImageDecoder.(info: ImageInfo, source: Source) -> Unit)
从来源创建位图 |
Drawable |
Source.decodeDrawable(crossinline action: ImageDecoder.(info: ImageInfo, source: Source) -> Unit)
从来源创建可绘制对象 |
对于 android.graphics.Matrix
运算符 Matrix |
Matrix.times(m: Matrix)
将此矩阵与另一个矩阵相乘,并返回结果作为一个新矩阵。 |
FloatArray |
Matrix.values()
返回此矩阵的 9 个值作为新的浮点数组。 |
对于 android.graphics.Paint
Boolean |
Paint.setBlendMode(blendModeCompat: BlendModeCompat?)
以向后兼容的方式配置 Paint 的 BlendMode 的简便方法。 |
对于 android.graphics.Path
infix Path |
Path.and(p: Path)
返回两条路径的交集作为新的路径。 |
Iterable<PathSegment> |
Path.flatten(error: Float = 0.5f)
通过一系列线段对路径进行扁平化(或近似)处理。 |
运算符 Path |
Path.minus(p: Path)
返回两条路径的差异部分作为新的路径。 |
infix Path |
Path.or(p: Path)
返回两条路径的并集作为新的路径。 |
运算符 Path |
Path.plus(p: Path)
返回两条路径的并集作为新的路径。 |
infix Path |
Path.xor(p: Path)
返回两条路径的并集减去交集的部分作为新的路径。 |
对于 android.graphics.Picture
Picture |
Picture.record(width: Int, height: Int, block: Canvas.() -> Unit)
|
对于 android.graphics.Point
运算符 Int |
Point.component1()
返回此点的 X 坐标。 |
运算符 Int |
Point.component2()
返回此点的 Y 坐标。 |
运算符 Point |
Point.minus(p: Point)
通过反向移动指定的点对此点进行偏移,并返回结果作为新的点。 |
运算符 Point |
Point.minus(xy: Int)
通过沿 X 轴和 Y 轴方向反向移动指定距离对该点进行偏移,并返回结果作为新的点。 |
运算符 Point |
Point.plus(p: Point)
根据指定点对该点进行偏移,并返回结果作为新的点。 |
运算符 Point |
Point.plus(xy: Int)
通过沿 X 轴和 Y 轴方向移动指定的距离对此点进行偏移,并返回结果作为新的点。 |
PointF |
Point.toPointF()
返回此点的 PointF 表示法。 |
运算符 Point |
Point.unaryMinus()
返回表示该点的对立点的新点。 |
对于 android.graphics.PointF
运算符 Float |
PointF.component1()
返回此点的 X 坐标。 |
运算符 Float |
PointF.component2()
返回此点的 Y 坐标。 |
运算符 PointF |
PointF.minus(p: PointF)
通过反向移动指定的点对此点进行偏移,并返回结果作为新的点。 |
运算符 PointF |
PointF.minus(xy: Float)
通过沿 X 轴和 Y 轴方向反向移动指定距离对该点进行偏移,并返回结果作为新的点。 |
运算符 PointF |
PointF.plus(p: PointF)
根据指定点对该点进行偏移,并返回结果作为新的点。 |
运算符 PointF |
PointF.plus(xy: Float)
通过沿 X 轴和 Y 轴方向移动指定的距离对此点进行偏移,并返回结果作为新的点。 |
Point |
PointF.toPoint()
返回此点的 Point 表示法。 |
运算符 PointF |
PointF.unaryMinus()
返回表示该点的对立点的新点。 |
对于 android.graphics.PorterDuff.Mode
PorterDuffColorFilter |
Mode.toColorFilter(color: Int)
创建一个新的 PorterDuffColorFilter,它使用此 PorterDuff.Mode 作为 Alpha 合成或混合模式,并使用指定的颜色。 |
PorterDuffXfermode |
Mode.toXfermode()
创建一个新的 PorterDuffXfermode,它使用此 PorterDuff.Mode 作为 Alpha 合成或混合模式。 |
对于 android.graphics.Rect
infix Rect |
Rect.and(r: Rect)
返回两个矩形的交集作为新的矩形。 |
运算符 Int |
Rect.component1()
返回矩形的第一个组成部分“left”。 |
运算符 Int |
Rect.component2()
返回矩形的第二个组成部分“top”。 |
运算符 Int |
Rect.component3()
返回矩形的第三个组成部分“right”。 |
运算符 Int |
Rect.component4()
返回矩形的第四个组成部分“bottom”。 |
运算符 Boolean |
Rect.contains(p: Point)
如果指定的点位于该矩形内部,则返回 true。 |
运算符 Region |
Rect.minus(r: Rect)
返回此矩形与指定矩形的差异部分作为新的区域。 |
运算符 Rect |
Rect.minus(xy: Int)
返回一个新的矩形,它表示该矩形通过沿 X 轴和 Y 轴方向反向移动指定距离进行偏移。 |
运算符 Rect |
Rect.minus(xy: Point)
返回一个新的矩形,它表示该矩形通过反向移动指定的点进行偏移。 |
infix Rect |
Rect.or(r: Rect)
返回两个矩形的并集作为新的矩形。 |
运算符 Rect |
Rect.plus(r: Rect)
执行此矩形与指定矩形的并集,并返回结果作为新的矩形。 |
运算符 Rect |
Rect.plus(xy: Int)
返回一个新的矩形,它表示该矩形在 X 轴和 Y 轴上按照指定的量进行偏移。 |
运算符 Rect |
Rect.plus(xy: Point)
返回一个新的矩形,它表示该矩形按照指定的点进行偏移。 |
运算符 Rect |
Rect.times(factor: Int)
返回一个新的矩形,它表示该矩形的各个组成部分按比例进行了缩放。 |
RectF |
Rect.toRectF()
返回该矩形的 RectF 表示法。 |
Region |
Rect.toRegion()
返回该矩形的 Region 表示法。 |
infix Region |
Rect.xor(r: Rect)
返回两个矩形的并集减去交集的部分作为新的区域。 |
对于 android.graphics.RectF
infix RectF |
RectF.and(r: RectF)
返回两个矩形的交集作为新的矩形。 |
运算符 Float |
RectF.component1()
返回矩形的第一个组成部分“left”。 |
运算符 Float |
RectF.component2()
返回矩形的第二个组成部分“top”。 |
运算符 Float |
RectF.component3()
返回矩形的第三个组成部分“right”。 |
运算符 Float |
RectF.component4()
返回矩形的第四个组成部分“bottom”。 |
运算符 Boolean |
RectF.contains(p: PointF)
如果指定的点位于该矩形内部,则返回 true。 |
运算符 Region |
RectF.minus(r: RectF)
返回此矩形与指定矩形的差异部分作为新的区域。 |
运算符 RectF |
RectF.minus(xy: Float)
返回一个新的矩形,它表示该矩形通过沿 X 轴和 Y 轴方向反向移动指定距离进行偏移。 |
运算符 RectF |
RectF.minus(xy: PointF)
返回一个新的矩形,它表示该矩形通过反向移动指定的点进行偏移。 |
infix RectF |
RectF.or(r: RectF)
返回两个矩形的并集作为新的矩形。 |
运算符 RectF |
RectF.plus(r: RectF)
执行此矩形与指定矩形的并集,并返回结果作为新的矩形。 |
运算符 RectF |
RectF.plus(xy: Float)
返回一个新的矩形,它表示该矩形在 X 轴和 Y 轴上按照指定的量进行偏移。 |
运算符 RectF |
RectF.plus(xy: PointF)
返回一个新的矩形,它表示该矩形按照指定的点进行偏移。 |
运算符 RectF |
RectF.times(factor: Int)
返回一个新的矩形,它表示该矩形的各个组成部分按比例进行了缩放。 |
运算符 RectF |
RectF.times(factor: Float)
返回一个新的矩形,它表示该矩形的各个组成部分按比例进行了缩放。 |
Rect |
RectF.toRect()
返回该矩形的 Rect 表示法。 |
Region |
RectF.toRegion()
返回该矩形的 Region 表示法。 |
RectF |
RectF.transform(m: Matrix)
使用提供的矩阵对此矩形进行适当转换,并返回该矩形。 |
infix Region |
RectF.xor(r: RectF)
返回两个矩形的并集减去交集的部分作为新的区域。 |
对于 android.graphics.Region
infix Region |
Region.and(r: Rect)
返回该区域与指定矩形的交集作为新的区域。 |
infix Region |
Region.and(r: Region)
返回该区域与指定区域的交集作为新的区域。 |
运算符 Boolean |
Region.contains(p: Point)
如果该区域包含指定的点,则返回 true。 |
Unit |
Region.forEach(action: (rect: Rect) -> Unit)
对该区域中的各个矩形执行指定的操作。 |
运算符 Iterator<Rect> |
Region.iterator()
针对该区域内的矩形返回迭代器。 |
运算符 Region |
Region.minus(r: Rect)
返回该区域与指定矩形之间的差异部分作为新的区域。 |
运算符 Region |
Region.minus(r: Region)
返回该区域与指定区域的差异部分作为新的区域。 |
运算符 Region |
Region.not()
返回该区域的对立区域作为新的区域。 |
infix Region |
Region.or(r: Rect)
返回该区域与指定矩形的并集作为新的区域。 |
infix Region |
Region.or(r: Region)
返回该区域与指定区域的并集作为新的区域。 |
运算符 Region |
Region.plus(r: Rect)
返回该区域与指定矩形的并集作为新的区域。 |
运算符 Region |
Region.plus(r: Region)
返回该区域与指定区域的并集作为新的区域。 |
运算符 Region |
Region.unaryMinus()
返回该区域的对立区域作为新的区域。 |
infix Region |
Region.xor(r: Rect)
返回该区域与指定矩形的并集减去交集的部分作为新的区域。 |
infix Region |
Region.xor(r: Region)
返回该区域与指定区域的并集减去交集的部分作为新的区域。 |
对于 android.graphics.Shader
Unit |
Shader.transform(block: Matrix.() -> Unit)
将指定的 block 封装在对 Shader.getLocalMatrix 和 Shader.setLocalMatrix 的调用中。 |
对于 kotlin.Int
运算符 Int |
Int.component1()
返回 color int 的 Alpha 分量。 |
运算符 Int |
Int.component2()
返回 color int 的红色分量。 |
运算符 Int |
Int.component3()
返回 color int 的绿色分量。 |
运算符 Int |
Int.component4()
返回 color int 的蓝色分量。 |
infix Long |
Int.convertTo(colorSpace: Named)
将 color int 接收器转换为指定颜色空间中的 color long。 |
infix Long |
Int.convertTo(colorSpace: ColorSpace)
将 color int 接收器转换为指定颜色空间中的 color long。 |
Color |
Int.toColor()
根据 color int 创建一个新的颜色实例。 |
Long |
Int.toColorLong()
将指定的 ARGB color int 转换为 sRGB 颜色空间中的 RGBA color long。 |
对于 kotlin.Long
运算符 Float |
Long.component1()
返回颜色的第一个分量。 |
运算符 Float |
Long.component2()
返回颜色的第二个分量。 |
运算符 Float |
Long.component3()
返回颜色的第三个分量。 |
运算符 Float |
Long.component4()
返回颜色的第四个分量。 |
infix Long |
Long.convertTo(colorSpace: Named)
将 color long 接收器转换为指定颜色空间中的 color long。 |
infix Long |
Long.convertTo(colorSpace: ColorSpace)
将 color long 接收器转换为指定颜色空间中的 color long。 |
Color |
Long.toColor()
从 color long 中创建一个新的颜色实例。 |
Int |
Long.toColorInt()
将指定的 color long 转换为 ARGB color int。 |
对于 kotlin.String
Int |
String.toColorInt()
|
扩展属性
对于 kotlin.Int
Int |
Int.alpha()
返回 color int 的 Alpha 分量。 |
Int |
Int.blue()
返回 color int 的蓝色分量。 |
Int |
Int.green()
返回 color int 的绿色分量。 |
Float |
Int.luminance()
返回 color int 的相对亮度,假设采用 sRGB 编码。 |
Int |
Int.red()
返回 color int 的红色分量。 |
对于 kotlin.Long
Float |
Long.alpha()
返回 color long 的 Alpha 分量。 |
Float |
Long.blue()
返回 color long 的蓝色分量。 |
ColorSpace |
Long.colorSpace()
返回采用指定的 color long 进行编码的颜色空间。 |
Float |
Long.green()
返回 color long 的绿色分量。 |
Boolean |
Long.isSrgb()
表明该颜色是否在 sRGB 颜色空间内。 |
Boolean |
Long.isWideGamut()
表明该颜色是否在广色域颜色空间内。 |
Float |
Long.luminance()
返回颜色的相对亮度。 |
Float |
Long.red()
返回 color long 的红色分量。 |
顶级函数
Bitmap |
createBitmap(width: Int, height: Int, config: Config = Bitmap.Config.ARGB_8888)
|
Bitmap |
createBitmap(width: Int, height: Int, config: Config = Bitmap.Config.ARGB_8888, hasAlpha: Boolean = true, colorSpace: ColorSpace = ColorSpace.get(ColorSpace.Named.SRGB))
|
Matrix |
rotationMatrix(degrees: Float, px: Float = 0.0f, py: Float = 0.0f)
|
Matrix |
scaleMatrix(sx: Float = 1.0f, sy: Float = 1.0f)
|
Matrix |
translationMatrix(tx: Float = 0.0f, ty: Float = 0.0f)
|
androidx.core.graphics.drawable
依赖项
Groovy
dependencies { implementation "androidx.core:core-ktx:1.13.1" }
Kotlin
dependencies { implementation("androidx.core:core-ktx:1.13.1") }
扩展函数
对于 android.graphics.Bitmap
Icon |
Bitmap.toAdaptiveIcon()
|
BitmapDrawable |
Bitmap.toDrawable(resources: Resources)
根据该位图创建一个 BitmapDrawable。 |
Icon |
Bitmap.toIcon()
|
对于 android.graphics.Color
ColorDrawable |
Color.toDrawable()
根据该颜色创建一个 ColorDrawable(通过 Color.toArgb)。 |
对于 android.graphics.drawable.Drawable
Bitmap |
Drawable.toBitmap(@Px width: Int = intrinsicWidth, @Px height: Int = intrinsicHeight, config: Config? = null)
|
Unit |
Drawable.updateBounds(@Px left: Int = bounds.left, @Px top: Int = bounds.top, @Px right: Int = bounds.right, @Px bottom: Int = bounds.bottom)
更新该可绘制对象的边界。 |
对于 android.net.Uri
Icon |
Uri.toIcon()
|
对于 kotlin.ByteArray
Icon |
ByteArray.toIcon()
|
对于 kotlin.Int
ColorDrawable |
Int.toDrawable()
根据该颜色值创建一个 ColorDrawable。 |
androidx.core.location
依赖项
Groovy
dependencies { implementation "androidx.core:core-ktx:1.13.1" }
Kotlin
dependencies { implementation("androidx.core:core-ktx:1.13.1") }
扩展函数
对于 android.location.Location
运算符 Double |
Location.component1()
返回此位置的纬度。 |
运算符 Double |
Location.component2()
返回此位置的经度。 |
androidx.core.net
依赖项
Groovy
dependencies { implementation "androidx.core:core-ktx:1.13.1" }
Kotlin
dependencies { implementation("androidx.core:core-ktx:1.13.1") }
扩展函数
对于 android.net.Uri
File |
Uri.toFile()
|
对于 java.io.File
Uri |
File.toUri()
根据指定的文件创建一个 URI。 |
对于 kotlin.String
Uri |
String.toUri()
根据指定的编码 URI 字符串创建一个 URI。 |
androidx.core.os
依赖项
Groovy
dependencies { implementation "androidx.core:core-ktx:1.13.1" }
Kotlin
dependencies { implementation("androidx.core:core-ktx:1.13.1") }
扩展函数
对于 android.os.Handler
Runnable |
Handler.postAtTime(uptimeMillis: Long, token: Any? = null, crossinline action: () -> Unit)
Handler.postAtTime 的一个版本,用于对参数重新排序,允许将操作置于括号之外。 |
Runnable |
Handler.postDelayed(delayInMillis: Long, token: Any? = null, crossinline action: () -> Unit)
Handler.postDelayed 的一个版本,用于对参数重新排序,允许将操作置于括号之外。 |
顶级函数
Bundle |
bundleOf(vararg pairs: Pair<String, Any?>)
返回以指定键值对作为元素的新 Bundle。 |
PersistableBundle |
persistableBundleOf(vararg pairs: Pair<String, Any?>)
返回以指定键值对作为元素的新 PersistableBundle。 |
T |
trace(sectionName: String, block: () -> T)
将指定的 block 封装在对 Trace.beginSection(具有提供的 sectionName)和 Trace.endSection 的调用中。 |
androidx.core.text
依赖项
Groovy
dependencies { implementation "androidx.core:core-ktx:1.13.1" }
Kotlin
dependencies { implementation("androidx.core:core-ktx:1.13.1") }
扩展函数
对于 android.text.Spannable
Unit |
Spannable.clearSpans()
清除此文本中的所有 span。 |
运算符 Unit |
Spannable.set(start: Int, end: Int, span: Any)
|
运算符 Unit |
Spannable.set(range: IntRange, span: Any)
|
对于 android.text.SpannableStringBuilder
对于 android.text.Spanned
Array<out T> |
Spanned.getSpans(start: Int = 0, end: Int = length)
获取为 T 的实例的所有 span。 |
String |
Spanned.toHtml(option: Int = TO_HTML_PARAGRAPH_LINES_CONSECUTIVE)
返回此 Spanned 中 span 的 HTML 字符串。 |
对于 kotlin.CharSequence
Boolean |
CharSequence.isDigitsOnly()
返回指定的 CharSequence 是否仅包含数字。 |
Spannable |
CharSequence.toSpannable()
从 CharSequence 中返回一个新的 Spannable,或者如果来源已是 SpannableString 的实例,则返回来源本身。 |
Spanned |
CharSequence.toSpanned()
从 CharSequence 中返回一个新的 Spanned,或者如果来源已是 SpannedString 的实例,则返回来源本身。 |
Int |
CharSequence.trimmedLength()
如果通过 String.trim 从开始和结束位置对空格和 ASCII 控件字符进行修剪,则返回指定的 CharSequence 的长度。 |
对于 kotlin.String
String |
String.htmlEncode()
对字符串进行 HTML 编码。 |
Spanned |
String.parseAsHtml(flags: Int = FROM_HTML_MODE_LEGACY, imageGetter: ImageGetter? = null, tagHandler: TagHandler? = null)
通过将此字符串解析为 HTML,返回 Spanned。 |
扩展属性
对于 java.util.Locale
Int |
Locale.layoutDirection()
返回指定语言区域的布局方向。 |
顶级函数
SpannedString |
buildSpannedString(builderAction: SpannableStringBuilder.() -> Unit)
使用提供的 builderAction 填充新创建的 SpannableStringBuilder,并将其转换为 SpannedString,从而构建新的字符串。 |
androidx.core.transition
依赖项
Groovy
dependencies { implementation "androidx.core:core-ktx:1.13.1" }
Kotlin
dependencies { implementation("androidx.core:core-ktx:1.13.1") }
扩展函数
对于 android.transition.Transition
TransitionListener |
Transition.addListener(crossinline onEnd: (transition: Transition) -> Unit = {}, crossinline onStart: (transition: Transition) -> Unit = {}, crossinline onCancel: (transition: Transition) -> Unit = {}, crossinline onResume: (transition: Transition) -> Unit = {}, crossinline onPause: (transition: Transition) -> Unit = {})
使用提供的操作为此转换添加监听器。 |
TransitionListener |
Transition.doOnCancel(crossinline action: (transition: Transition) -> Unit)
添加将在此转换被取消时调用的操作。 |
TransitionListener |
Transition.doOnEnd(crossinline action: (transition: Transition) -> Unit)
添加将在此转换结束时调用的操作。 |
TransitionListener |
Transition.doOnPause(crossinline action: (transition: Transition) -> Unit)
添加将在此转换暂停时调用的操作。 |
TransitionListener |
Transition.doOnResume(crossinline action: (transition: Transition) -> Unit)
添加将在此转换暂停后再次继续进行时调用的操作。 |
TransitionListener |
Transition.doOnStart(crossinline action: (transition: Transition) -> Unit)
添加将在此转换开始时调用的操作。 |
androidx.core.util
依赖项
Groovy
dependencies { implementation "androidx.core:core-ktx:1.13.1" }
Kotlin
dependencies { implementation("androidx.core:core-ktx:1.13.1") }
扩展函数
对于 android.util.AtomicFile
ByteArray |
AtomicFile.readBytes()
以字节数组的形式获取此文件的全部内容。 |
String |
AtomicFile.readText(charset: Charset = Charsets.UTF_8)
使用 UTF-8 或指定的字符集以字符串形式获取此文件的全部内容。 |
Unit |
AtomicFile.tryWrite(block: (out: FileOutputStream) -> Unit)
在此文件的 block 内执行写入操作。 |
Unit |
AtomicFile.writeBytes(array: ByteArray)
将此文件的内容设置为字节数组。 |
Unit |
AtomicFile.writeText(text: String, charset: Charset = Charsets.UTF_8)
|
对于 android.util.LongSparseArray
运算符 Boolean |
LongSparseArray<T>.contains(key: Long)
如果该集合包含 key,则返回 true。 |
Boolean |
LongSparseArray<T>.containsKey(key: Long)
如果该集合包含 key,则返回 true。 |
Boolean |
LongSparseArray<T>.containsValue(value: T)
如果该集合包含 value,则返回 true。 |
Unit |
LongSparseArray<T>.forEach(action: (key: Long, value: T) -> Unit)
针对各个键值对条目执行指定的操作。 |
T |
LongSparseArray<T>.getOrDefault(key: Long, defaultValue: T)
返回与 key 对应的值,如果该值不存在,则返回 defaultValue。 |
T |
LongSparseArray<T>.getOrElse(key: Long, defaultValue: () -> T)
返回与 key 对应的值,如果该值不存在,则返回 defaultValue 中的值。 |
Boolean |
LongSparseArray<T>.isEmpty()
当集合中未包含任何元素时,返回 true。 |
Boolean |
LongSparseArray<T>.isNotEmpty()
当集合中包含多个元素时,返回 true。 |
LongIterator |
LongSparseArray<T>.keyIterator()
针对该集合的键返回迭代器。 |
运算符 LongSparseArray<T> |
LongSparseArray<T>.plus(other: LongSparseArray<T>)
通过添加或替换 other 中的条目来创建一个新集合。 |
Unit |
LongSparseArray<T>.putAll(other: LongSparseArray<T>)
通过添加或替换 other 中的条目来更新此集合。 |
Boolean |
LongSparseArray<T>.remove(key: Long, value: T)
|
运算符 Unit |
LongSparseArray<T>.set(key: Long, value: T)
允许使用索引运算符在集合中存储值。 |
Iterator<T> |
LongSparseArray<T>.valueIterator()
针对该集合的值返回迭代器。 |
对于 android.util.Pair
运算符 F |
Pair<F, S>.component1()
返回键值对的第一个组成部分。 |
运算符 S |
Pair<F, S>.component2()
返回键值对的第二个组成部分。 |
Pair<F, S> |
Pair<F, S>.toKotlinPair()
将此键值对作为 kotlin.Pair 返回。 |
对于 android.util.Range
infix Range<T> |
Range<T>.and(other: Range<T>)
返回此范围与 other 的交集。 |
运算符 Range<T> |
Range<T>.plus(value: T)
返回包含该范围和 value 的最小范围。 |
运算符 Range<T> |
Range<T>.plus(other: Range<T>)
返回包含该范围和 other 的最小范围。 |
ClosedRange<T> |
Range<T>.toClosedRange()
将此 Rang 作为 ClosedRange 返回。 |
对于 android.util.Size
运算符 Int |
Size.component1()
返回该尺寸的第一个组成部分“width”。 |
运算符 Int |
Size.component2()
返回该尺寸的第二个组成部分“height”。 |
对于 android.util.SizeF
运算符 Float |
SizeF.component1()
返回该 SizeF 的第一个组成部分“width”。 |
运算符 Float |
SizeF.component2()
返回该 SizeF 的第二个组成部分“height”。 |
对于 android.util.SparseArray
运算符 Boolean |
SparseArray<T>.contains(key: Int)
如果该集合包含 key,则返回 true。 |
Boolean |
SparseArray<T>.containsKey(key: Int)
如果该集合包含 key,则返回 true。 |
Boolean |
SparseArray<T>.containsValue(value: T)
如果该集合包含 value,则返回 true。 |
Unit |
SparseArray<T>.forEach(action: (key: Int, value: T) -> Unit)
针对各个键值对条目执行指定的操作。 |
T |
SparseArray<T>.getOrDefault(key: Int, defaultValue: T)
返回与 key 对应的值,如果该值不存在,则返回 defaultValue。 |
T |
SparseArray<T>.getOrElse(key: Int, defaultValue: () -> T)
返回与 key 对应的值,如果该值不存在,则返回 defaultValue 中的值。 |
Boolean |
SparseArray<T>.isEmpty()
当集合中未包含任何元素时,返回 true。 |
Boolean |
SparseArray<T>.isNotEmpty()
当集合中包含多个元素时,返回 true。 |
IntIterator |
SparseArray<T>.keyIterator()
针对该集合的键返回迭代器。 |
运算符 SparseArray<T> |
SparseArray<T>.plus(other: SparseArray<T>)
通过添加或替换 other 中的条目来创建一个新集合。 |
Unit |
SparseArray<T>.putAll(other: SparseArray<T>)
通过添加或替换 other 中的条目来更新此集合。 |
Boolean |
SparseArray<T>.remove(key: Int, value: T)
|
运算符 Unit |
SparseArray<T>.set(key: Int, value: T)
允许使用索引运算符在集合中存储值。 |
Iterator<T> |
SparseArray<T>.valueIterator()
针对该集合的值返回迭代器。 |
对于 android.util.SparseBooleanArray
对于 android.util.SparseIntArray
对于 android.util.SparseLongArray
对于 kotlin.Double
Half |
Double.toHalf()
|
对于 kotlin.Float
Half |
Float.toHalf()
|
对于 kotlin.Pair
Pair<F, S> |
Pair<F, S>.toAndroidPair()
返回此 kotlin.Pair 作为 Android 键值对。 |
对于 kotlin.Short
Half |
Short.toHalf()
|
对于 kotlin.String
Half |
String.toHalf()
|
对于 kotlin.ranges.ClosedRange
Range<T> |
ClosedRange<T>.toRange()
将该 ClosedRange 作为 Rang 返回。 |
扩展属性
对于 android.util.LongSparseArray
Int |
LongSparseArray<T>.size()
返回集合中键/值对的数量。 |
对于 android.util.SparseArray
Int |
SparseArray<T>.size()
返回集合中键/值对的数量。 |
对于 android.util.SparseBooleanArray
Int |
SparseBooleanArray.size()
返回集合中键/值对的数量。 |
对于 android.util.SparseIntArray
Int |
SparseIntArray.size()
返回集合中键/值对的数量。 |
对于 android.util.SparseLongArray
Int |
SparseLongArray.size()
返回集合中键/值对条目的数量。 |
顶级函数
LruCache<K, V> |
lruCache(maxSize: Int, crossinline sizeOf: (key: K, value: V) -> Int = { _, _ -> 1 }, crossinline create: (key: K) -> V? = { null as V? }, crossinline onEntryRemoved: (evicted: Boolean, key: K, oldValue: V, newValue: V?) -> Unit = { _, _, _, _ -> })
创建具有指定参数的 LruCache。 |
infix Range<T> |
T.rangeTo(that: T)
|
androidx.core.view
依赖项
Groovy
dependencies { implementation "androidx.core:core-ktx:1.13.1" }
Kotlin
dependencies { implementation("androidx.core:core-ktx:1.13.1") }
扩展函数
对于 android.view.Menu
运算符 Boolean |
Menu.contains(item: MenuItem)
如果在此菜单中找到项,则返回 |
Unit |
Menu.forEach(action: (item: MenuItem) -> Unit)
针对此菜单中的每个项执行指定的操作。 |
Unit |
Menu.forEachIndexed(action: (index: Int, item: MenuItem) -> Unit)
针对此菜单中的每个项执行指定的操作,并提供其顺序索引。 |
运算符 MenuItem |
Menu.get(index: Int)
返回索引处的菜单。 |
Boolean |
Menu.isEmpty()
如果此菜单中未包含任何项,则返回 true。 |
Boolean |
Menu.isNotEmpty()
如果此菜单中包含一个或多个项,则返回 true。 |
运算符 MutableIterator<MenuItem> |
Menu.iterator()
针对此菜单中的项返回 MutableIterator。 |
运算符 Unit |
Menu.minusAssign(item: MenuItem)
从此菜单中移除项。 |
对于 android.view.View
Unit |
View.doOnAttach(crossinline action: (view: View) -> Unit)
当该视图附加到窗口时,执行指定的操作。 |
Unit |
View.doOnDetach(crossinline action: (view: View) -> Unit)
当该视图与窗口分离时,执行指定的操作。 |
Unit |
View.doOnLayout(crossinline action: (view: View) -> Unit)
布局该视图时,执行指定的操作。 |
Unit |
View.doOnNextLayout(crossinline action: (view: View) -> Unit)
当再次布局该视图时,执行指定的操作。 |
OneShotPreDrawListener |
View.doOnPreDraw(crossinline action: (view: View) -> Unit)
当要绘制视图树时,执行指定的操作。 |
Bitmap |
View.drawToBitmap(config: Config = Bitmap.Config.ARGB_8888)
|
Runnable |
View.postDelayed(delayInMillis: Long, crossinline action: () -> Unit)
View.postDelayed 的一个版本,用于对参数重新排序,允许将操作置于括号之外。 |
Runnable |
View.postOnAnimationDelayed(delayInMillis: Long, crossinline action: () -> Unit)
View.postOnAnimationDelayed 的一个版本,用于对参数重新排序,允许将操作置于括号之外。 |
Unit |
View.setPadding(@Px size: Int)
设置视图的内边距。 |
Unit |
View.updateLayoutParams(block: LayoutParams.() -> Unit)
使用视图的 layoutParams 执行 block,并使用更新版本重新分配 layoutParams。 |
Unit |
View.updateLayoutParams(block: T.() -> Unit)
使用视图 layoutParams 的打印版本执行 block,并使用更新版本重新分配 layoutParams。 |
Unit |
View.updatePadding(@Px left: Int = paddingLeft, @Px top: Int = paddingTop, @Px right: Int = paddingRight, @Px bottom: Int = paddingBottom)
更新该视图的内边距。 |
Unit |
View.updatePaddingRelative(@Px start: Int = paddingStart, @Px top: Int = paddingTop, @Px end: Int = paddingEnd, @Px bottom: Int = paddingBottom)
更新该视图的相对内边距。 |
对于 android.view.ViewGroup
运算符 Boolean |
ViewGroup.contains(view: View)
如果在该视图组中发现视图,则返回 |
Unit |
ViewGroup.forEach(action: (view: View) -> Unit)
对该视图组中的各个视图执行指定的操作。 |
Unit |
ViewGroup.forEachIndexed(action: (index: Int, view: View) -> Unit)
对该视图组中的各个视图执行指定的操作,并提供其顺序索引。 |
运算符 View |
ViewGroup.get(index: Int)
返回索引处的视图。 |
Boolean |
ViewGroup.isEmpty()
如果该视图组不包含任何视图,则返回 true。 |
Boolean |
ViewGroup.isNotEmpty()
如果该视图组包含一个或多个视图,则返回 true。 |
运算符 MutableIterator<View> |
ViewGroup.iterator()
针对该视图组中的视图返回 MutableIterator。 |
运算符 Unit |
ViewGroup.minusAssign(view: View)
从该视图组中移除视图。 |
运算符 Unit |
ViewGroup.plusAssign(view: View)
向该视图组添加视图。 |
对于 android.view.ViewGroup.MarginLayoutParams
Unit |
MarginLayoutParams.setMargins(@Px size: Int)
在 ViewGroup 的 MarginLayoutParams 中设置外边距。 |
Unit |
MarginLayoutParams.updateMargins(@Px left: Int = leftMargin, @Px top: Int = topMargin, @Px right: Int = rightMargin, @Px bottom: Int = bottomMargin)
在 ViewGroup 的 ViewGroup.MarginLayoutParams 中更新外边距。 |
Unit |
MarginLayoutParams.updateMarginsRelative(@Px start: Int = marginStart, @Px top: Int = topMargin, @Px end: Int = marginEnd, @Px bottom: Int = bottomMargin)
在 ViewGroup 的 MarginLayoutParams 中更新相对外边距。 |
扩展属性
对于 android.view.Menu
Sequence<MenuItem> |
Menu.children()
针对此菜单中的项返回一个序列。 |
Int |
Menu.size()
返回此菜单中的项数。 |
对于 android.view.View
Boolean |
View.isGone()
当该视图的可见性为 View.GONE 时,返回 true,否则返回 false。 |
Boolean |
View.isInvisible()
当该视图的可见性为 View.INVISIBLE 时,返回 true,否则返回 false。 |
Boolean |
View.isVisible()
当该视图的可见性为 View.VISIBLE 时,返回 true,否则返回 false。 |
Int |
View.marginBottom()
如果该视图的 LayoutParams 为 ViewGroup.MarginLayoutParams,则返回下外边距,否则返回 0。 |
Int |
View.marginEnd()
如果该视图的 LayoutParams 为 ViewGroup.MarginLayoutParams,则返回末端外边距,否则返回 0。 |
Int |
View.marginLeft()
如果该视图的 LayoutParams 为 ViewGroup.MarginLayoutParams,则返回左外边距,否则返回 0。 |
Int |
View.marginRight()
如果该视图的 LayoutParams 为 ViewGroup.MarginLayoutParams,则返回右外边距,否则返回 0。 |
Int |
View.marginStart()
如果该视图的 LayoutParams 为 ViewGroup.MarginLayoutParams,则返回起始外边距,否则返回 0。 |
Int |
View.marginTop()
如果该视图的 LayoutParams 为 ViewGroup.MarginLayoutParams,则返回上外边距,否则返回 0。 |
对于 android.view.ViewGroup
Sequence<View> |
ViewGroup.children()
针对该视图组中的子视图返回一个序列。 |
Int |
ViewGroup.size()
返回该视图组中的视图数。 |
androidx.core.widget
依赖项
Groovy
dependencies { implementation "androidx.core:core-ktx:1.13.1" }
Kotlin
dependencies { implementation("androidx.core:core-ktx:1.13.1") }
扩展函数
对于 android.widget.TextView
TextWatcher |
TextView.addTextChangedListener(crossinline beforeTextChanged: (text: CharSequence?, start: Int, count: Int, after: Int) -> Unit = { _, _, _, _ -> }, crossinline onTextChanged: (text: CharSequence?, start: Int, count: Int, after: Int) -> Unit = { _, _, _, _ -> }, crossinline afterTextChanged: (text: Editable?) -> Unit = {})
使用提供的操作为此 TextView 添加文本更改监听器 |
TextWatcher |
TextView.doAfterTextChanged(crossinline action: (text: Editable?) -> Unit)
添加将在文本更改后调用的操作。 |
TextWatcher |
TextView.doBeforeTextChanged(crossinline action: (text: CharSequence?, start: Int, count: Int, after: Int) -> Unit)
添加将在文本更改之前调用的操作。 |
TextWatcher |
TextView.doOnTextChanged(crossinline action: (text: CharSequence?, start: Int, count: Int, after: Int) -> Unit)
添加将在文本更改时调用的操作。 |
androidx.dynamicanimation.animation
依赖项
Groovy
dependencies { implementation "androidx.dynamicanimation:dynamicanimation-ktx:1.1.0-alpha03" }
Kotlin
dependencies { implementation("androidx.dynamicanimation:dynamicanimation-ktx:1.1.0-alpha03") }
扩展函数
对于 SpringAnimation
SpringAnimation |
SpringAnimation.withSpringForceProperties(func: SpringForce.() -> Unit)
在 SpringAnimation 上更新或应用 SpringForce.mDampingRatio、SpringForce.mFinalPosition 和刚度等弹簧弹力属性。 |
顶级函数
FlingAnimation |
flingAnimationOf(setter: (Float) -> Unit, getter: () -> Float)
针对可通过提供的 setter 和 getter 访问的属性创建 FlingAnimation。 |
SpringAnimation |
springAnimationOf(setter: (Float) -> Unit, getter: () -> Float, finalPosition: Float = Float.NaN)
针对可通过提供的 setter 和 getter 访问的属性创建 SpringAnimation。 |
androidx.fragment.app
依赖项
Groovy
dependencies { implementation "androidx.fragment:fragment-ktx:1.6.2" }
Kotlin
dependencies { implementation("androidx.fragment:fragment-ktx:1.6.2") }
扩展函数
对于 android.view.View
F |
View.findFragment()
|
对于 Fragment
Lazy<VM> |
Fragment.activityViewModels(noinline factoryProducer: () -> ViewModelProvider.Factory = null)
返回一个属性委托以访问父级 Activity 的 ViewModel。如果已指定 factoryProducer,则它返回的 ViewModelProvider.Factory 将用于首次创建 ViewModel。 |
Lazy<VM> |
Fragment.createViewModelLazy(viewModelClass: KClass<VM>, storeProducer: () -> ViewModelStore, factoryProducer: () -> ViewModelProvider.Factory = null)
用于创建 ViewModelLazy 的辅助程序方法,会将作为 factoryProducer 传递的 |
Lazy<VM> |
Fragment.viewModels(noinline ownerProducer: () -> ViewModelStoreOwner = { this }, noinline factoryProducer: () -> ViewModelProvider.Factory = null)
|
对于 FragmentTransaction
FragmentTransaction |
FragmentTransaction.add(@IdRes containerViewId: Int, tag: String? = null, args: Bundle? = null)
将 Fragment 添加到关联的 FragmentManager 中,同时将 Fragment 的视图扩充到由 containerViewId 指定的容器视图中,以便稍后通过 FragmentManager.findFragmentById 进行检索。 |
FragmentTransaction |
FragmentTransaction.add(tag: String, args: Bundle? = null)
将 Fragment 添加到关联的 FragmentManager 中,而无需将 Fragment 添加到任何容器视图中。 |
FragmentTransaction |
FragmentTransaction.replace(@IdRes containerViewId: Int, tag: String? = null, args: Bundle? = null)
替换添加到容器中的现有 Fragment。 |
对于 FragmentManager
Unit |
FragmentManager.commit(allowStateLoss: Boolean = false, body: FragmentTransaction.() -> Unit)
在 FragmentTransaction 中运行 body,如果顺利完成,则系统将自动提交该对象。 |
Unit |
FragmentManager.commitNow(allowStateLoss: Boolean = false, body: FragmentTransaction.() -> Unit)
在 FragmentTransaction 中运行 body,如果顺利完成,则系统将自动提交该对象。 |
Unit |
FragmentManager.transaction(now: Boolean = false, allowStateLoss: Boolean = false, body: FragmentTransaction.() -> Unit)
在 FragmentTransaction 中运行 body,如果顺利完成,则系统将自动提交该对象。 |
androidx.fragment.app.testing
依赖项
Groovy
dependencies { implementation "androidx.fragment:fragment-testing:1.6.2" }
Kotlin
dependencies { implementation("androidx.fragment:fragment-testing:1.6.2") }
顶级函数
FragmentScenario<F!> |
launchFragment(fragmentArgs: Bundle? = null, @StyleRes themeResId: Int = R.style.FragmentScenarioEmptyFragmentActivityTheme, factory: FragmentFactory? = null)
使用指定的 FragmentFactory 启动具有由空 FragmentActivity 托管的指定参数的 Fragment,并等待其达到“已恢复”状态。 |
FragmentScenario<F!> |
launchFragment(fragmentArgs: Bundle? = null, @StyleRes themeResId: Int = R.style.FragmentScenarioEmptyFragmentActivityTheme, crossinline instantiate: () -> F)
使用实例化启动具有由空 FragmentActivity 托管的指定参数的 Fragment,以创建 Fragment,并等待其达到“已恢复”状态。 |
FragmentScenario<F!> |
launchFragmentInContainer(fragmentArgs: Bundle? = null, @StyleRes themeResId: Int = R.style.FragmentScenarioEmptyFragmentActivityTheme, factory: FragmentFactory? = null)
在 Activity 的根视图容器 |
FragmentScenario<F!> |
launchFragmentInContainer(fragmentArgs: Bundle? = null, @StyleRes themeResId: Int = R.style.FragmentScenarioEmptyFragmentActivityTheme, crossinline instantiate: () -> F)
使用实例化在 Activity 的根视图容器 |
androidx.lifecycle
依赖项
Groovy
dependencies { implementation "androidx.lifecycle:lifecycle-livedata-core-ktx:2.6.2" implementation "androidx.lifecycle:lifecycle-livedata-ktx:2.6.2" implementation "androidx.lifecycle:lifecycle-reactivestreams-ktx:2.6.2" implementation "androidx.lifecycle:lifecycle-runtime-ktx:2.6.2" implementation "androidx.lifecycle:lifecycle-viewmodel-ktx:2.6.2" }
Kotlin
dependencies { implementation("androidx.lifecycle:lifecycle-livedata-core-ktx:2.6.2") implementation("androidx.lifecycle:lifecycle-livedata-ktx:2.6.2") implementation("androidx.lifecycle:lifecycle-reactivestreams-ktx:2.6.2") implementation("androidx.lifecycle:lifecycle-runtime-ktx:2.6.2") implementation("androidx.lifecycle:lifecycle-viewmodel-ktx:2.6.2") }
扩展函数
对于 kotlinx.coroutines.flow.Flow
LiveData<T> |
Flow<T>.asLiveData(context: CoroutineContext = EmptyCoroutineContext, timeoutInMs: Long = DEFAULT_TIMEOUT)
创建一个 LiveData,其中包含从原始流收集的值。 |
LiveData<T> |
Flow<T>.asLiveData(context: CoroutineContext = EmptyCoroutineContext, timeout: Duration)
创建一个 LiveData,其中包含从原始流收集的值。 |
对于 org.reactivestreams.Publisher
LiveData<T> |
Publisher<T>.toLiveData()
|
对于 LiveData
Flow<T> |
LiveData<T>.asFlow()
创建一个流。其中包含由原始 LiveData 分派的值:首先,流收集器接收由 LiveData 持有的最新值,然后观察 LiveData 更新。 |
LiveData<X> |
LiveData<X>.distinctUntilChanged()
创建一个新的 LiveData 对象,该对象在源 |
LiveData<Y> |
LiveData<X>.map(crossinline transform: (X) -> Y)
将转换应用于在 |
Observer<T> |
LiveData<T>.observe(owner: LifecycleOwner, crossinline onChanged: (T) -> Unit)
|
LiveData<Y> |
LiveData<X>.switchMap(crossinline transform: (X) -> LiveData<Y>)
|
Publisher<T> |
LiveData<T>.toPublisher(lifecycle: LifecycleOwner)
|
对于 ViewModelProvider
VM |
ViewModelProvider.get()
返回现有的 ViewModel,或者在相应范围(通常为 Fragment 或 Activity)内创建一个与此 |
对于 LifecycleOwner
suspend T |
LifecycleOwner.whenCreated(block: suspend CoroutineScope.() -> T)
当 LifecycleOwner 的生命周期至少处于 Lifecycle.State.CREATED 状态时,运行指定的 block。 |
suspend T |
LifecycleOwner.whenResumed(block: suspend CoroutineScope.() -> T)
当 LifecycleOwner 的生命周期至少处于 Lifecycle.State.RESUMED 状态时,运行指定的 block。 |
suspend T |
LifecycleOwner.whenStarted(block: suspend CoroutineScope.() -> T)
当 LifecycleOwner 的生命周期至少处于 Lifecycle.State.STARTED 状态时,运行指定的 block。 |
对于 Lifecycle
suspend T |
Lifecycle.whenCreated(block: suspend CoroutineScope.() -> T)
当生命周期至少处于 Lifecycle.State.CREATED 状态时,运行指定的 block。 |
suspend T |
Lifecycle.whenResumed(block: suspend CoroutineScope.() -> T)
当生命周期至少处于 Lifecycle.State.RESUMED 状态时,运行指定的 block。 |
suspend T |
Lifecycle.whenStarted(block: suspend CoroutineScope.() -> T)
当生命周期至少处于 Lifecycle.State.STARTED 状态时,运行指定的 block。 |
suspend T |
Lifecycle.whenStateAtLeast(minState: Lifecycle.State, block: suspend CoroutineScope.() -> T)
在能够在主线程上执行相应 block 的 CoroutineDispatcher 上运行指定的 block,并且仅当生命周期的状态至少处于 minState 时才执行该 block。 |
扩展属性
对于 Lifecycle
LifecycleCoroutineScope |
Lifecycle.coroutineScope()
CoroutineScope 与该生命周期相关联。 |
对于 LifecycleOwner
LifecycleCoroutineScope |
LifecycleOwner.lifecycleScope()
CoroutineScope 与该 LifecycleOwner 的生命周期相关联。 |
对于 ViewModel
CoroutineScope |
ViewModel.viewModelScope()
CoroutineScope 与该 ViewModel 相关联。 |
顶级函数
LiveData<T> |
liveData(context: CoroutineContext = EmptyCoroutineContext, timeoutInMs: Long = DEFAULT_TIMEOUT, block: suspend LiveDataScope<T>.() -> Unit)
构建一个 LiveData,其中包含从在 LiveDataScope 上执行的指定 block 中获取的值。 |
LiveData<T> |
liveData(context: CoroutineContext = EmptyCoroutineContext, timeout: Duration, block: suspend LiveDataScope<T>.() -> Unit)
构建一个 LiveData,其中包含从在 LiveDataScope 上执行的指定 block 中获取的值。 |
androidx.navigation
依赖项
Groovy
dependencies { implementation "androidx.navigation:navigation-runtime-ktx:2.7.5" implementation "androidx.navigation:navigation-fragment-ktx:2.7.5" implementation "androidx.navigation:navigation-ui-ktx:2.7.5" }
Kotlin
dependencies { implementation("androidx.navigation:navigation-runtime-ktx:2.7.5") implementation("androidx.navigation:navigation-fragment-ktx:2.7.5") implementation("androidx.navigation:navigation-ui-ktx:2.7.5") }
扩展函数
对于 android.app.Activity
NavController |
Activity.findNavController(@IdRes : Int)
根据视图 ID 及其包含的 Activity 查找 NavController。 |
NavArgsLazy<Args> |
Activity.navArgs()
返回一个延迟委托,以便访问 Activity 的额外项作为 Args 实例。 |
对于 android.view.View
NavController |
View.findNavController()
查找与视图相关联的 NavController。 |
对于 NavGraphBuilder
Unit |
NavGraphBuilder.activity(@IdRes : Int, : ActivityNavigatorDestinationBuilder.() -> Unit)
|
Unit |
NavGraphBuilder.navigation(@IdRes : Int, @IdRes : Int, : NavGraphBuilder.() -> Unit)
构造一个嵌套的 NavGraph |
对于 NavGraph
运算符 Boolean |
NavGraph.contains(@IdRes : Int)
如果在该导航图中找到了具有 |
运算符 NavDestination |
NavGraph.get(@IdRes : Int)
返回具有 |
运算符 Unit |
NavGraph.minusAssign(: NavDestination)
从该导航图中移除 |
运算符 Unit |
NavGraph.plusAssign(: NavDestination)
向该 NavGraph 添加目的地。 |
运算符 Unit |
NavGraph.plusAssign(: NavGraph)
将其他集合中的所有目的地均添加到该集合中。 |
对于 NavController
NavGraph |
NavController.createGraph(@IdRes : Int = 0, @IdRes : Int, : NavGraphBuilder.() -> Unit)
构造一个新的 NavGraph |
对于 NavHost
NavGraph |
NavHost.createGraph(@IdRes : Int = 0, @IdRes : Int, : NavGraphBuilder.() -> Unit)
构造一个新的 NavGraph |
对于 NavigatorProvider
运算符 T |
NavigatorProvider.get(: String)
按名称检索已注册的导航器。 |
运算符 T |
NavigatorProvider.get(: KClass<T>)
使用由 Navigator.Name annotation 提供的名称检索已注册的导航器。 |
NavGraph |
NavigatorProvider.navigation(@IdRes : Int = 0, @IdRes : Int, : NavGraphBuilder.() -> Unit)
构造一个新的 NavGraph |
运算符 Unit |
NavigatorProvider.plusAssign(: Navigator<out NavDestination>)
使用由 Navigator.Name annotation 提供的名称注册导航器。 |
运算符 Navigator<out NavDestination!>? |
NavigatorProvider.set(: String, : Navigator<out NavDestination>)
按名称注册导航器。 |
对于 Fragment
Lazy<VM> |
Fragment.navGraphViewModels(@IdRes : Int, noinline : () -> ViewModelProvider.Factory = null)
返回一个属性委托,以便访问范围限定为在 {@link NavController} 返回堆栈上显示的导航图的 ViewModel: |
顶级函数
ActivityNavigator.Extras |
ActivityNavigatorExtras(: ActivityOptionsCompat? = null, : Int = 0)
使用特定的 ActivityOptionsCompat 实例和/或任何 |
NavOptions |
navOptions(: NavOptionsBuilder.() -> Unit)
构造一个新的 NavOptions |
androidx.navigation.fragment
依赖项
Groovy
dependencies { implementation "androidx.navigation:navigation-fragment-ktx:2.7.5" }
Kotlin
dependencies { implementation("androidx.navigation:navigation-fragment-ktx:2.7.5") }
扩展函数
对于 NavGraphBuilder
Unit |
NavGraphBuilder.dialog(@IdRes : Int)
|
Unit |
NavGraphBuilder.dialog(@IdRes : Int, : DialogFragmentNavigatorDestinationBuilder.() -> Unit)
|
Unit |
NavGraphBuilder.fragment(@IdRes : Int)
|
Unit |
NavGraphBuilder.fragment(@IdRes : Int, : FragmentNavigatorDestinationBuilder.() -> Unit)
|
对于 Fragment
NavController |
Fragment.findNavController()
根据 Fragment 查找 NavController |
NavArgsLazy<Args> |
Fragment.navArgs()
返回一个延迟委托,以便访问 Fragment 的参数作为 Args 实例。 |
顶级函数
FragmentNavigator.Extras |
FragmentNavigatorExtras(vararg : Pair<View, String>)
使用指定的共享元素创建新的 FragmentNavigator.Extras 实例 |
androidx.navigation.ui
依赖项
Groovy
dependencies { implementation "androidx.navigation:navigation-ui-ktx:2.7.5" }
Kotlin
dependencies { implementation("androidx.navigation:navigation-ui-ktx:2.7.5") }
扩展函数
对于 android.view.MenuItem
Boolean |
MenuItem.onNavDestinationSelected(: NavController)
尝试转到与该 MenuItem 相关联的 NavDestination。 |
对于 androidx.appcompat.app.AppCompatActivity
Unit |
AppCompatActivity.setupActionBarWithNavController(: NavController, : DrawerLayout?)
设置由 AppCompatActivity.getSupportActionBar 返回的 ActionBar,以便与 NavController 配合使用。 |
Unit |
AppCompatActivity.setupActionBarWithNavController(: NavController, : AppBarConfiguration = AppBarConfiguration(navController.graph))
设置由 AppCompatActivity.getSupportActionBar 返回的 ActionBar,以便与 NavController 配合使用。 |
对于 androidx.appcompat.widget.Toolbar
Unit |
Toolbar.setupWithNavController(: NavController, : DrawerLayout?)
设置工具栏,以便与 NavController 配合使用。 |
Unit |
Toolbar.setupWithNavController(: NavController, : AppBarConfiguration = AppBarConfiguration(navController.graph))
设置工具栏,以便与 NavController 配合使用。 |
对于 com.google.android.material.appbar.CollapsingToolbarLayout
Unit |
CollapsingToolbarLayout.setupWithNavController(: Toolbar, : NavController, : DrawerLayout?)
设置 CollapsingToolbarLayout 和工具栏,以便与 NavController 配合使用。 |
Unit |
CollapsingToolbarLayout.setupWithNavController(: Toolbar, : NavController, : AppBarConfiguration = AppBarConfiguration(navController.graph))
设置 CollapsingToolbarLayout 和工具栏,以便与 NavController 配合使用。 |
对于 com.google.android.material.bottomnavigation.BottomNavigationView
Unit |
BottomNavigationView.setupWithNavController(: NavController)
设置 BottomNavigationView,以便与 NavController 配合使用。 |
对于 com.google.android.material.navigation.NavigationView
Unit |
NavigationView.setupWithNavController(: NavController)
设置 NavigationView,以便与 NavController 配合使用。 |
对于 NavController
Boolean |
NavController.navigateUp(: DrawerLayout?)
通过将“向上”按钮的行为委托给指定的 NavController 来处理该按钮。 |
Boolean |
NavController.navigateUp(: AppBarConfiguration)
通过将“向上”按钮的行为委托给指定的 NavController 来处理该按钮。 |
顶级函数
AppBarConfiguration |
AppBarConfiguration(: NavGraph, : DrawerLayout? = null, noinline : () -> Boolean = { false })
与应用栏模式的实现进行互动的 NavigationUI 方法的配置选项,例如 android.support.v7.widget.Toolbar、android.support.design.widget .CollapsingToolbarLayout 和 android.support.v7.app.ActionBar。 |
AppBarConfiguration |
AppBarConfiguration(: Menu, : DrawerLayout? = null, noinline : () -> Boolean = { false })
与应用栏模式的实现进行互动的 NavigationUI 方法的配置选项,例如 android.support.v7.widget.Toolbar、android.support.design.widget .CollapsingToolbarLayout 和 android.support.v7.app.ActionBar。 |
AppBarConfiguration |
AppBarConfiguration(: Set<Int>, : DrawerLayout? = null, noinline : () -> Boolean = { false })
与应用栏模式的实现进行互动的 NavigationUI 方法的配置选项,例如 android.support.v7.widget.Toolbar、android.support.design.widget .CollapsingToolbarLayout 和 android.support.v7.app.ActionBar。 |
androidx.paging
依赖项
Groovy
dependencies { implementation "androidx.paging:paging-common-ktx:2.1.2" implementation "androidx.paging:paging-runtime-ktx:2.1.2" implementation "androidx.paging:paging-rxjava2-ktx:2.1.2" }
Kotlin
dependencies { implementation("androidx.paging:paging-common-ktx:2.1.2") implementation("androidx.paging:paging-runtime-ktx:2.1.2") implementation("androidx.paging:paging-rxjava2-ktx:2.1.2") }
扩展函数
对于 Factory
Flowable<PagedList<Value>> |
DataSource.Factory<Key, Value>.toFlowable(config: PagedList.Config, initialLoadKey: Key? = null, boundaryCallback: PagedList.BoundaryCallback<Value>? = null, fetchScheduler: Scheduler? = null, notifyScheduler: Scheduler? = null, backpressureStrategy: BackpressureStrategy = BackpressureStrategy.LATEST)
从该 |
Flowable<PagedList<Value>> |
DataSource.Factory<Key, Value>.toFlowable(pageSize: Int, initialLoadKey: Key? = null, boundaryCallback: PagedList.BoundaryCallback<Value>? = null, fetchScheduler: Scheduler? = null, notifyScheduler: Scheduler? = null, backpressureStrategy: BackpressureStrategy = BackpressureStrategy.LATEST)
从该 |
LiveData<PagedList<Value>> |
DataSource.Factory<Key, Value>.toLiveData(config: PagedList.Config, initialLoadKey: Key? = null, boundaryCallback: PagedList.BoundaryCallback<Value>? = null, fetchExecutor: Executor = ArchTaskExecutor.getIOThreadExecutor())
从该 |
LiveData<PagedList<Value>> |
DataSource.Factory<Key, Value>.toLiveData(pageSize: Int, initialLoadKey: Key? = null, boundaryCallback: PagedList.BoundaryCallback<Value>? = null, fetchExecutor: Executor = ArchTaskExecutor.getIOThreadExecutor())
从该 |
Observable<PagedList<Value>> |
DataSource.Factory<Key, Value>.toObservable(config: PagedList.Config, initialLoadKey: Key? = null, boundaryCallback: PagedList.BoundaryCallback<Value>? = null, fetchScheduler: Scheduler? = null, notifyScheduler: Scheduler? = null)
从该 |
Observable<PagedList<Value>> |
DataSource.Factory<Key, Value>.toObservable(pageSize: Int, initialLoadKey: Key? = null, boundaryCallback: PagedList.BoundaryCallback<Value>? = null, fetchScheduler: Scheduler? = null, notifyScheduler: Scheduler? = null)
从该 |
顶级函数
PagedList.Config |
Config(pageSize: Int, prefetchDistance: Int = pageSize, enablePlaceholders: Boolean = true, initialLoadSizeHint: Int = pageSize * PagedList.Config.Builder.DEFAULT_INITIAL_PAGE_MULTIPLIER, maxSize: Int = PagedList.Config.MAX_SIZE_UNBOUNDED)
构造一个 PagedList.Config,从而为 PagedList.Config.Builder 提供便利。 |
PagedList<Value> |
PagedList(dataSource: DataSource<Key, Value>, config: PagedList.Config, notifyExecutor: Executor, fetchExecutor: Executor, boundaryCallback: PagedList.BoundaryCallback<Value>? = null, initialKey: Key? = null)
构造一个 PagedList,从而为 PagedList.Builder 提供便利。 |
androidx.palette.graphics
依赖项
Groovy
dependencies { implementation "androidx.palette:palette-ktx:1.0.0" }
Kotlin
dependencies { implementation("androidx.palette:palette-ktx:1.0.0") }
扩展函数
对于 Palette
运算符 Palette.Swatch? |
Palette.get(target: Target)
从调色板返回指定目标的选定色样,如果未找到,则返回 |
androidx.preference
依赖项
Groovy
dependencies { implementation "androidx.preference:preference-ktx:1.2.1" }
Kotlin
dependencies { implementation("androidx.preference:preference-ktx:1.2.1") }
扩展函数
对于 PreferenceGroup
运算符 Boolean |
PreferenceGroup.contains(preference: Preference)
如果在该偏好设置组中找到 |
Unit |
PreferenceGroup.forEach(action: (preference: Preference) -> Unit)
针对该偏好设置组中的每个偏好设置执行指定的操作。 |
Unit |
PreferenceGroup.forEachIndexed(action: (index: Int, preference: Preference) -> Unit)
针对该偏好设置组中的每个偏好设置执行指定的操作,并提供其顺序索引。 |
运算符 T? |
PreferenceGroup.get(key: CharSequence)
返回具有 |
运算符 Preference |
PreferenceGroup.get(index: Int)
返回 |
Boolean |
PreferenceGroup.isEmpty()
如果该偏好设置组中未包含任何偏好设置,则返回 true。 |
Boolean |
PreferenceGroup.isNotEmpty()
如果该偏好设置组中包含一个或多个偏好设置,则返回 true。 |
运算符 MutableIterator<Preference> |
PreferenceGroup.iterator()
针对该偏好设置组中的偏好设置返回 MutableIterator。 |
运算符 Unit |
PreferenceGroup.minusAssign(preference: Preference)
从该偏好设置组中移除 |
运算符 Unit |
PreferenceGroup.plusAssign(preference: Preference)
向该偏好设置组中添加 |
扩展属性
对于 PreferenceGroup
Sequence<Preference> |
PreferenceGroup.children()
针对该偏好设置组中的偏好设置返回序列。 |
Int |
PreferenceGroup.size()
返回该偏好设置组中的偏好设置数量。 |
androidx.room
依赖项
Groovy
dependencies { implementation "androidx.room:room-ktx:2.6.1" }
Kotlin
dependencies { implementation("androidx.room:room-ktx:2.6.1") }
扩展函数
对于 RoomDatabase
suspend R |
RoomDatabase.withTransaction(block: suspend () -> R)
在数据库事务中调用指定的挂起 block。 |
androidx.slice.builders
依赖项
Groovy
dependencies { implementation "androidx.slice:slice-builders-ktx:1.0.0-alpha08" }
Kotlin
dependencies { implementation("androidx.slice:slice-builders-ktx:1.0.0-alpha08") }
扩展函数
对于 GridRowBuilderDsl
GridRowBuilder |
GridRowBuilderDsl.cell(buildCell: CellBuilderDsl.() -> Unit)
|
GridRowBuilder |
GridRowBuilderDsl.seeMoreCell(buildCell: CellBuilderDsl.() -> Unit)
|
对于 ListBuilderDsl
ListBuilder |
ListBuilderDsl.gridRow(buildGrid: GridRowBuilderDsl.() -> Unit)
|
ListBuilder |
ListBuilderDsl.header(buildHeader: HeaderBuilderDsl.() -> Unit)
|
ListBuilder |
ListBuilderDsl.inputRange(buildInputRange: InputRangeBuilderDsl.() -> Unit)
|
ListBuilder |
ListBuilderDsl.range(buildRange: RangeBuilderDsl.() -> Unit)
|
ListBuilder |
ListBuilderDsl.row(buildRow: RowBuilderDsl.() -> Unit)
|
ListBuilder |
ListBuilderDsl.seeMoreRow(buildRow: RowBuilderDsl.() -> Unit)
|
顶级函数
Slice |
list(context: Context, uri: Uri, ttl: Long, addRows: ListBuilderDsl.() -> Unit)
降低在 Kotlin 中构建切片所需的详细程度。 |
SliceAction |
tapSliceAction(pendingIntent: PendingIntent, icon: IconCompat, imageMode: Int = ICON_IMAGE, title: CharSequence)
用于构建可点按的 SliceAction 的工厂方法。 |
SliceAction |
toggleSliceAction(pendingIntent: PendingIntent, icon: IconCompat? = null, title: CharSequence, isChecked: Boolean)
用于构建可切换的 SliceAction 的工厂方法。 |
androidx.sqlite.db
依赖项
Groovy
dependencies { implementation "androidx.sqlite:sqlite-ktx:2.4.0" }
Kotlin
dependencies { implementation("androidx.sqlite:sqlite-ktx:2.4.0") }
扩展函数
对于 SupportSQLiteDatabase
T |
SupportSQLiteDatabase.transaction(exclusive: Boolean = true, body: SupportSQLiteDatabase.() -> T)
在事务中运行 body,如果顺利完成,则将其标记为“成功”。 |
androidx.work
依赖项
扩展函数
对于 com.google.common.util.concurrent.ListenableFuture
suspend R |
ListenableFuture<R>.await()
等待 ListenableFuture 完成,而无需屏蔽线程。 |
对于 Operation
suspend Operation.State.SUCCESS! |
Operation.await()
等待操作,而无需屏蔽线程。 |
对于 Data
Boolean |
Data.hasKeyWithValueOfType(key: String)
|
对于 Builder
OneTimeWorkRequest.Builder |
OneTimeWorkRequest.Builder.setInputMerger(@NonNull inputMerger: KClass<out InputMerger>)
|
顶级函数
OneTimeWorkRequest.Builder |
OneTimeWorkRequestBuilder()
使用指定的 ListenableWorker 创建一个 OneTimeWorkRequest。 |
PeriodicWorkRequest.Builder |
PeriodicWorkRequestBuilder(repeatInterval: Long, repeatIntervalTimeUnit: TimeUnit)
使用指定的 ListenableWorker 创建一个 PeriodicWorkRequest.Builder。 |
PeriodicWorkRequest.Builder |
PeriodicWorkRequestBuilder(repeatInterval: Duration)
使用指定的 ListenableWorker 创建一个 PeriodicWorkRequest.Builder。 |
PeriodicWorkRequest.Builder |
PeriodicWorkRequestBuilder(repeatInterval: Long, repeatIntervalTimeUnit: TimeUnit, flexTimeInterval: Long, flexTimeIntervalUnit: TimeUnit)
使用指定的 ListenableWorker 创建一个 PeriodicWorkRequest.Builder。 |
PeriodicWorkRequest.Builder |
PeriodicWorkRequestBuilder(repeatInterval: Duration, flexTimeInterval: Duration)
使用指定的 ListenableWorker 创建一个 PeriodicWorkRequest.Builder。 |
Data |
workDataOf(vararg pairs: Pair<String, Any?>)
将键值对列表转换为 Data 对象。 |
androidx.work.testing
依赖项
Groovy
dependencies { implementation "androidx.work:work-testing:2.9.0" }
Kotlin
dependencies { implementation("androidx.work:work-testing:2.9.0") }
顶级函数
TestListenableWorkerBuilder<W> |
TestListenableWorkerBuilder(context: Context, inputData: Data = Data.EMPTY, tags: List<String> = emptyList(), runAttemptCount: Int = 1, triggeredContentUris: List<Uri> = emptyList(), triggeredContentAuthorities: List<String> = emptyList())
构建 TestListenableWorkerBuilder 的实例。 |
TestWorkerBuilder<W> |
TestWorkerBuilder(context: Context, executor: Executor, inputData: Data = Data.EMPTY, tags: List<String> = emptyList(), runAttemptCount: Int = 1, triggeredContentUris: List<Uri> = emptyList(), triggeredContentAuthorities: List<String> = emptyList())
构建 TestWorkerBuilder 的实例。 |
com.google.android.play.core.ktx
依赖项
Groovy
dependencies { implementation "com.google.android.play:core-ktx:1.8.1" }
Kotlin
dependencies { implementation("com.google.android.play:core-ktx:1.8.1") }
扩展函数
对于 com.google.android.play.core.appupdate.AppUpdateManager
suspend AppUpdateInfo |
AppUpdateManager.requestAppUpdateInfo()
请求当前应用的更新可用性 |
suspend Unit |
AppUpdateManager.requestCompleteUpdate()
针对灵活更新流程,触发完成更新。 |
Flow<AppUpdateResult> |
AppUpdateManager.requestUpdateFlow()
入口点,用于监控更新的可用性和进度。 |
Boolean |
AppUpdateManager.startUpdateFlowForResult(appUpdateInfo: AppUpdateInfo, appUpdateType: Int, fragment: Fragment, requestCode: Int)
AppUpdateManager.startUpdateFlowForResult 的一个版本,可接受 AndroidX Fragment 以返回结果。 |
对于 com.google.android.play.core.splitinstall.SplitInstallManager
扩展属性
对于 com.google.android.play.core.appupdate.AppUpdateInfo
Int |
AppUpdateInfo.installStatus()
返回更新的进度状态。 |
Boolean |
AppUpdateInfo.isFlexibleUpdateAllowed()
如果允许进行灵活更新,则返回 |
Boolean |
AppUpdateInfo.isImmediateUpdateAllowed()
如果允许立即更新,则返回 |
对于 com.google.android.play.core.install.InstallState
Boolean |
InstallState.hasTerminalStatus()
这表明此为终端状态(不会再进行更新),并且应该进行相应处理(成功、取消或失败)。 |
Int |
InstallState.installErrorCode()
返回安装的错误代码,或 {@link InstallErrorCode#NO_ERROR}。 |
Int |
InstallState.installStatus()
返回安装的状态。 |
String! |
InstallState.packageName()
返回正在安装的应用的软件包名称。 |
对于 com.google.android.play.core.splitinstall.SplitInstallSessionState
Long |
SplitInstallSessionState.bytesDownloaded()
该更新所下载的字节数。 |
Int |
SplitInstallSessionState.errorCode()
该更新的错误代码。 |
Boolean |
SplitInstallSessionState.hasTerminalStatus()
表明该更新为终端状态,这意味着将不会再针对此会话进行更新。 |
List<String> |
SplitInstallSessionState.languages()
该更新包含的语言。 |
List<String> |
SplitInstallSessionState.moduleNames()
该更新包含的模块。 |
Int |
SplitInstallSessionState.sessionId()
该更新的会话 ID。 |
Int |
SplitInstallSessionState.status()
该更新的状态代码。 |
Long |
SplitInstallSessionState.totalBytesToDownload()
该更新要下载的总字节数。 |
顶级函数
SplitInstallStateUpdatedListener |
SplitInstallStateUpdatedListener(onRequiresConfirmation: (SplitInstallSessionState) -> Unit, onInstalled: (SplitInstallSessionState) -> Unit, onFailed: (SplitInstallSessionState) -> Unit = {}, onPending: (SplitInstallSessionState) -> Unit = {}, onDownloaded: (SplitInstallSessionState) -> Unit = {}, onDownloading: (SplitInstallSessionState) -> Unit = {}, onInstalling: (SplitInstallSessionState) -> Unit = {}, onCanceling: (SplitInstallSessionState) -> Unit = {}, onCanceled: (SplitInstallSessionState) -> Unit = {}, onNonTerminalStatus: (SplitInstallSessionState) -> Unit = {}, onTerminalStatus: (SplitInstallSessionState) -> Unit = {})
用于创建 SplitInstallStateUpdatedListener 的便捷函数。 |