SettingsActivity.kt深度解析

以下是 SettingsActivity.kt 文件中每一行代码的深度解析:


🧩 1. 类定义与生命周期

kotlin 复制代码
class SettingsActivity : AppCompatActivity() {
  • 说明 : 定义 SettingsActivity 类,继承自 AppCompatActivity,以支持 Material Design 风格和向后兼容性。
kotlin 复制代码
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
  • 说明 : 重写 onCreate() 方法,这是 Activity 的入口点。
  • super.onCreate(savedInstanceState) 调用父类方法,确保基础初始化逻辑执行。

🌗 2. 主题适配与状态栏颜色设置

kotlin 复制代码
        // Themes
        val themes = Themes(this)
        themes.applyDayNightOverride()
        setTheme(themes.getTheme())
  • 说明 :
    • 创建 Themes 实例,传入当前上下文 this
    • applyDayNightOverride() 强制应用当前主题(如深色或浅色模式)。
    • setTheme(themes.getTheme()) 设置当前 Activity 的主题样式。
kotlin 复制代码
        setContentView(R.layout.settings_activity)
kotlin 复制代码
        if (savedInstanceState == null) {
            supportFragmentManager
                    .beginTransaction()
                    .replace(R.id.settings, SettingsFragment())
                    .commit()
        }
  • 说明 :
    • 检查是否为首次创建(无保存实例状态)。
    • 使用 supportFragmentManager 开始一个 Fragment 事务。
    • 替换 R.id.settings 容器视图的内容为 SettingsFragment
    • commit() 提交事务以完成 Fragment 的加载。
kotlin 复制代码
        supportActionBar?.setDisplayHomeAsUpEnabled(true)
  • 说明: 显示返回按钮(HomeAsUp),方便用户返回上一级。
kotlin 复制代码
        // Change the status bar color
        if (MyPreferences(this).theme == 1) { // Amoled theme
            window.statusBarColor = ContextCompat.getColor(this, R.color.amoled_background_color)
        } else {
            window.statusBarColor = ContextCompat.getColor(this, R.color.background_color)
        }
  • 说明 :
    • 使用 MyPreferences 获取用户选择的主题 ID。
    • 如果是 Amoled 主题 (theme == 1),则使用黑色背景作为状态栏颜色。
    • 否则使用默认背景色。
    • ContextCompat.getColor() 确保在不同 API 版本上都能正确获取颜色资源。
kotlin 复制代码
        // back button
        findViewById<ImageView>(R.id.settings_back_button).setOnClickListener {
            finish()
        }
  • 说明 :
    • 找到 R.id.settings_back_button 对应的 ImageView。
    • 设置点击监听器,当用户点击时调用 finish() 关闭当前 Activity。

⚙️ 3. 设置项实现:SettingsFragment

✅ 初始化设置项

kotlin 复制代码
override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) {
    setPreferencesFromResource(R.xml.root_preferences, rootKey)
  • 说明 :
    • res/xml/root_preferences.xml 加载预设的设置项。
    • 这些设置项通常包含主题、语言、数字系统等选项。

🌍 语言设置

kotlin 复制代码
val appLanguagePreference = findPreference<Preference>("darkempire78.opencalculator.APP_LANGUAGE")
  • 说明 : 查找键为 "darkempire78.opencalculator.APP_LANGUAGE" 的 Preference。
kotlin 复制代码
// remove the app language button if you are using an Android version lower than v33 (Android 13)
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.TIRAMISU) {
    appLanguagePreference?.isVisible = false
} else {
    // Display the current selected language
    appLanguagePreference?.summary = Locale.getDefault().displayLanguage
}
  • 说明 :
    • 如果设备运行的是低于 Android 13(API 33)的版本,则隐藏语言设置项。
    • 否则显示当前系统的语言名称作为摘要。
kotlin 复制代码
// Select app language button
appLanguagePreference?.setOnPreferenceClickListener {
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) {
        launchChangeAppLanguageIntent()
    }
    true
}
  • 说明 :
    • 设置点击监听器,在 Android 13 及以上版本中调用 launchChangeAppLanguageIntent() 打开系统语言设置。

🎨 主题设置

kotlin 复制代码
// Theme button
val appThemePreference = findPreference<Preference>("darkempire78.opencalculator.APP_THEME_SELECTOR")
  • 说明 : 查找键为 "darkempire78.opencalculator.APP_THEME_SELECTOR" 的 Preference。
kotlin 复制代码
appThemePreference?.summary = Themes(this.requireContext()).getThemeNameFromId(
    MyPreferences(this.requireContext()).theme)
  • 说明: 获取当前主题名称并设置为摘要文本。
kotlin 复制代码
appThemePreference?.setOnPreferenceClickListener {
    Themes.openDialogThemeSelector(this.requireContext())
    true
}
  • 说明: 设置点击监听器,点击后弹出主题选择对话框。

🔢 数字系统设置

kotlin 复制代码
// Numbering System button
val appNumberingSystemPreference =
    findPreference<Preference>("darkempire78.opencalculator.NUMBERING_SYSTEM")
  • 说明 : 查找键为 "darkempire78.opencalculator.NUMBERING_SYSTEM" 的 Preference。
kotlin 复制代码
appNumberingSystemPreference?.summary =
    NumberingSystem.getDescription(MyPreferences(this.requireContext()).numberingSystem)
  • 说明: 获取当前数字系统描述并设置为摘要文本。
kotlin 复制代码
appNumberingSystemPreference?.setOnPreferenceClickListener {
    openDialogNumberingSystemSelector(this.requireContext())
    true
}
  • 说明: 设置点击监听器,点击后弹出数字系统选择对话框。

💬 4. 对话框实现

✅ 数字系统选择对话框

kotlin 复制代码
private fun openDialogNumberingSystemSelector(context: Context) {

    val preferences = MyPreferences(context)

    val builder = MaterialAlertDialogBuilder(context)
    builder.background = ContextCompat.getDrawable(context, R.drawable.rounded)
  • 说明 :
    • 创建 MaterialAlertDialogBuilder 实例,并设置自定义背景。
kotlin 复制代码
    val numberingSystem = hashMapOf(
        0 to NumberingSystem.INTERNATIONAL.description,
        1 to NumberingSystem.INDIAN.description
    )
  • 说明: 创建数字系统映射表,包含国际格式和印度格式。
kotlin 复制代码
    val checkedItem = preferences.numberingSystem

    builder.setSingleChoiceItems(
        numberingSystem.values.toTypedArray(),
        checkedItem
    ) { dialog, which ->
        when (which) {
            0 -> {
                preferences.numberingSystem = 0
            }

            1 -> {
                preferences.numberingSystem = 1
            }
        }
        dialog.dismiss()
        reloadActivity(requireContext())
    }
  • 说明 :
    • 显示单选对话框,允许用户选择数字系统。
    • 用户选择后更新偏好设置,并调用 reloadActivity() 重启 Activity。
kotlin 复制代码
    val dialog = builder.create()
    dialog.show()
}
  • 说明: 创建并显示对话框。

🔁 重启 Activity

kotlin 复制代码
private fun reloadActivity(context: Context) {
    (context as Activity).finish()
    ContextCompat.startActivity(context, context.intent, null)
}
  • 说明 :
    • 结束当前 Activity。
    • 重新启动 Activity 以应用新的设置。

🌐 系统语言设置跳转

kotlin 复制代码
@RequiresApi(Build.VERSION_CODES.TIRAMISU)
fun launchChangeAppLanguageIntent() {
    try {
        Intent(Settings.ACTION_APP_LOCALE_SETTINGS).apply {
            data = Uri.fromParts("package", requireContext().packageName, null)
            startActivity(this)
        }
    } catch (e: Exception) {
        try {
            Intent(Settings.ACTION_APPLICATION_DETAILS_SETTINGS).apply {
                data = Uri.fromParts("package", requireContext().packageName, null)
                startActivity(this)
            }
        } catch (e: Exception) {
            println(e)
        }
    }
}
  • 说明 :
    • 构造一个 Intent,打开系统语言设置界面。
    • 如果失败,则尝试打开应用详情页。

总结

SettingsActivity.kt 文件实现了 OpenCalc 应用的设置功能,包括:

  • 多主题支持(深色、浅色、Amoled)
  • 语言设置(仅限 Android 13+)
  • 数字系统选择(国际格式和印度格式)
  • UI 刷新机制(修改设置后自动重启 Activity)
相关推荐
盖世英雄酱5813614 分钟前
java深度调试【第二章通过堆栈分析性能瓶颈】
java·后端
sivdead37 分钟前
当前智能体的几种形式
人工智能·后端·agent
lang201509281 小时前
Spring Boot RSocket:高性能异步通信实战
java·spring boot·后端
Moonbit1 小时前
倒计时 2 天|Meetup 议题已公开,Copilot 月卡等你来拿!
前端·后端
天天摸鱼的java工程师2 小时前
解释 Spring 框架中 bean 的生命周期:一个八年 Java 开发的实战视角
java·后端
往事随风去2 小时前
那个让老板闭嘴、让性能翻倍的“黑科技”:基准测试最全指南
后端·测试
李广坤2 小时前
JAVA线程池详解
后端
调试人生的显微镜2 小时前
深入剖析 iOS 26 系统流畅度,多工具协同监控与性能优化实践
后端
蹦跑的蜗牛2 小时前
Spring Boot使用Redis实现消息队列
spring boot·redis·后端
非凡ghost2 小时前
HWiNFO(专业系统信息检测工具)
前端·javascript·后端