mirror of
https://github.com/HighCapable/YukiHookAPI.git
synced 2025-09-04 09:45:19 +08:00
309 lines
4.9 KiB
Markdown
309 lines
4.9 KiB
Markdown
## YukiHookModulePrefs [class]
|
||
|
||
```kotlin
|
||
class YukiHookModulePrefs(private val context: Context?)
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0` `添加`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 实现 Xposed 模块的数据存取,对接 `SharedPreferences` 和 `XSharedPreferences`。
|
||
|
||
在不同环境智能选择存取使用的对象。
|
||
|
||
!> 请注意此功能为实验性功能,仅在 LSPosed 环境测试通过,EdXposed 理论也可以使用但不再推荐。
|
||
|
||
使用 LSPosed 环境请在 `AndroidManifests.xml` 中将 `xposedminversion` 最低设置为 `93`。
|
||
|
||
详见 [New XSharedPreferences](https://github.com/LSPosed/LSPosed/wiki/New-XSharedPreferences#for-the-module)。
|
||
|
||
未使用 LSPosed 环境请将你的模块 `API` 降至 `26` 以下,`YukiHookAPI` 将会尝试使用 `makeWorldReadable` 但仍有可能不成功。
|
||
|
||
太极请参阅 [文件权限/配置/XSharedPreference](https://taichi.cool/zh/doc/for-xposed-dev.html#文件权限-配置-xsharedpreference)。
|
||
|
||
!> 当你在 Xposed 模块中存取数据的时候 `context` 必须不能是空的。
|
||
|
||
### name [method]
|
||
|
||
```kotlin
|
||
fun name(name: String): YukiHookModulePrefs
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0` `添加`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 自定义 Sp 存储名称。
|
||
|
||
<b>功能示例</b>
|
||
|
||
在 `Activity` 中的使用方法。
|
||
|
||
> 示例如下
|
||
|
||
```kotlin
|
||
modulePrefs("custom_name").getString("custom_key")
|
||
```
|
||
|
||
在 Xposed 模块环境 `PackageParam` 中的使用方法。
|
||
|
||
> 示例如下
|
||
|
||
```kotlin
|
||
prefs("custom_name").getString("custom_key")
|
||
```
|
||
|
||
### direct [method]
|
||
|
||
```kotlin
|
||
fun direct(): YukiHookModulePrefs
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0.5` `新增`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 忽略缓存直接读取键值。
|
||
|
||
无论是否开启 `YukiHookAPI.Configs.isEnableModulePrefsCache`。
|
||
|
||
仅在 `XSharedPreferences` 下生效。
|
||
|
||
### getString [method]
|
||
|
||
```kotlin
|
||
fun getString(key: String, value: String): String
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0` `添加`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 获取 `String` 键值。
|
||
|
||
### getBoolean [method]
|
||
|
||
```kotlin
|
||
fun getBoolean(key: String, value: Boolean): Boolean
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0` `添加`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 获取 `Boolean` 键值。
|
||
|
||
### getInt [method]
|
||
|
||
```kotlin
|
||
fun getInt(key: String, value: Int): Int
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0` `添加`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 获取 `Int` 键值。
|
||
|
||
### getLong [method]
|
||
|
||
```kotlin
|
||
fun getLong(key: String, value: Long): Long
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0` `添加`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 获取 `Long` 键值。
|
||
|
||
### getFloat [method]
|
||
|
||
```kotlin
|
||
fun getFloat(key: String, value: Float): Float
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0` `添加`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 获取 `Float` 键值。
|
||
|
||
### remove [method]
|
||
|
||
```kotlin
|
||
fun remove(key: String)
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0` `添加`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 移除全部包含 `key` 的存储数据。
|
||
|
||
!> 在 `XSharedPreferences` 环境下只读,无法使用。
|
||
|
||
### remove [method]
|
||
|
||
```kotlin
|
||
inline fun <reified T> remove(prefs: PrefsData<T>)
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0.67` `新增`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 移除 `PrefsData.key` 的存储数据。
|
||
|
||
!> 在 `XSharedPreferences` 环境下只读,无法使用。
|
||
|
||
### putString [method]
|
||
|
||
```kotlin
|
||
fun putString(key: String, value: String)
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0` `添加`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 存储 `String` 键值。
|
||
|
||
!> 在 `XSharedPreferences` 环境下只读,无法使用。
|
||
|
||
### putBoolean [method]
|
||
|
||
```kotlin
|
||
fun putBoolean(key: String, value: Boolean)
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0` `添加`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 存储 `Boolean` 键值。
|
||
|
||
!> 在 `XSharedPreferences` 环境下只读,无法使用。
|
||
|
||
### putInt [method]
|
||
|
||
```kotlin
|
||
fun putInt(key: String, value: Int)
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0` `添加`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 存储 `Int` 键值。
|
||
|
||
!> 在 `XSharedPreferences` 环境下只读,无法使用。
|
||
|
||
### putLong [method]
|
||
|
||
```kotlin
|
||
fun putLong(key: String, value: Long)
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0` `添加`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 存储 `Long` 键值。
|
||
|
||
!> 在 `XSharedPreferences` 环境下只读,无法使用。
|
||
|
||
### putFloat [method]
|
||
|
||
```kotlin
|
||
fun putFloat(key: String, value: Float)
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0` `添加`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 存储 `Float` 键值。
|
||
|
||
!> 在 `XSharedPreferences` 环境下只读,无法使用。
|
||
|
||
### get [method]
|
||
|
||
```kotlin
|
||
inline fun <reified T> get(prefs: PrefsData<T>, value: T): T
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0.67` `新增`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 智能获取指定类型的键值。
|
||
|
||
### put [method]
|
||
|
||
```kotlin
|
||
inline fun <reified T> put(prefs: PrefsData<T>, value: T)
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0.67` `新增`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 智能存储指定类型的键值。
|
||
|
||
!> 在 `XSharedPreferences` 环境下只读,无法使用。
|
||
|
||
### clearCache [method]
|
||
|
||
```kotlin
|
||
fun clearCache()
|
||
```
|
||
|
||
<b>变更记录</b>
|
||
|
||
`v1.0.5` `新增`
|
||
|
||
<b>功能描述</b>
|
||
|
||
> 清除 `XSharedPreferences` 中缓存的键值数据。
|
||
|
||
无论是否开启 `YukiHookAPI.Configs.isEnableModulePrefsCache`。
|
||
|
||
调用此方法将清除当前存储的全部键值缓存。
|
||
|
||
下次将从 `XSharedPreferences` 重新读取。 |