From 5cf14e45e1b3527d360c81f324a99263fa1d446a Mon Sep 17 00:00:00 2001 From: lynxnb Date: Tue, 18 Oct 2022 19:26:18 +0200 Subject: [PATCH] Enable frame throttling when triple buffering is disabled --- app/src/main/java/emu/skyline/SettingsActivity.kt | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/app/src/main/java/emu/skyline/SettingsActivity.kt b/app/src/main/java/emu/skyline/SettingsActivity.kt index fff0e4f0..d1aa9a05 100644 --- a/app/src/main/java/emu/skyline/SettingsActivity.kt +++ b/app/src/main/java/emu/skyline/SettingsActivity.kt @@ -7,10 +7,10 @@ package emu.skyline import android.os.Bundle import android.view.KeyEvent -import android.view.View import android.view.ViewTreeObserver import androidx.appcompat.app.AppCompatActivity import androidx.coordinatorlayout.widget.CoordinatorLayout +import androidx.preference.CheckBoxPreference import androidx.preference.Preference import androidx.preference.PreferenceFragmentCompat import emu.skyline.databinding.SettingsActivityBinding @@ -37,7 +37,7 @@ class SettingsActivity : AppCompatActivity() { var layoutDone = false // Tracks if the layout is complete to avoid retrieving invalid attributes binding.coordinatorLayout.viewTreeObserver.addOnTouchModeChangeListener { isTouchMode -> - val layoutUpdate = { -> + val layoutUpdate = { val params = binding.settings.layoutParams as CoordinatorLayout.LayoutParams if (!isTouchMode) { binding.titlebar.appBarLayout.setExpanded(true) @@ -83,6 +83,14 @@ class SettingsActivity : AppCompatActivity() { */ override fun onCreatePreferences(savedInstanceState : Bundle?, rootKey : String?) { setPreferencesFromResource(R.xml.preferences, rootKey) + + // Uncheck `disable_frame_throttling` if `force_triple_buffering` gets disabled + val disableFrameThrottlingPref = findPreference("disable_frame_throttling")!! + findPreference("force_triple_buffering")?.setOnPreferenceChangeListener { _, newValue -> + if (newValue == false) + disableFrameThrottlingPref.isChecked = false + true + } } override fun onDisplayPreferenceDialog(preference : Preference) {