Added a Wi-Fi (non-metered) only setting

This commit is contained in:
Timotej Leginus 2023-06-11 21:18:25 +02:00
parent adad1d88d6
commit 8a1f3b7c41
6 changed files with 44 additions and 4 deletions

View file

@ -48,7 +48,7 @@ class YuzuApplication : Application() {
documentsTree = DocumentsTree()
DirectoryInitialization.start(applicationContext)
GpuDriverHelper.initializeDriverParameters(applicationContext)
NetworkHelper.setRoutes(applicationContext)
NetworkHelper.getRoute(applicationContext)
MultiplayerHelper.initRoom(applicationContext)
NativeLibrary.logDeviceInfo()

View file

@ -132,6 +132,8 @@ class Settings {
const val PREF_BUTTON_TOGGLE_13 = "buttonToggle13"
const val PREF_BUTTON_TOGGLE_14 = "buttonToggle14"
const val PREF_FORCE_WIFI = "Network_ForceWifi"
const val PREF_ROOM_ADDRESS = "MultiplayerRoom_ServerAddress"
const val PREF_ROOM_PORT = "MultiplayerRoom_ServerPort"
const val PREF_ROOM_NICKNAME = "MultiplayerRoom_Nickname"

View file

@ -450,6 +450,31 @@ class SettingsFragmentPresenter(private val fragmentView: SettingsFragmentView)
settingsActivity.setToolbarTitle(settingsActivity.getString(R.string.preferences_network))
sl.apply {
val forceWifi: AbstractBooleanSetting = object : AbstractBooleanSetting {
override var boolean: Boolean
get() = preferences.getBoolean(Settings.PREF_FORCE_WIFI, false)
set(value) {
preferences.edit()
.putBoolean(Settings.PREF_FORCE_WIFI, value)
.apply()
}
override val key: String? = null
override val section: String? = null
override val isRuntimeEditable: Boolean = false
override val valueAsString: String
get() = preferences.getBoolean(Settings.PREF_FORCE_WIFI, false).toString()
override val defaultValue: Any = false
}
add(
SwitchSetting(
forceWifi,
R.string.set_force_wifi,
R.string.force_wifi_desc,
"",
false
)
)
add(
TextSetting(
StringSetting.NETWORK_ROUTE,

View file

@ -5,13 +5,24 @@ package org.yuzu.yuzu_emu.utils
import android.content.Context
import android.net.ConnectivityManager
import androidx.preference.PreferenceManager
import org.yuzu.yuzu_emu.features.settings.model.Settings
object NetworkHelper {
fun getRoutes(context: Context): String {
/**
* Gets available network interface info/route info - currently the active network info.
* @return The route info separated by semicolons (interface, address, netmask, gateway), or null if no networks are available.
*/
fun getRoute(context: Context): String? {
val connectivity =
context.getSystemService(Context.CONNECTIVITY_SERVICE) as ConnectivityManager
val lp = connectivity.getLinkProperties(connectivity.activeNetwork) ?: return ""
val preferences = PreferenceManager.getDefaultSharedPreferences(context)
if(connectivity.isActiveNetworkMetered && preferences.getBoolean(Settings.PREF_FORCE_WIFI, false))
return null
val lp = connectivity.getLinkProperties(connectivity.activeNetwork) ?: return null
val ifName = lp.interfaceName
val addr = lp.linkAddresses[0]

View file

@ -347,7 +347,7 @@ namespace {
u16 server_port = Network::DefaultRoomPort,
const std::string& password = "") {
auto room_network = m_system.GetRoomNetwork();
a
if (const auto member = room_network.GetRoomMember().lock()) {
// Prevent the user from trying to join a room while they are already joining.
if (member->GetState() == Network::RoomMember::State::Joining || member->IsConnected()) {

View file

@ -155,6 +155,8 @@
<!-- Network settings strings -->
<string name="network_route_desc">Sets the default network route</string>
<string name="set_network_route">Set network route</string>
<string name="set_force_wifi">Force Wi-Fi</string>
<string name="force_wifi_desc">Forces yuzu to use only Wi-Fi (non-metered connections in general)</string>
<!-- Multiplayer settings strings -->
<string name="multiplayer_room_server_address">Server address</string>