123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344 |
- package com.xugame.gameconsole;
- import androidx.appcompat.app.AppCompatActivity;
- import android.Manifest;
- import android.app.AlertDialog;
- import android.content.DialogInterface;
- import android.content.Intent;
- import android.content.SharedPreferences;
- import android.content.pm.PackageManager;
- import android.media.AudioManager;
- import android.os.AsyncTask;
- import android.os.Bundle;
- import android.os.Environment;
- import android.preference.PreferenceActivity;
- import android.preference.PreferenceManager;
- import android.provider.Settings;
- import android.text.TextUtils;
- import android.util.Log;
- import android.view.View;
- import android.widget.Button;
- import android.widget.EditText;
- import android.widget.Toast;
- import com.xugame.gameconsole.emulator.RetroArchEmulatorActivity;
- import com.xugame.gameconsole.preferences.UserPreferences;
- import com.xugame.gameconsole.util.DebugUtil;
- import com.xugame.gameconsole.util.Util;
- import java.io.BufferedOutputStream;
- import java.io.File;
- import java.io.FileInputStream;
- import java.io.FileOutputStream;
- import java.io.IOException;
- import java.io.InputStream;
- import java.lang.reflect.Field;
- import java.util.ArrayList;
- import java.util.List;
- public class MainActivity extends PreferenceActivity implements View.OnClickListener {
- private EditText mETRom, mETLib, mETConfig;
- private Button mBtnLocalGame, mBtnNetP1, mBtnNetP2;
- final private int REQUEST_CODE_ASK_MULTIPLE_PERMISSIONS = 124;
- public static String PACKAGE_NAME;
- boolean checkPermissions = false;
- public void showMessageOKCancel(String message, DialogInterface.OnClickListener onClickListener) {
- new AlertDialog.Builder(this).setMessage(message)
- .setPositiveButton("OK", onClickListener).setCancelable(false)
- .setNegativeButton("Cancel", null).create().show();
- }
- private boolean addPermission(List<String> permissionsList, String permission) {
- if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.M) {
- if (checkSelfPermission(permission) != PackageManager.PERMISSION_GRANTED) {
- permissionsList.add(permission);
- // Check for Rationale Option
- if (!shouldShowRequestPermissionRationale(permission))
- return false;
- }
- }
- return true;
- }
- public void checkRuntimePermissions() {
- if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.M) {
- // Android 6.0+ needs runtime permission checks
- List<String> permissionsNeeded = new ArrayList<String>();
- final List<String> permissionsList = new ArrayList<String>();
- if (!addPermission(permissionsList, Manifest.permission.READ_EXTERNAL_STORAGE))
- permissionsNeeded.add("Read External Storage");
- if (!addPermission(permissionsList, Manifest.permission.WRITE_EXTERNAL_STORAGE))
- permissionsNeeded.add("Write External Storage");
- if (permissionsList.size() > 0) {
- checkPermissions = true;
- if (permissionsNeeded.size() > 0) {
- // Need Rationale
- Log.i("MainMenuActivity", "Need to request external storage permissions.");
- String message = "You need to grant access to " + permissionsNeeded.get(0);
- for (int i = 1; i < permissionsNeeded.size(); i++)
- message = message + ", " + permissionsNeeded.get(i);
- showMessageOKCancel(message,
- new DialogInterface.OnClickListener() {
- @Override
- public void onClick(DialogInterface dialog, int which) {
- if (which == AlertDialog.BUTTON_POSITIVE) {
- requestPermissions(permissionsList.toArray(new String[permissionsList.size()]),
- REQUEST_CODE_ASK_MULTIPLE_PERMISSIONS);
- Log.i("MainMenuActivity", "User accepted request for external storage permissions.");
- }
- }
- });
- } else {
- requestPermissions(permissionsList.toArray(new String[permissionsList.size()]),
- REQUEST_CODE_ASK_MULTIPLE_PERMISSIONS);
- Log.i("MainMenuActivity", "Requested external storage permissions.");
- }
- }
- }
- if (!checkPermissions) {
- finalStartup();
- }
- }
- public void finalStartup() {
- final SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(this);
- Intent retro = new Intent(this, RetroArchEmulatorActivity.class);
- // retro.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
- // retro.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
- startRetroActivity(
- retro,
- romPath,
- // prefs.getString("libretro_path", getApplicationInfo().dataDir + "/cores/fbalpha2012_neogeo_libretro_android.so"),
- prefs.getString("libretro_path", corePath),
- UserPreferences.getDefaultConfigPath(this),
- Settings.Secure.getString(getContentResolver(), Settings.Secure.DEFAULT_INPUT_METHOD),
- getApplicationInfo().dataDir,
- getApplicationInfo().sourceDir);
- startActivity(retro);
- finish();
- }
- public static void startRetroActivity(Intent retro, String contentPath, String corePath,
- String configFilePath, String imePath, String dataDirPath, String dataSourcePath) {
- if (contentPath != null) {
- retro.putExtra("ROM", contentPath);
- }
- retro.putExtra("LIBRETRO", corePath);
- retro.putExtra("CONFIGFILE", configFilePath);
- retro.putExtra("IME", imePath);
- retro.putExtra("DATADIR", dataDirPath);
- retro.putExtra("APK", dataSourcePath);
- retro.putExtra("SDCARD", Environment.getExternalStorageDirectory().getAbsolutePath());
- String external = Environment.getExternalStorageDirectory().getAbsolutePath() + "/Android/data/" + PACKAGE_NAME + "/files";
- retro.putExtra("EXTERNAL", external);
- Log.i("TEST_STAT", "rompath=" + contentPath + "\ncorePath=" + corePath + "\n" + "configFilePath=" + configFilePath + "\nimePath=" + imePath
- + "\nDATADIR=" + dataDirPath + "\nAPK=" + dataSourcePath +
- "\nSDCARD=" + Environment.getExternalStorageDirectory().getAbsolutePath() + "\nEXTERNAL="
- + external);
- retro.putExtra("screenMode", screenMode);
- }
- @Override
- public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
- switch (requestCode) {
- case REQUEST_CODE_ASK_MULTIPLE_PERMISSIONS:
- for (int i = 0; i < permissions.length; i++) {
- if (grantResults[i] == PackageManager.PERMISSION_GRANTED) {
- Log.i("MainMenuActivity", "Permission: " + permissions[i] + " was granted.");
- } else {
- Log.i("MainMenuActivity", "Permission: " + permissions[i] + " was not granted.");
- }
- }
- break;
- default:
- super.onRequestPermissionsResult(requestCode, permissions, grantResults);
- break;
- }
- finalStartup();
- }
- private String baseUsbPath, corePath, romPath, coreName;
- private static int screenMode = 0;
- private String romName;
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- // setContentView(R.layout.activity_main);
- // this.findView();
- Util.init(this);
- PACKAGE_NAME = getPackageName();
- baseUsbPath = getIntent().getStringExtra("baseUsbPath");
- romPath = getIntent().getStringExtra("romPath");
- corePath = getIntent().getStringExtra("corePath");
- coreName = getIntent().getStringExtra("coreName");
- screenMode = getIntent().getIntExtra("screenMode", 0);
- checkCores();
- // checkRobot();
- }
- private void checkRobot() {
- File file = new File(this.getFilesDir().getParent() + File.separator + "autoconfig/android/robot.cfg");
- if (!file.exists()) {
- DebugUtil.i("", "复制robot" + file.getAbsolutePath());
- try {
- InputStream in = getResources().openRawResource(R.raw.robot);
- // in = this.getResources().getAssets().open("xucores/"+fileName);
- // in = new FileInputStream(file);
- BufferedOutputStream outStream
- = new BufferedOutputStream(new FileOutputStream(getFilesDir().getParent() + File.separator + "autoconfig/android/robot.cfg", false));
- byte[] buffer = new byte[1024];
- int size;
- while ((size = in.read(buffer)) > 0) {
- outStream.write(buffer, 0, size);
- }
- in.close();
- outStream.flush();
- outStream.close();
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
- }
- private void checkCores() {
- if (TextUtils.isEmpty(corePath)) {
- finish();
- }
- File file = new File(corePath);
- if (file.exists()) {
- start();
- } else {
- startCopy(coreName, corePath);
- }
- }
- private void startCopy(final String fileName, final String toPath) {
- File file = new File(this.getFilesDir().getParent() + File.separator + "cores");
- if (!file.exists())
- file.mkdirs();
- new AsyncTask<String, Integer, String>() {
- @Override
- protected String doInBackground(String... strings) {
- copyFile(getFilesDir().getParent() + File.separator + "cores/" + fileName, fileName);
- return null;
- }
- @Override
- protected void onPostExecute(String s) {
- start();
- super.onPostExecute(s);
- }
- }.execute("");
- }
- private boolean copyFile(String file_path, String fileName) {
- File baseFile = new File(Environment.getExternalStorageDirectory().getAbsolutePath() + "/arcade/cores/");
- if (!baseFile.exists())//创建/arcade/cores文件夹
- baseFile.mkdirs();
- File file;
- if (!TextUtils.isEmpty(baseUsbPath)) {
- file = new File(baseUsbPath + "/cores/" + fileName);
- } else
- file = new File(Environment.getExternalStorageDirectory().getAbsolutePath() + "/arcade/cores/" + fileName);
- if (!file.exists())//检测cores文件夹下是否存在.so
- return false;
- DebugUtil.i("COPY:", file.getAbsolutePath());
- try {
- InputStream in = null;
- // in = this.getResources().getAssets().open("xucores/"+fileName);
- in = new FileInputStream(file);
- BufferedOutputStream outStream
- = new BufferedOutputStream(new FileOutputStream(file_path, false));
- byte[] buffer = new byte[1024];
- int size;
- while ((size = in.read(buffer)) > 0) {
- outStream.write(buffer, 0, size);
- }
- in.close();
- outStream.flush();
- outStream.close();
- return true;
- } catch (IOException e) {
- e.printStackTrace();
- }
- return false;
- }
- private void start() {
- // Bind audio stream to hardware controls.
- setVolumeControlStream(AudioManager.STREAM_MUSIC);
- UserPreferences.updateConfigFile(this, baseUsbPath + File.separator + "/system");
- checkRuntimePermissions();
- }
- private void findView() {
- this.mBtnLocalGame = findViewById(R.id.btn_start_local_game);
- this.mBtnNetP1 = findViewById(R.id.btn_start_net_game_p1);
- this.mBtnNetP2 = findViewById(R.id.btn_start_net_game_p2);
- this.mETRom = findViewById(R.id.et_rom);
- this.mETLib = findViewById(R.id.et_libs);
- this.mETConfig = findViewById(R.id.et_config);
- this.mBtnLocalGame.setOnClickListener(this);
- this.mBtnNetP1.setOnClickListener(this);
- this.mBtnNetP1.setOnClickListener(this);
- }
- @Override
- public void onClick(View view) {
- if (view == mBtnLocalGame) {
- if (!checkPermissions) {
- finalStartup();
- }
- // String PACKAGE_NAME = this.getPackageName();
- // Intent retro = new Intent(this, RetroArchEmulatorActivity.class);
- // retro.putExtra("ROM", "/storage/emulated/0/arcade/rom/kofxi.zip");
- // retro.putExtra("LIBRETRO", "/data/data/com.xugame.gameconsole/cores/flycast_libretro_android.so");
- //// retro.putExtra("ROM", "");
- //// retro.putExtra("LIBRETRO", "");
- //
- // retro.putExtra("CONFIGFILE", "/storage/emulated/0/Android/data/com.xugame.gameconsole/files/retroarch.cfg");
- // retro.putExtra("IME", "com.android.inputmethod.latin/.LatinIME");
- // retro.putExtra("DATADIR", "/data/user/0/com.xugame.gameconsole");
- // retro.putExtra("APK", "/data/app/com.xugame.gameconsole-1/base.apk");
- // retro.putExtra("SDCARD", Environment.getExternalStorageDirectory().getAbsolutePath());
- // String external = Environment.getExternalStorageDirectory().getAbsolutePath() + "/Android/data/" + PACKAGE_NAME + "/files";
- // retro.putExtra("EXTERNAL", external);
- // startActivity(retro);
- }
- }
- }
|