Android: Implement installing system update from disc image

This commit is contained in:
JosJuice 2022-04-03 11:04:40 +02:00
parent a4445fa1b0
commit 57733ddc70
9 changed files with 125 additions and 42 deletions

View File

@ -21,6 +21,7 @@ import org.dolphinemu.dolphinemu.features.settings.model.StringSetting;
import org.dolphinemu.dolphinemu.features.settings.ui.MenuTag; import org.dolphinemu.dolphinemu.features.settings.ui.MenuTag;
import org.dolphinemu.dolphinemu.features.settings.ui.SettingsActivity; import org.dolphinemu.dolphinemu.features.settings.ui.SettingsActivity;
import org.dolphinemu.dolphinemu.model.GameFile; import org.dolphinemu.dolphinemu.model.GameFile;
import org.dolphinemu.dolphinemu.ui.main.MainPresenter;
import org.dolphinemu.dolphinemu.ui.platform.Platform; import org.dolphinemu.dolphinemu.ui.platform.Platform;
import org.dolphinemu.dolphinemu.utils.AlertDialogItemsBuilder; import org.dolphinemu.dolphinemu.utils.AlertDialogItemsBuilder;
import org.dolphinemu.dolphinemu.utils.DirectoryInitialization; import org.dolphinemu.dolphinemu.utils.DirectoryInitialization;
@ -101,6 +102,12 @@ public class GamePropertiesDialog extends DialogFragment
ConvertActivity.launch(getContext(), path)); ConvertActivity.launch(getContext(), path));
} }
if (isDisc && isWii)
{
itemsBuilder.add(R.string.properties_system_update, (dialog, i) ->
MainPresenter.launchDiscUpdate(path, requireActivity()));
}
itemsBuilder.add(R.string.properties_edit_game_settings, (dialog, i) -> itemsBuilder.add(R.string.properties_edit_game_settings, (dialog, i) ->
SettingsActivity.launch(getContext(), MenuTag.SETTINGS, gameId, revision, isWii)); SettingsActivity.launch(getContext(), MenuTag.SETTINGS, gameId, revision, isWii));

View File

@ -31,8 +31,8 @@ public class OnlineUpdateRegionSelectDialogFragment extends DialogFragment
new ViewModelProvider(requireActivity()).get(SystemUpdateViewModel.class); new ViewModelProvider(requireActivity()).get(SystemUpdateViewModel.class);
viewModel.setRegion(which); viewModel.setRegion(which);
OnlineUpdateProgressBarDialogFragment progressBarFragment = SystemUpdateProgressBarDialogFragment progressBarFragment =
new OnlineUpdateProgressBarDialogFragment(); new SystemUpdateProgressBarDialogFragment();
progressBarFragment progressBarFragment
.show(getParentFragmentManager(), "OnlineUpdateProgressBarDialogFragment"); .show(getParentFragmentManager(), "OnlineUpdateProgressBarDialogFragment");
progressBarFragment.setCancelable(false); progressBarFragment.setCancelable(false);

View File

@ -14,7 +14,7 @@ import androidx.lifecycle.ViewModelProvider;
import org.dolphinemu.dolphinemu.R; import org.dolphinemu.dolphinemu.R;
public class OnlineUpdateProgressBarDialogFragment extends DialogFragment public class SystemUpdateProgressBarDialogFragment extends DialogFragment
{ {
@NonNull @NonNull
@Override @Override
@ -74,7 +74,7 @@ public class OnlineUpdateProgressBarDialogFragment extends DialogFragment
return; return;
} }
OnlineUpdateResultFragment progressBarFragment = new OnlineUpdateResultFragment(); SystemUpdateResultFragment progressBarFragment = new SystemUpdateResultFragment();
progressBarFragment.show(getParentFragmentManager(), "OnlineUpdateResultFragment"); progressBarFragment.show(getParentFragmentManager(), "OnlineUpdateResultFragment");
getActivity().setRequestedOrientation(orientation); getActivity().setRequestedOrientation(orientation);
@ -84,28 +84,7 @@ public class OnlineUpdateProgressBarDialogFragment extends DialogFragment
if (savedInstanceState == null) if (savedInstanceState == null)
{ {
final String region; viewModel.startUpdate();
int selectedItem = viewModel.getRegion();
switch (selectedItem)
{
case 0:
region = "EUR";
break;
case 1:
region = "JPN";
break;
case 2:
region = "KOR";
break;
case 3:
region = "USA";
break;
default:
region = "";
break;
}
viewModel.startUpdate(region);
} }
return progressDialog; return progressDialog;
} }

View File

@ -13,7 +13,7 @@ import androidx.lifecycle.ViewModelProvider;
import org.dolphinemu.dolphinemu.R; import org.dolphinemu.dolphinemu.R;
import org.dolphinemu.dolphinemu.utils.WiiUtils; import org.dolphinemu.dolphinemu.utils.WiiUtils;
public class OnlineUpdateResultFragment extends DialogFragment public class SystemUpdateResultFragment extends DialogFragment
{ {
private int mResult; private int mResult;

View File

@ -5,6 +5,7 @@ package org.dolphinemu.dolphinemu.features.sysupdate.ui;
import androidx.lifecycle.MutableLiveData; import androidx.lifecycle.MutableLiveData;
import androidx.lifecycle.ViewModel; import androidx.lifecycle.ViewModel;
import org.dolphinemu.dolphinemu.utils.WiiUpdateCallback;
import org.dolphinemu.dolphinemu.utils.WiiUtils; import org.dolphinemu.dolphinemu.utils.WiiUtils;
import java.util.concurrent.ExecutorService; import java.util.concurrent.ExecutorService;
@ -21,6 +22,7 @@ public class SystemUpdateViewModel extends ViewModel
private boolean mCanceled = false; private boolean mCanceled = false;
private int mRegion; private int mRegion;
private String mDiscPath;
public SystemUpdateViewModel() public SystemUpdateViewModel()
{ {
@ -37,6 +39,16 @@ public class SystemUpdateViewModel extends ViewModel
return mRegion; return mRegion;
} }
public void setDiscPath(String discPath)
{
mDiscPath = discPath;
}
public String getDiscPath()
{
return mDiscPath;
}
public MutableLiveData<Integer> getProgressData() public MutableLiveData<Integer> getProgressData()
{ {
return mProgressData; return mProgressData;
@ -62,21 +74,55 @@ public class SystemUpdateViewModel extends ViewModel
mCanceled = true; mCanceled = true;
} }
public void startUpdate(String region) public void startUpdate()
{
if (!mDiscPath.isEmpty())
{
startDiscUpdate(mDiscPath);
}
else
{
final String region;
switch (mRegion)
{
case 0:
region = "EUR";
break;
case 1:
region = "JPN";
break;
case 2:
region = "KOR";
break;
case 3:
region = "USA";
break;
default:
region = "";
break;
}
startOnlineUpdate(region);
}
}
public void startOnlineUpdate(String region)
{ {
mCanceled = false; mCanceled = false;
executor.execute(() -> executor.execute(() ->
{ {
int result = WiiUtils.doOnlineUpdate(region, ((processed, total, titleId) -> int result = WiiUtils.doOnlineUpdate(region, constructCallback());
{ mResultData.postValue(result);
mProgressData.postValue(processed); });
mTotalData.postValue(total); }
mTitleIdData.postValue(titleId);
return !mCanceled; public void startDiscUpdate(String path)
})); {
mCanceled = false;
executor.execute(() ->
{
int result = WiiUtils.doDiscUpdate(path, constructCallback());
mResultData.postValue(result); mResultData.postValue(result);
}); });
} }
@ -88,5 +134,19 @@ public class SystemUpdateViewModel extends ViewModel
mTitleIdData.setValue(0l); mTitleIdData.setValue(0l);
mResultData.setValue(-1); mResultData.setValue(-1);
mCanceled = false; mCanceled = false;
mRegion = -1;
mDiscPath = "";
}
private WiiUpdateCallback constructCallback()
{
return (processed, total, titleId) ->
{
mProgressData.postValue(processed);
mTotalData.postValue(total);
mTitleIdData.postValue(titleId);
return !mCanceled;
};
} }
} }

View File

@ -17,7 +17,7 @@ import org.dolphinemu.dolphinemu.R;
import org.dolphinemu.dolphinemu.activities.EmulationActivity; import org.dolphinemu.dolphinemu.activities.EmulationActivity;
import org.dolphinemu.dolphinemu.features.settings.model.BooleanSetting; import org.dolphinemu.dolphinemu.features.settings.model.BooleanSetting;
import org.dolphinemu.dolphinemu.features.settings.ui.MenuTag; import org.dolphinemu.dolphinemu.features.settings.ui.MenuTag;
import org.dolphinemu.dolphinemu.features.sysupdate.ui.OnlineUpdateProgressBarDialogFragment; import org.dolphinemu.dolphinemu.features.sysupdate.ui.SystemUpdateProgressBarDialogFragment;
import org.dolphinemu.dolphinemu.features.sysupdate.ui.SystemMenuNotInstalledDialogFragment; import org.dolphinemu.dolphinemu.features.sysupdate.ui.SystemMenuNotInstalledDialogFragment;
import org.dolphinemu.dolphinemu.features.sysupdate.ui.SystemUpdateViewModel; import org.dolphinemu.dolphinemu.features.sysupdate.ui.SystemUpdateViewModel;
import org.dolphinemu.dolphinemu.model.GameFileCache; import org.dolphinemu.dolphinemu.model.GameFileCache;
@ -280,11 +280,7 @@ public final class MainPresenter
SystemUpdateViewModel viewModel = SystemUpdateViewModel viewModel =
new ViewModelProvider(mActivity).get(SystemUpdateViewModel.class); new ViewModelProvider(mActivity).get(SystemUpdateViewModel.class);
viewModel.setRegion(-1); viewModel.setRegion(-1);
OnlineUpdateProgressBarDialogFragment progressBarFragment = launchUpdateProgressBarFragment(mActivity);
new OnlineUpdateProgressBarDialogFragment();
progressBarFragment
.show(mActivity.getSupportFragmentManager(), "OnlineUpdateProgressBarDialogFragment");
progressBarFragment.setCancelable(false);
} }
else else
{ {
@ -295,6 +291,23 @@ public final class MainPresenter
} }
} }
public static void launchDiscUpdate(String path, FragmentActivity activity)
{
SystemUpdateViewModel viewModel =
new ViewModelProvider(activity).get(SystemUpdateViewModel.class);
viewModel.setDiscPath(path);
launchUpdateProgressBarFragment(activity);
}
private static void launchUpdateProgressBarFragment(FragmentActivity activity)
{
SystemUpdateProgressBarDialogFragment progressBarFragment =
new SystemUpdateProgressBarDialogFragment();
progressBarFragment
.show(activity.getSupportFragmentManager(), "SystemUpdateProgressBarDialogFragment");
progressBarFragment.setCancelable(false);
}
private void launchWiiSystemMenu() private void launchWiiSystemMenu()
{ {
WiiUtils.isSystemMenuInstalled(); WiiUtils.isSystemMenuInstalled();

View File

@ -28,6 +28,8 @@ public final class WiiUtils
public static native int doOnlineUpdate(String region, WiiUpdateCallback callback); public static native int doOnlineUpdate(String region, WiiUpdateCallback callback);
public static native int doDiscUpdate(String path, WiiUpdateCallback callback);
public static native boolean isSystemMenuInstalled(); public static native boolean isSystemMenuInstalled();
public static native String getSystemMenuVersion(); public static native String getSystemMenuVersion();

View File

@ -433,6 +433,7 @@
<string name="properties_start_with_riivolution">Start with Riivolution Patches</string> <string name="properties_start_with_riivolution">Start with Riivolution Patches</string>
<string name="properties_set_default_iso">Set as Default ISO</string> <string name="properties_set_default_iso">Set as Default ISO</string>
<string name="properties_convert">Convert File</string> <string name="properties_convert">Convert File</string>
<string name="properties_system_update">Perform System Update</string>
<string name="properties_edit_game_settings">Edit Game Settings</string> <string name="properties_edit_game_settings">Edit Game Settings</string>
<string name="properties_edit_cheats">Edit Cheats</string> <string name="properties_edit_cheats">Edit Cheats</string>
<string name="properties_clear_game_settings">Clear Game Settings and Cheats</string> <string name="properties_clear_game_settings">Clear Game Settings and Cheats</string>

View File

@ -63,7 +63,7 @@ static jint ConvertUpdateResult(WiiUtils::UpdateResult result)
return 8; return 8;
default: default:
ASSERT(false); ASSERT(false);
return 1; return 7;
} }
static_assert(static_cast<int>(WiiUtils::UpdateResult::NumberOfEntries) == 9); static_assert(static_cast<int>(WiiUtils::UpdateResult::NumberOfEntries) == 9);
@ -132,6 +132,27 @@ JNIEXPORT jint JNICALL Java_org_dolphinemu_dolphinemu_utils_WiiUtils_doOnlineUpd
return ConvertUpdateResult(result); return ConvertUpdateResult(result);
} }
JNIEXPORT jint JNICALL Java_org_dolphinemu_dolphinemu_utils_WiiUtils_doDiscUpdate(JNIEnv* env,
jclass,
jstring jPath,
jobject jCallback)
{
const std::string path = GetJString(env, jPath);
jobject jCallbackGlobal = env->NewGlobalRef(jCallback);
Common::ScopeGuard scope_guard([jCallbackGlobal, env] { env->DeleteGlobalRef(jCallbackGlobal); });
const auto callback = [&jCallbackGlobal](int processed, int total, u64 title_id) {
JNIEnv* env = IDCache::GetEnvForThread();
return static_cast<bool>(env->CallBooleanMethod(
jCallbackGlobal, IDCache::GetWiiUpdateCallbackFunction(), processed, total, title_id));
};
WiiUtils::UpdateResult result = WiiUtils::DoDiscUpdate(callback, path);
return ConvertUpdateResult(result);
}
JNIEXPORT jboolean JNICALL JNIEXPORT jboolean JNICALL
Java_org_dolphinemu_dolphinemu_utils_WiiUtils_isSystemMenuInstalled(JNIEnv* env, jclass) Java_org_dolphinemu_dolphinemu_utils_WiiUtils_isSystemMenuInstalled(JNIEnv* env, jclass)
{ {