26 changed files with 312 additions and 211 deletions
-
22src/android/app/src/main/java/org/yuzu/yuzu_emu/NativeLibrary.kt
-
15src/android/app/src/main/java/org/yuzu/yuzu_emu/activities/EmulationActivity.kt
-
52src/android/app/src/main/java/org/yuzu/yuzu_emu/disk_shader_cache/DiskShaderCacheProgress.kt
-
31src/android/app/src/main/java/org/yuzu/yuzu_emu/disk_shader_cache/ShaderProgressViewModel.kt
-
103src/android/app/src/main/java/org/yuzu/yuzu_emu/disk_shader_cache/ui/ShaderProgressDialogFragment.kt
-
110src/android/app/src/main/java/org/yuzu/yuzu_emu/fragments/EmulationFragment.kt
-
59src/android/app/src/main/java/org/yuzu/yuzu_emu/model/EmulationViewModel.kt
-
14src/android/app/src/main/jni/id_cache.cpp
-
2src/android/app/src/main/jni/id_cache.h
-
16src/android/app/src/main/jni/native.cpp
-
83src/android/app/src/main/res/layout/fragment_emulation.xml
-
1src/android/app/src/main/res/values-de/strings.xml
-
1src/android/app/src/main/res/values-es/strings.xml
-
1src/android/app/src/main/res/values-fr/strings.xml
-
1src/android/app/src/main/res/values-it/strings.xml
-
1src/android/app/src/main/res/values-ja/strings.xml
-
1src/android/app/src/main/res/values-ko/strings.xml
-
1src/android/app/src/main/res/values-nb/strings.xml
-
1src/android/app/src/main/res/values-pl/strings.xml
-
1src/android/app/src/main/res/values-pt-rBR/strings.xml
-
1src/android/app/src/main/res/values-pt-rPT/strings.xml
-
1src/android/app/src/main/res/values-ru/strings.xml
-
1src/android/app/src/main/res/values-uk/strings.xml
-
1src/android/app/src/main/res/values-zh-rCN/strings.xml
-
1src/android/app/src/main/res/values-zh-rTW/strings.xml
-
2src/android/app/src/main/res/values/strings.xml
@ -1,31 +0,0 @@ |
|||||
// SPDX-FileCopyrightText: 2023 yuzu Emulator Project |
|
||||
// SPDX-License-Identifier: GPL-2.0-or-later |
|
||||
|
|
||||
package org.yuzu.yuzu_emu.disk_shader_cache |
|
||||
|
|
||||
import androidx.lifecycle.LiveData |
|
||||
import androidx.lifecycle.MutableLiveData |
|
||||
import androidx.lifecycle.ViewModel |
|
||||
|
|
||||
class ShaderProgressViewModel : ViewModel() { |
|
||||
private val _progress = MutableLiveData(0) |
|
||||
val progress: LiveData<Int> get() = _progress |
|
||||
|
|
||||
private val _max = MutableLiveData(0) |
|
||||
val max: LiveData<Int> get() = _max |
|
||||
|
|
||||
private val _message = MutableLiveData("") |
|
||||
val message: LiveData<String> get() = _message |
|
||||
|
|
||||
fun setProgress(progress: Int) { |
|
||||
_progress.postValue(progress) |
|
||||
} |
|
||||
|
|
||||
fun setMax(max: Int) { |
|
||||
_max.postValue(max) |
|
||||
} |
|
||||
|
|
||||
fun setMessage(msg: String) { |
|
||||
_message.postValue(msg) |
|
||||
} |
|
||||
} |
|
||||
@ -1,103 +0,0 @@ |
|||||
// SPDX-FileCopyrightText: 2023 yuzu Emulator Project |
|
||||
// SPDX-License-Identifier: GPL-2.0-or-later |
|
||||
|
|
||||
package org.yuzu.yuzu_emu.disk_shader_cache.ui |
|
||||
|
|
||||
import android.app.Dialog |
|
||||
import android.os.Bundle |
|
||||
import android.view.LayoutInflater |
|
||||
import android.view.View |
|
||||
import android.view.ViewGroup |
|
||||
import androidx.appcompat.app.AlertDialog |
|
||||
import androidx.fragment.app.DialogFragment |
|
||||
import androidx.lifecycle.ViewModelProvider |
|
||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder |
|
||||
import org.yuzu.yuzu_emu.databinding.DialogProgressBarBinding |
|
||||
import org.yuzu.yuzu_emu.disk_shader_cache.DiskShaderCacheProgress |
|
||||
import org.yuzu.yuzu_emu.disk_shader_cache.ShaderProgressViewModel |
|
||||
|
|
||||
class ShaderProgressDialogFragment : DialogFragment() { |
|
||||
private var _binding: DialogProgressBarBinding? = null |
|
||||
private val binding get() = _binding!! |
|
||||
|
|
||||
private lateinit var alertDialog: AlertDialog |
|
||||
|
|
||||
private lateinit var shaderProgressViewModel: ShaderProgressViewModel |
|
||||
|
|
||||
override fun onCreateDialog(savedInstanceState: Bundle?): Dialog { |
|
||||
_binding = DialogProgressBarBinding.inflate(layoutInflater) |
|
||||
shaderProgressViewModel = |
|
||||
ViewModelProvider(requireActivity())[ShaderProgressViewModel::class.java] |
|
||||
|
|
||||
val title = requireArguments().getString(TITLE) |
|
||||
val message = requireArguments().getString(MESSAGE) |
|
||||
|
|
||||
isCancelable = false |
|
||||
alertDialog = MaterialAlertDialogBuilder(requireActivity()) |
|
||||
.setView(binding.root) |
|
||||
.setTitle(title) |
|
||||
.setMessage(message) |
|
||||
.create() |
|
||||
return alertDialog |
|
||||
} |
|
||||
|
|
||||
override fun onCreateView( |
|
||||
inflater: LayoutInflater, |
|
||||
container: ViewGroup?, |
|
||||
savedInstanceState: Bundle? |
|
||||
): View { |
|
||||
return binding.root |
|
||||
} |
|
||||
|
|
||||
override fun onViewCreated(view: View, savedInstanceState: Bundle?) { |
|
||||
super.onViewCreated(view, savedInstanceState) |
|
||||
shaderProgressViewModel.progress.observe(viewLifecycleOwner) { progress -> |
|
||||
binding.progressBar.progress = progress |
|
||||
setUpdateText() |
|
||||
} |
|
||||
shaderProgressViewModel.max.observe(viewLifecycleOwner) { max -> |
|
||||
binding.progressBar.max = max |
|
||||
setUpdateText() |
|
||||
} |
|
||||
shaderProgressViewModel.message.observe(viewLifecycleOwner) { msg -> |
|
||||
alertDialog.setMessage(msg) |
|
||||
} |
|
||||
synchronized(DiskShaderCacheProgress.finishLock) { |
|
||||
DiskShaderCacheProgress.finishLock.notifyAll() |
|
||||
} |
|
||||
} |
|
||||
|
|
||||
override fun onDestroyView() { |
|
||||
super.onDestroyView() |
|
||||
_binding = null |
|
||||
} |
|
||||
|
|
||||
fun onUpdateProgress(msg: String, progress: Int, max: Int) { |
|
||||
shaderProgressViewModel.setProgress(progress) |
|
||||
shaderProgressViewModel.setMax(max) |
|
||||
shaderProgressViewModel.setMessage(msg) |
|
||||
} |
|
||||
|
|
||||
private fun setUpdateText() { |
|
||||
binding.progressText.text = String.format( |
|
||||
"%d/%d", |
|
||||
shaderProgressViewModel.progress.value, |
|
||||
shaderProgressViewModel.max.value |
|
||||
) |
|
||||
} |
|
||||
|
|
||||
companion object { |
|
||||
const val TAG = "ProgressDialogFragment" |
|
||||
const val TITLE = "title" |
|
||||
const val MESSAGE = "message" |
|
||||
|
|
||||
fun newInstance(title: String, message: String): ShaderProgressDialogFragment { |
|
||||
val frag = ShaderProgressDialogFragment() |
|
||||
val args = Bundle() |
|
||||
args.putString(TITLE, title) |
|
||||
args.putString(MESSAGE, message) |
|
||||
frag.arguments = args |
|
||||
return frag |
|
||||
} |
|
||||
} |
|
||||
} |
|
||||
@ -0,0 +1,59 @@ |
|||||
|
// SPDX-FileCopyrightText: 2023 yuzu Emulator Project |
||||
|
// SPDX-License-Identifier: GPL-3.0-or-later |
||||
|
|
||||
|
package org.yuzu.yuzu_emu.model |
||||
|
|
||||
|
import androidx.lifecycle.LiveData |
||||
|
import androidx.lifecycle.MutableLiveData |
||||
|
import androidx.lifecycle.ViewModel |
||||
|
|
||||
|
class EmulationViewModel : ViewModel() { |
||||
|
private val _emulationStarted = MutableLiveData(false) |
||||
|
val emulationStarted: LiveData<Boolean> get() = _emulationStarted |
||||
|
|
||||
|
private val _isEmulationStopping = MutableLiveData(false) |
||||
|
val isEmulationStopping: LiveData<Boolean> get() = _isEmulationStopping |
||||
|
|
||||
|
private val _shaderProgress = MutableLiveData(0) |
||||
|
val shaderProgress: LiveData<Int> get() = _shaderProgress |
||||
|
|
||||
|
private val _totalShaders = MutableLiveData(0) |
||||
|
val totalShaders: LiveData<Int> get() = _totalShaders |
||||
|
|
||||
|
private val _shaderMessage = MutableLiveData("") |
||||
|
val shaderMessage: LiveData<String> get() = _shaderMessage |
||||
|
|
||||
|
fun setEmulationStarted(started: Boolean) { |
||||
|
_emulationStarted.postValue(started) |
||||
|
} |
||||
|
|
||||
|
fun setIsEmulationStopping(value: Boolean) { |
||||
|
_isEmulationStopping.value = value |
||||
|
} |
||||
|
|
||||
|
fun setShaderProgress(progress: Int) { |
||||
|
_shaderProgress.value = progress |
||||
|
} |
||||
|
|
||||
|
fun setTotalShaders(max: Int) { |
||||
|
_totalShaders.value = max |
||||
|
} |
||||
|
|
||||
|
fun setShaderMessage(msg: String) { |
||||
|
_shaderMessage.value = msg |
||||
|
} |
||||
|
|
||||
|
fun updateProgress(msg: String, progress: Int, max: Int) { |
||||
|
setShaderMessage(msg) |
||||
|
setShaderProgress(progress) |
||||
|
setTotalShaders(max) |
||||
|
} |
||||
|
|
||||
|
fun clear() { |
||||
|
_emulationStarted.value = false |
||||
|
_isEmulationStopping.value = false |
||||
|
_shaderProgress.value = 0 |
||||
|
_totalShaders.value = 0 |
||||
|
_shaderMessage.value = "" |
||||
|
} |
||||
|
} |
||||
Write
Preview
Loading…
Cancel
Save
Reference in new issue