forked from eden-emu/eden
		
	android: Use the center of the object and reduce draw calls
This commit is contained in:
		
							parent
							
								
									76b5181bdf
								
							
						
					
					
						commit
						ada3a4085a
					
				
					 8 changed files with 76 additions and 59 deletions
				
			
		|  | @ -12,6 +12,7 @@ import android.view.KeyEvent; | ||||||
| import android.view.LayoutInflater; | import android.view.LayoutInflater; | ||||||
| import android.view.MotionEvent; | import android.view.MotionEvent; | ||||||
| import android.view.View; | import android.view.View; | ||||||
|  | import android.view.WindowManager; | ||||||
| import android.widget.SeekBar; | import android.widget.SeekBar; | ||||||
| import android.widget.TextView; | import android.widget.TextView; | ||||||
| 
 | 
 | ||||||
|  | @ -164,6 +165,9 @@ public final class EmulationActivity extends AppCompatActivity { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void enableFullscreenImmersive() { |     private void enableFullscreenImmersive() { | ||||||
|  |         getWindow().getAttributes().layoutInDisplayCutoutMode= | ||||||
|  |                 WindowManager.LayoutParams.LAYOUT_IN_DISPLAY_CUTOUT_MODE_SHORT_EDGES; | ||||||
|  | 
 | ||||||
|         // It would be nice to use IMMERSIVE_STICKY, but that doesn't show the toolbar. |         // It would be nice to use IMMERSIVE_STICKY, but that doesn't show the toolbar. | ||||||
|         mDecorView.setSystemUiVisibility( |         mDecorView.setSystemUiVisibility( | ||||||
|                 View.SYSTEM_UI_FLAG_LAYOUT_STABLE | |                 View.SYSTEM_UI_FLAG_LAYOUT_STABLE | | ||||||
|  |  | ||||||
|  | @ -186,7 +186,7 @@ public final class InputOverlay extends SurfaceView implements OnTouchListener, | ||||||
|                 scale = 0.38f; |                 scale = 0.38f; | ||||||
|                 break; |                 break; | ||||||
|             default: |             default: | ||||||
|                 scale = 0.40f; |                 scale = 0.43f; | ||||||
|                 break; |                 break; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | @ -215,10 +215,10 @@ public final class InputOverlay extends SurfaceView implements OnTouchListener, | ||||||
| 
 | 
 | ||||||
|         // Now set the bounds for the InputOverlayDrawableButton. |         // Now set the bounds for the InputOverlayDrawableButton. | ||||||
|         // This will dictate where on the screen (and the what the size) the InputOverlayDrawableButton will be. |         // This will dictate where on the screen (and the what the size) the InputOverlayDrawableButton will be. | ||||||
|         overlayDrawable.setBounds(drawableX, drawableY, drawableX + width, drawableY + height); |         overlayDrawable.setBounds(drawableX - (width / 2), drawableY - (height / 2), drawableX + (width / 2), drawableY + (height / 2)); | ||||||
| 
 | 
 | ||||||
|         // Need to set the image's position |         // Need to set the image's position | ||||||
|         overlayDrawable.setPosition(drawableX, drawableY); |         overlayDrawable.setPosition(drawableX - (width / 2), drawableY - (height / 2)); | ||||||
| 
 | 
 | ||||||
|         return overlayDrawable; |         return overlayDrawable; | ||||||
|     } |     } | ||||||
|  | @ -278,10 +278,10 @@ public final class InputOverlay extends SurfaceView implements OnTouchListener, | ||||||
| 
 | 
 | ||||||
|         // Now set the bounds for the InputOverlayDrawableDpad. |         // Now set the bounds for the InputOverlayDrawableDpad. | ||||||
|         // This will dictate where on the screen (and the what the size) the InputOverlayDrawableDpad will be. |         // This will dictate where on the screen (and the what the size) the InputOverlayDrawableDpad will be. | ||||||
|         overlayDrawable.setBounds(drawableX, drawableY, drawableX + width, drawableY + height); |         overlayDrawable.setBounds(drawableX - (width / 2), drawableY - (height / 2), drawableX + (width / 2), drawableY + (height / 2)); | ||||||
| 
 | 
 | ||||||
|         // Need to set the image's position |         // Need to set the image's position | ||||||
|         overlayDrawable.setPosition(drawableX, drawableY); |         overlayDrawable.setPosition(drawableX - (width / 2), drawableY - (height / 2)); | ||||||
| 
 | 
 | ||||||
|         return overlayDrawable; |         return overlayDrawable; | ||||||
|     } |     } | ||||||
|  | @ -306,7 +306,7 @@ public final class InputOverlay extends SurfaceView implements OnTouchListener, | ||||||
|         final SharedPreferences sPrefs = PreferenceManager.getDefaultSharedPreferences(context); |         final SharedPreferences sPrefs = PreferenceManager.getDefaultSharedPreferences(context); | ||||||
| 
 | 
 | ||||||
|         // Decide scale based on user preference |         // Decide scale based on user preference | ||||||
|         float scale = 0.35f; |         float scale = 0.40f; | ||||||
|         scale *= (sPrefs.getInt("controlScale", 50) + 50); |         scale *= (sPrefs.getInt("controlScale", 50) + 50); | ||||||
|         scale /= 100; |         scale /= 100; | ||||||
| 
 | 
 | ||||||
|  | @ -320,12 +320,12 @@ public final class InputOverlay extends SurfaceView implements OnTouchListener, | ||||||
|         int drawableX = (int) sPrefs.getFloat(button + orientation + "-X", 0f); |         int drawableX = (int) sPrefs.getFloat(button + orientation + "-X", 0f); | ||||||
|         int drawableY = (int) sPrefs.getFloat(button + orientation + "-Y", 0f); |         int drawableY = (int) sPrefs.getFloat(button + orientation + "-Y", 0f); | ||||||
| 
 | 
 | ||||||
|         float outerScale = 1.3f; |         float outerScale = 1.66f; | ||||||
| 
 | 
 | ||||||
|         // Now set the bounds for the InputOverlayDrawableJoystick. |         // Now set the bounds for the InputOverlayDrawableJoystick. | ||||||
|         // This will dictate where on the screen (and the what the size) the InputOverlayDrawableJoystick will be. |         // This will dictate where on the screen (and the what the size) the InputOverlayDrawableJoystick will be. | ||||||
|         int outerSize = bitmapOuter.getWidth(); |         int outerSize = bitmapOuter.getWidth(); | ||||||
|         Rect outerRect = new Rect(drawableX, drawableY, drawableX + outerSize, drawableY + outerSize); |         Rect outerRect = new Rect(drawableX - (outerSize / 2), drawableY - (outerSize / 2), drawableX + (outerSize / 2), drawableY + (outerSize / 2)); | ||||||
|         Rect innerRect = new Rect(0, 0, (int) (outerSize / outerScale), (int) (outerSize / outerScale)); |         Rect innerRect = new Rect(0, 0, (int) (outerSize / outerScale), (int) (outerSize / outerScale)); | ||||||
| 
 | 
 | ||||||
|         // Send the drawableId to the joystick so it can be referenced when saving control position. |         // Send the drawableId to the joystick so it can be referenced when saving control position. | ||||||
|  | @ -362,12 +362,13 @@ public final class InputOverlay extends SurfaceView implements OnTouchListener, | ||||||
|         if (isInEditMode()) { |         if (isInEditMode()) { | ||||||
|             return onTouchWhileEditing(event); |             return onTouchWhileEditing(event); | ||||||
|         } |         } | ||||||
| 
 |         boolean should_update_view = false; | ||||||
|         for (InputOverlayDrawableButton button : overlayButtons) { |         for (InputOverlayDrawableButton button : overlayButtons) { | ||||||
|             if (!button.updateStatus(event)) { |             if (!button.updateStatus(event)) { | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|             NativeLibrary.onGamePadButtonEvent(NativeLibrary.Player1Device, button.getId(), button.getStatus()); |             NativeLibrary.onGamePadButtonEvent(NativeLibrary.Player1Device, button.getId(), button.getStatus()); | ||||||
|  |             should_update_view = true; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         for (InputOverlayDrawableDpad dpad : overlayDpads) { |         for (InputOverlayDrawableDpad dpad : overlayDpads) { | ||||||
|  | @ -378,6 +379,7 @@ public final class InputOverlay extends SurfaceView implements OnTouchListener, | ||||||
|             NativeLibrary.onGamePadButtonEvent(NativeLibrary.Player1Device, dpad.getDownId(), dpad.getDownStatus()); |             NativeLibrary.onGamePadButtonEvent(NativeLibrary.Player1Device, dpad.getDownId(), dpad.getDownStatus()); | ||||||
|             NativeLibrary.onGamePadButtonEvent(NativeLibrary.Player1Device, dpad.getLeftId(), dpad.getLeftStatus()); |             NativeLibrary.onGamePadButtonEvent(NativeLibrary.Player1Device, dpad.getLeftId(), dpad.getLeftStatus()); | ||||||
|             NativeLibrary.onGamePadButtonEvent(NativeLibrary.Player1Device, dpad.getRightId(), dpad.getRightStatus()); |             NativeLibrary.onGamePadButtonEvent(NativeLibrary.Player1Device, dpad.getRightId(), dpad.getRightStatus()); | ||||||
|  |             should_update_view = true; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         for (InputOverlayDrawableJoystick joystick : overlayJoysticks) { |         for (InputOverlayDrawableJoystick joystick : overlayJoysticks) { | ||||||
|  | @ -387,6 +389,11 @@ public final class InputOverlay extends SurfaceView implements OnTouchListener, | ||||||
|             int axisID = joystick.getJoystickId(); |             int axisID = joystick.getJoystickId(); | ||||||
|             NativeLibrary.onGamePadJoystickEvent(NativeLibrary.Player1Device, axisID, joystick.getXAxis(), joystick.getYAxis()); |             NativeLibrary.onGamePadJoystickEvent(NativeLibrary.Player1Device, axisID, joystick.getXAxis(), joystick.getYAxis()); | ||||||
|             NativeLibrary.onGamePadButtonEvent(NativeLibrary.Player1Device, joystick.getButtonId(), joystick.getButtonStatus()); |             NativeLibrary.onGamePadButtonEvent(NativeLibrary.Player1Device, joystick.getButtonId(), joystick.getButtonStatus()); | ||||||
|  |             should_update_view = true; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         if (should_update_view) { | ||||||
|  |             invalidate(); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (!mPreferences.getBoolean("isTouchEnabled", true)) { |         if (!mPreferences.getBoolean("isTouchEnabled", true)) { | ||||||
|  | @ -420,8 +427,6 @@ public final class InputOverlay extends SurfaceView implements OnTouchListener, | ||||||
|             NativeLibrary.onTouchReleased(pointerId); |             NativeLibrary.onTouchReleased(pointerId); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         invalidate(); |  | ||||||
| 
 |  | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -536,11 +541,11 @@ public final class InputOverlay extends SurfaceView implements OnTouchListener, | ||||||
|             overlayJoysticks.add(initializeOverlayJoystick(getContext(), R.drawable.joystick_range, |             overlayJoysticks.add(initializeOverlayJoystick(getContext(), R.drawable.joystick_range, | ||||||
|                     R.drawable.joystick, R.drawable.joystick_depressed, StickType.STICK_R, ButtonType.STICK_R, orientation)); |                     R.drawable.joystick, R.drawable.joystick_depressed, StickType.STICK_R, ButtonType.STICK_R, orientation)); | ||||||
|         } |         } | ||||||
|         if (mPreferences.getBoolean("buttonToggle13", true)) { |         if (mPreferences.getBoolean("buttonToggle13", false)) { | ||||||
|             overlayButtons.add(initializeOverlayButton(getContext(), R.drawable.facebutton_home, |             overlayButtons.add(initializeOverlayButton(getContext(), R.drawable.facebutton_home, | ||||||
|                     R.drawable.facebutton_home_depressed, ButtonType.BUTTON_HOME, orientation)); |                     R.drawable.facebutton_home_depressed, ButtonType.BUTTON_HOME, orientation)); | ||||||
|         } |         } | ||||||
|         if (mPreferences.getBoolean("buttonToggle14", true)) { |         if (mPreferences.getBoolean("buttonToggle14", false)) { | ||||||
|             overlayButtons.add(initializeOverlayButton(getContext(), R.drawable.facebutton_screenshot, |             overlayButtons.add(initializeOverlayButton(getContext(), R.drawable.facebutton_screenshot, | ||||||
|                     R.drawable.facebutton_screenshot_depressed, ButtonType.BUTTON_CAPTURE, orientation)); |                     R.drawable.facebutton_screenshot_depressed, ButtonType.BUTTON_CAPTURE, orientation)); | ||||||
|         } |         } | ||||||
|  | @ -580,7 +585,7 @@ public final class InputOverlay extends SurfaceView implements OnTouchListener, | ||||||
|         if (!mPreferences.getBoolean("OverlayInit", false)) { |         if (!mPreferences.getBoolean("OverlayInit", false)) { | ||||||
|             defaultOverlayLandscape(); |             defaultOverlayLandscape(); | ||||||
|         } |         } | ||||||
| 
 |         resetButtonPlacement(); | ||||||
|         SharedPreferences.Editor sPrefsEditor = mPreferences.edit(); |         SharedPreferences.Editor sPrefsEditor = mPreferences.edit(); | ||||||
|         sPrefsEditor.putBoolean("OverlayInit", true); |         sPrefsEditor.putBoolean("OverlayInit", true); | ||||||
|         sPrefsEditor.apply(); |         sPrefsEditor.apply(); | ||||||
|  | @ -596,7 +601,7 @@ public final class InputOverlay extends SurfaceView implements OnTouchListener, | ||||||
|         // Get screen size |         // Get screen size | ||||||
|         Display display = ((Activity) getContext()).getWindowManager().getDefaultDisplay(); |         Display display = ((Activity) getContext()).getWindowManager().getDefaultDisplay(); | ||||||
|         DisplayMetrics outMetrics = new DisplayMetrics(); |         DisplayMetrics outMetrics = new DisplayMetrics(); | ||||||
|         display.getMetrics(outMetrics); |         display.getRealMetrics(outMetrics); | ||||||
|         float maxX = outMetrics.heightPixels; |         float maxX = outMetrics.heightPixels; | ||||||
|         float maxY = outMetrics.widthPixels; |         float maxY = outMetrics.widthPixels; | ||||||
|         // Height and width changes depending on orientation. Use the larger value for height. |         // Height and width changes depending on orientation. Use the larger value for height. | ||||||
|  | @ -605,6 +610,7 @@ public final class InputOverlay extends SurfaceView implements OnTouchListener, | ||||||
|             maxX = maxY; |             maxX = maxY; | ||||||
|             maxY = tmp; |             maxY = tmp; | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|         Resources res = getResources(); |         Resources res = getResources(); | ||||||
| 
 | 
 | ||||||
|         // Each value is a percent from max X/Y stored as an int. Have to bring that value down |         // Each value is a percent from max X/Y stored as an int. Have to bring that value down | ||||||
|  | @ -621,8 +627,8 @@ public final class InputOverlay extends SurfaceView implements OnTouchListener, | ||||||
|         sPrefsEditor.putFloat(ButtonType.TRIGGER_ZL + "-Y", (((float) res.getInteger(R.integer.SWITCH_TRIGGER_ZL_Y) / 1000) * maxY)); |         sPrefsEditor.putFloat(ButtonType.TRIGGER_ZL + "-Y", (((float) res.getInteger(R.integer.SWITCH_TRIGGER_ZL_Y) / 1000) * maxY)); | ||||||
|         sPrefsEditor.putFloat(ButtonType.TRIGGER_ZR + "-X", (((float) res.getInteger(R.integer.SWITCH_TRIGGER_ZR_X) / 1000) * maxX)); |         sPrefsEditor.putFloat(ButtonType.TRIGGER_ZR + "-X", (((float) res.getInteger(R.integer.SWITCH_TRIGGER_ZR_X) / 1000) * maxX)); | ||||||
|         sPrefsEditor.putFloat(ButtonType.TRIGGER_ZR + "-Y", (((float) res.getInteger(R.integer.SWITCH_TRIGGER_ZR_Y) / 1000) * maxY)); |         sPrefsEditor.putFloat(ButtonType.TRIGGER_ZR + "-Y", (((float) res.getInteger(R.integer.SWITCH_TRIGGER_ZR_Y) / 1000) * maxY)); | ||||||
|         sPrefsEditor.putFloat(ButtonType.DPAD_UP + "-X", (((float) res.getInteger(R.integer.SWITCH_BUTTON_UP_X) / 1000) * maxX)); |         sPrefsEditor.putFloat(ButtonType.DPAD_UP + "-X", (((float) res.getInteger(R.integer.SWITCH_BUTTON_DPAD_X) / 1000) * maxX)); | ||||||
|         sPrefsEditor.putFloat(ButtonType.DPAD_UP + "-Y", (((float) res.getInteger(R.integer.SWITCH_BUTTON_UP_Y) / 1000) * maxY)); |         sPrefsEditor.putFloat(ButtonType.DPAD_UP + "-Y", (((float) res.getInteger(R.integer.SWITCH_BUTTON_DPAD_Y) / 1000) * maxY)); | ||||||
|         sPrefsEditor.putFloat(ButtonType.TRIGGER_L + "-X", (((float) res.getInteger(R.integer.SWITCH_TRIGGER_L_X) / 1000) * maxX)); |         sPrefsEditor.putFloat(ButtonType.TRIGGER_L + "-X", (((float) res.getInteger(R.integer.SWITCH_TRIGGER_L_X) / 1000) * maxX)); | ||||||
|         sPrefsEditor.putFloat(ButtonType.TRIGGER_L + "-Y", (((float) res.getInteger(R.integer.SWITCH_TRIGGER_L_Y) / 1000) * maxY)); |         sPrefsEditor.putFloat(ButtonType.TRIGGER_L + "-Y", (((float) res.getInteger(R.integer.SWITCH_TRIGGER_L_Y) / 1000) * maxY)); | ||||||
|         sPrefsEditor.putFloat(ButtonType.TRIGGER_R + "-X", (((float) res.getInteger(R.integer.SWITCH_TRIGGER_R_X) / 1000) * maxX)); |         sPrefsEditor.putFloat(ButtonType.TRIGGER_R + "-X", (((float) res.getInteger(R.integer.SWITCH_TRIGGER_R_X) / 1000) * maxX)); | ||||||
|  |  | ||||||
|  | @ -67,6 +67,7 @@ public final class InputOverlayDrawableButton { | ||||||
|         int motion_event = event.getAction() & MotionEvent.ACTION_MASK; |         int motion_event = event.getAction() & MotionEvent.ACTION_MASK; | ||||||
|         boolean isActionDown = motion_event == MotionEvent.ACTION_DOWN || motion_event == MotionEvent.ACTION_POINTER_DOWN; |         boolean isActionDown = motion_event == MotionEvent.ACTION_DOWN || motion_event == MotionEvent.ACTION_POINTER_DOWN; | ||||||
|         boolean isActionUp = motion_event == MotionEvent.ACTION_UP || motion_event == MotionEvent.ACTION_POINTER_UP; |         boolean isActionUp = motion_event == MotionEvent.ACTION_UP || motion_event == MotionEvent.ACTION_POINTER_UP; | ||||||
|  |         boolean current_state = mPressedState; | ||||||
| 
 | 
 | ||||||
|         if (isActionDown) { |         if (isActionDown) { | ||||||
|             if (!getBounds().contains(xPosition, yPosition)) { |             if (!getBounds().contains(xPosition, yPosition)) { | ||||||
|  |  | ||||||
|  | @ -121,12 +121,16 @@ public final class InputOverlayDrawableDpad { | ||||||
|             maxY -= getBounds().centerY(); |             maxY -= getBounds().centerY(); | ||||||
|             final float AxisX = touchX / maxX; |             final float AxisX = touchX / maxX; | ||||||
|             final float AxisY = touchY / maxY; |             final float AxisY = touchY / maxY; | ||||||
|  |             final boolean up_state = mUpButtonState; | ||||||
|  |             final boolean down_state = mDownButtonState; | ||||||
|  |             final boolean left_state = mLeftButtonState; | ||||||
|  |             final boolean right_state = mRightButtonState; | ||||||
| 
 | 
 | ||||||
|             mUpButtonState = AxisY < -InputOverlayDrawableDpad.VIRT_AXIS_DEADZONE; |             mUpButtonState = AxisY < -InputOverlayDrawableDpad.VIRT_AXIS_DEADZONE; | ||||||
|             mDownButtonState = AxisY > InputOverlayDrawableDpad.VIRT_AXIS_DEADZONE; |             mDownButtonState = AxisY > InputOverlayDrawableDpad.VIRT_AXIS_DEADZONE; | ||||||
|             mLeftButtonState = AxisX < -InputOverlayDrawableDpad.VIRT_AXIS_DEADZONE; |             mLeftButtonState = AxisX < -InputOverlayDrawableDpad.VIRT_AXIS_DEADZONE; | ||||||
|             mRightButtonState = AxisX > InputOverlayDrawableDpad.VIRT_AXIS_DEADZONE; |             mRightButtonState = AxisX > InputOverlayDrawableDpad.VIRT_AXIS_DEADZONE; | ||||||
|             return true; |             return up_state != mUpButtonState || down_state != mDownButtonState || left_state != mLeftButtonState || right_state != mRightButtonState; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return false; |         return false; | ||||||
|  |  | ||||||
|  | @ -140,6 +140,8 @@ public final class InputOverlayDrawableJoystick { | ||||||
|             maxY -= getVirtBounds().centerY(); |             maxY -= getVirtBounds().centerY(); | ||||||
|             final float AxisX = touchX / maxX; |             final float AxisX = touchX / maxX; | ||||||
|             final float AxisY = touchY / maxY; |             final float AxisY = touchY / maxY; | ||||||
|  |             final float oldXAxis = mXAxis; | ||||||
|  |             final float oldYAxis = mYAxis; | ||||||
| 
 | 
 | ||||||
|             // Clamp the circle pad input to a circle |             // Clamp the circle pad input to a circle | ||||||
|             final float angle = (float) Math.atan2(AxisY, AxisX); |             final float angle = (float) Math.atan2(AxisY, AxisX); | ||||||
|  | @ -150,7 +152,7 @@ public final class InputOverlayDrawableJoystick { | ||||||
|             mXAxis = ((float) Math.cos(angle) * radius); |             mXAxis = ((float) Math.cos(angle) * radius); | ||||||
|             mYAxis = ((float) Math.sin(angle) * radius); |             mYAxis = ((float) Math.sin(angle) * radius); | ||||||
|             SetInnerBounds(); |             SetInnerBounds(); | ||||||
|             return true; |             return oldXAxis != mXAxis && oldYAxis != mYAxis; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return false; |         return false; | ||||||
|  |  | ||||||
|  | @ -20,17 +20,17 @@ | ||||||
|         </aapt:attr> |         </aapt:attr> | ||||||
|     </path> |     </path> | ||||||
|     <path android:fillAlpha="0.6" |     <path android:fillAlpha="0.6" | ||||||
|         android:pathData="M18.74,64.84A132.8,132.8 0,1 0,200.8 18.74,132.8 132.8,0 0,0 18.74,64.84ZM230,190.72A113.12,113.12 0,1 1,190.72 35.64,113.12 113.12,0 0,1 230,190.72Z" android:strokeAlpha="0.6"> |         android:pathData="m18.72,64.82a132.8,132.8 0,1 0,182.06 -46.1,132.8 132.8,0 0,0 -182.06,46.1zM229.98,190.7a113.12,113.12 0,1 1,-39.28 -155.08,113.12 113.12,0 0,1 39.28,155.08z" android:strokeAlpha="0.6"> | ||||||
|         <aapt:attr name="android:fillColor"> |         <aapt:attr name="android:fillColor"> | ||||||
|             <gradient android:centerX="132.84" android:centerY="132.73" |             <gradient android:centerX="132.82" android:centerY="132.7" | ||||||
|                 android:gradientRadius="132.8" android:type="radial"> |                 android:gradientRadius="141.24" android:type="radial"> | ||||||
|                 <item android:color="#FF969696" android:offset="0"/> |                 <item android:color="#FF969696" android:offset="0"/> | ||||||
|                 <item android:color="#FF949494" android:offset="0.45"/> |                 <item android:color="#FF949494" android:offset="0.8"/> | ||||||
|                 <item android:color="#FF8D8D8D" android:offset="0.61"/> |                 <item android:color="#FF8D8D8D" android:offset="0.84"/> | ||||||
|                 <item android:color="#FF828282" android:offset="0.72"/> |                 <item android:color="#FF828282" android:offset="0.87"/> | ||||||
|                 <item android:color="#FF717171" android:offset="0.82"/> |                 <item android:color="#FF717171" android:offset="0.9"/> | ||||||
|                 <item android:color="#FF5B5B5B" android:offset="0.9"/> |                 <item android:color="#FF5B5B5B" android:offset="0.94"/> | ||||||
|                 <item android:color="#FF404040" android:offset="0.97"/> |                 <item android:color="#FF404040" android:offset="0.98"/> | ||||||
|                 <item android:color="#FF303030" android:offset="1"/> |                 <item android:color="#FF303030" android:offset="1"/> | ||||||
|             </gradient> |             </gradient> | ||||||
|         </aapt:attr> |         </aapt:attr> | ||||||
|  |  | ||||||
|  | @ -23,7 +23,7 @@ | ||||||
| 
 | 
 | ||||||
|     <TextView |     <TextView | ||||||
|         android:id="@+id/show_fps_text" |         android:id="@+id/show_fps_text" | ||||||
|         android:layout_marginStart="8dp" |         android:layout_marginStart="18dp" | ||||||
|         android:layout_marginTop="2dp" |         android:layout_marginTop="2dp" | ||||||
|         android:layout_width="wrap_content" |         android:layout_width="wrap_content" | ||||||
|         android:layout_height="wrap_content" |         android:layout_height="wrap_content" | ||||||
|  |  | ||||||
|  | @ -4,35 +4,35 @@ | ||||||
|     <integer name="game_grid_columns">1</integer> |     <integer name="game_grid_columns">1</integer> | ||||||
| 
 | 
 | ||||||
|     <!-- Default SWITCH landscape layout --> |     <!-- Default SWITCH landscape layout --> | ||||||
|     <integer name="SWITCH_BUTTON_A_X">930</integer> |     <integer name="SWITCH_BUTTON_A_X">760</integer> | ||||||
|     <integer name="SWITCH_BUTTON_A_Y">610</integer> |     <integer name="SWITCH_BUTTON_A_Y">810</integer> | ||||||
|     <integer name="SWITCH_BUTTON_B_X">870</integer> |     <integer name="SWITCH_BUTTON_B_X">710</integer> | ||||||
|     <integer name="SWITCH_BUTTON_B_Y">720</integer> |     <integer name="SWITCH_BUTTON_B_Y">920</integer> | ||||||
|     <integer name="SWITCH_BUTTON_X_X">870</integer> |     <integer name="SWITCH_BUTTON_X_X">710</integer> | ||||||
|     <integer name="SWITCH_BUTTON_X_Y">500</integer> |     <integer name="SWITCH_BUTTON_X_Y">700</integer> | ||||||
|     <integer name="SWITCH_BUTTON_Y_X">810</integer> |     <integer name="SWITCH_BUTTON_Y_X">660</integer> | ||||||
|     <integer name="SWITCH_BUTTON_Y_Y">610</integer> |     <integer name="SWITCH_BUTTON_Y_Y">810</integer> | ||||||
|     <integer name="SWITCH_STICK_L_X">170</integer> |     <integer name="SWITCH_STICK_L_X">100</integer> | ||||||
|     <integer name="SWITCH_STICK_L_Y">740</integer> |     <integer name="SWITCH_STICK_L_Y">670</integer> | ||||||
|     <integer name="SWITCH_STICK_R_X">715</integer> |     <integer name="SWITCH_STICK_R_X">900</integer> | ||||||
|     <integer name="SWITCH_STICK_R_Y">740</integer> |     <integer name="SWITCH_STICK_R_Y">670</integer> | ||||||
|     <integer name="SWITCH_TRIGGER_L_X">13</integer> |     <integer name="SWITCH_TRIGGER_L_X">70</integer> | ||||||
|     <integer name="SWITCH_TRIGGER_L_Y">125</integer> |     <integer name="SWITCH_TRIGGER_L_Y">220</integer> | ||||||
|     <integer name="SWITCH_TRIGGER_R_X">895</integer> |     <integer name="SWITCH_TRIGGER_R_X">930</integer> | ||||||
|     <integer name="SWITCH_TRIGGER_R_Y">125</integer> |     <integer name="SWITCH_TRIGGER_R_Y">220</integer> | ||||||
|     <integer name="SWITCH_TRIGGER_ZL_X">13</integer> |     <integer name="SWITCH_TRIGGER_ZL_X">70</integer> | ||||||
|     <integer name="SWITCH_TRIGGER_ZL_Y">0</integer> |     <integer name="SWITCH_TRIGGER_ZL_Y">90</integer> | ||||||
|     <integer name="SWITCH_TRIGGER_ZR_X">895</integer> |     <integer name="SWITCH_TRIGGER_ZR_X">930</integer> | ||||||
|     <integer name="SWITCH_TRIGGER_ZR_Y">0</integer> |     <integer name="SWITCH_TRIGGER_ZR_Y">90</integer> | ||||||
|     <integer name="SWITCH_BUTTON_MINUS_X">440</integer> |     <integer name="SWITCH_BUTTON_MINUS_X">460</integer> | ||||||
|     <integer name="SWITCH_BUTTON_MINUS_Y">850</integer> |     <integer name="SWITCH_BUTTON_MINUS_Y">955</integer> | ||||||
|     <integer name="SWITCH_BUTTON_PLUS_X">520</integer> |     <integer name="SWITCH_BUTTON_PLUS_X">540</integer> | ||||||
|     <integer name="SWITCH_BUTTON_PLUS_Y">850</integer> |     <integer name="SWITCH_BUTTON_PLUS_Y">955</integer> | ||||||
|     <integer name="SWITCH_BUTTON_HOME_X">600</integer> |     <integer name="SWITCH_BUTTON_HOME_X">620</integer> | ||||||
|     <integer name="SWITCH_BUTTON_HOME_Y">890</integer> |     <integer name="SWITCH_BUTTON_HOME_Y">960</integer> | ||||||
|     <integer name="SWITCH_BUTTON_CAPTURE_X">360</integer> |     <integer name="SWITCH_BUTTON_CAPTURE_X">380</integer> | ||||||
|     <integer name="SWITCH_BUTTON_CAPTURE_Y">890</integer> |     <integer name="SWITCH_BUTTON_CAPTURE_Y">960</integer> | ||||||
|     <integer name="SWITCH_BUTTON_UP_X">35</integer> |     <integer name="SWITCH_BUTTON_DPAD_X">260</integer> | ||||||
|     <integer name="SWITCH_BUTTON_UP_Y">480</integer> |     <integer name="SWITCH_BUTTON_DPAD_Y">810</integer> | ||||||
| 
 | 
 | ||||||
| </resources> | </resources> | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 german77
						german77