mirror of
https://github.com/RetroDECK/Duckstation.git
synced 2025-01-18 22:35:39 +00:00
Android: Add touchscreen controller toggle
This commit is contained in:
parent
9321fcb627
commit
6592b59597
|
@ -5,9 +5,11 @@ import android.annotation.SuppressLint;
|
||||||
import androidx.appcompat.app.ActionBar;
|
import androidx.appcompat.app.ActionBar;
|
||||||
import androidx.appcompat.app.AppCompatActivity;
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
|
|
||||||
|
import android.content.Intent;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
import android.view.Menu;
|
||||||
import android.view.MotionEvent;
|
import android.view.MotionEvent;
|
||||||
import android.view.SurfaceHolder;
|
import android.view.SurfaceHolder;
|
||||||
import android.view.SurfaceView;
|
import android.view.SurfaceView;
|
||||||
|
@ -31,6 +33,7 @@ public class EmulationActivity extends AppCompatActivity implements SurfaceHolde
|
||||||
* Touchscreen controller overlay
|
* Touchscreen controller overlay
|
||||||
*/
|
*/
|
||||||
TouchscreenControllerView mTouchscreenController;
|
TouchscreenControllerView mTouchscreenController;
|
||||||
|
private boolean mTouchscreenControllerVisible = true;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether or not the system UI should be auto-hidden after
|
* Whether or not the system UI should be auto-hidden after
|
||||||
|
@ -148,6 +151,7 @@ public class EmulationActivity extends AppCompatActivity implements SurfaceHolde
|
||||||
mTouchscreenController = new TouchscreenControllerView(this);
|
mTouchscreenController = new TouchscreenControllerView(this);
|
||||||
activityLayout.addView(mTouchscreenController);
|
activityLayout.addView(mTouchscreenController);
|
||||||
mTouchscreenController.init(0, "DigitalController", mHostInterface);
|
mTouchscreenController.init(0, "DigitalController", mHostInterface);
|
||||||
|
setTouchscreenControllerVisibility(true);
|
||||||
|
|
||||||
// Hook up controller input.
|
// Hook up controller input.
|
||||||
mContentView.initControllerKeyMapping(mHostInterface, "DigitalController");
|
mContentView.initControllerKeyMapping(mHostInterface, "DigitalController");
|
||||||
|
@ -164,13 +168,34 @@ public class EmulationActivity extends AppCompatActivity implements SurfaceHolde
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onOptionsItemSelected(MenuItem item) {
|
public boolean onCreateOptionsMenu(Menu menu) {
|
||||||
int id = item.getItemId();
|
// Inflate the menu; this adds items to the action bar if it is present.
|
||||||
if (id == android.R.id.home) {
|
getMenuInflater().inflate(R.menu.menu_emulation, menu);
|
||||||
// This ID represents the Home or Up button.
|
menu.findItem(R.id.show_controller).setChecked(mTouchscreenControllerVisible);
|
||||||
NavUtils.navigateUpFromSameTask(this);
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onOptionsItemSelected(MenuItem item) {
|
||||||
|
// Handle action bar item clicks here. The action bar will
|
||||||
|
// automatically handle clicks on the Home/Up button, so long
|
||||||
|
// as you specify a parent activity in AndroidManifest.xml.
|
||||||
|
int id = item.getItemId();
|
||||||
|
|
||||||
|
//noinspection SimplifiableIfStatement
|
||||||
|
if (id == R.id.action_settings) {
|
||||||
|
Intent intent = new Intent(this, SettingsActivity.class);
|
||||||
|
startActivity(intent);
|
||||||
|
return true;
|
||||||
|
} else if (id == R.id.show_controller) {
|
||||||
|
setTouchscreenControllerVisibility(!mTouchscreenControllerVisible);
|
||||||
|
item.setChecked(mTouchscreenControllerVisible);
|
||||||
|
return true;
|
||||||
|
} else if (id == R.id.quit) {
|
||||||
|
finish();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
return super.onOptionsItemSelected(item);
|
return super.onOptionsItemSelected(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -217,4 +242,9 @@ public class EmulationActivity extends AppCompatActivity implements SurfaceHolde
|
||||||
mHideHandler.removeCallbacks(mHideRunnable);
|
mHideHandler.removeCallbacks(mHideRunnable);
|
||||||
mHideHandler.postDelayed(mHideRunnable, delayMillis);
|
mHideHandler.postDelayed(mHideRunnable, delayMillis);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void setTouchscreenControllerVisibility(boolean visible) {
|
||||||
|
mTouchscreenControllerVisible = visible;
|
||||||
|
mTouchscreenController.setVisibility(visible ? View.VISIBLE : View.INVISIBLE);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
27
android/app/src/main/res/menu/menu_emulation.xml
Normal file
27
android/app/src/main/res/menu/menu_emulation.xml
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<menu xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto">
|
||||||
|
|
||||||
|
<group android:id="@+id/quick_load_save">
|
||||||
|
<item android:title="Quick Load" />
|
||||||
|
<item android:title="Quick Save" />
|
||||||
|
</group>
|
||||||
|
<group android:id="@+id/quick_settings">
|
||||||
|
<item
|
||||||
|
android:id="@+id/change_disc"
|
||||||
|
android:title="Change Disc" />
|
||||||
|
<item
|
||||||
|
android:id="@+id/show_controller"
|
||||||
|
android:checkable="true"
|
||||||
|
android:title="Show Controller" />
|
||||||
|
</group>
|
||||||
|
|
||||||
|
<group>
|
||||||
|
<item
|
||||||
|
android:id="@+id/action_settings"
|
||||||
|
android:title="Settings" />
|
||||||
|
<item
|
||||||
|
android:id="@+id/quit"
|
||||||
|
android:title="Quit" />
|
||||||
|
</group>
|
||||||
|
</menu>
|
Loading…
Reference in a new issue