diff options
Diffstat (limited to 'platform/android/java')
9 files changed, 59 insertions, 56 deletions
| diff --git a/platform/android/java/app/config.gradle b/platform/android/java/app/config.gradle index 0346625e4b..e1d9dc4cde 100644 --- a/platform/android/java/app/config.gradle +++ b/platform/android/java/app/config.gradle @@ -1,10 +1,10 @@  ext.versions = [ -    androidGradlePlugin: '7.0.3', +    androidGradlePlugin: '7.2.1',      compileSdk         : 32, -    minSdk             : 19, // Also update 'platform/android/java/lib/AndroidManifest.xml#minSdkVersion' & 'platform/android/export/export_plugin.cpp#DEFAULT_MIN_SDK_VERSION' -    targetSdk          : 32, // Also update 'platform/android/java/lib/AndroidManifest.xml#targetSdkVersion' & 'platform/android/export/export_plugin.cpp#DEFAULT_TARGET_SDK_VERSION' +    minSdk             : 19, // Also update 'platform/android/export/export_plugin.cpp#DEFAULT_MIN_SDK_VERSION' +    targetSdk          : 32, // Also update 'platform/android/export/export_plugin.cpp#DEFAULT_TARGET_SDK_VERSION'      buildTools         : '32.0.0', -    kotlinVersion      : '1.6.21', +    kotlinVersion      : '1.7.0',      fragmentVersion    : '1.3.6',      nexusPublishVersion: '1.1.0',      javaVersion        : 11, diff --git a/platform/android/java/editor/src/main/java/org/godotengine/editor/GodotEditor.kt b/platform/android/java/editor/src/main/java/org/godotengine/editor/GodotEditor.kt index 489a81fc1a..46a334ef38 100644 --- a/platform/android/java/editor/src/main/java/org/godotengine/editor/GodotEditor.kt +++ b/platform/android/java/editor/src/main/java/org/godotengine/editor/GodotEditor.kt @@ -37,10 +37,12 @@ import android.os.Build  import android.os.Bundle  import android.os.Debug  import android.os.Environment +import android.util.Log  import android.widget.Toast  import androidx.window.layout.WindowMetricsCalculator  import org.godotengine.godot.FullScreenGodotApp  import org.godotengine.godot.utils.PermissionsUtil +import org.godotengine.godot.utils.ProcessPhoenix  import java.util.*  import kotlin.math.min @@ -56,12 +58,17 @@ import kotlin.math.min  open class GodotEditor : FullScreenGodotApp() {  	companion object { +		private val TAG = GodotEditor::class.java.simpleName +  		private const val WAIT_FOR_DEBUGGER = false  		private const val COMMAND_LINE_PARAMS = "command_line_params"  		private const val EDITOR_ARG = "--editor" +		private const val EDITOR_ARG_SHORT = "-e" +  		private const val PROJECT_MANAGER_ARG = "--project-manager" +		private const val PROJECT_MANAGER_ARG_SHORT = "-p"  	}  	private val commandLineParams = ArrayList<String>() @@ -105,13 +112,13 @@ open class GodotEditor : FullScreenGodotApp() {  			Build.VERSION.SDK_INT >= Build.VERSION_CODES.N && (isInMultiWindowMode || isLargeScreen)  		for (arg in args) { -			if (EDITOR_ARG == arg) { +			if (EDITOR_ARG == arg || EDITOR_ARG_SHORT == arg) {  				targetClass = GodotEditor::class.java  				launchAdjacent = false  				break  			} -			if (PROJECT_MANAGER_ARG == arg) { +			if (PROJECT_MANAGER_ARG == arg || PROJECT_MANAGER_ARG_SHORT == arg) {  				targetClass = GodotProjectManager::class.java  				launchAdjacent = false  				break @@ -125,7 +132,13 @@ open class GodotEditor : FullScreenGodotApp() {  		if (launchAdjacent) {  			newInstance.addFlags(Intent.FLAG_ACTIVITY_LAUNCH_ADJACENT)  		} -		startActivity(newInstance) +		if (targetClass == javaClass) { +			Log.d(TAG, "Restarting $targetClass") +			ProcessPhoenix.triggerRebirth(this, newInstance) +		} else { +			Log.d(TAG, "Starting $targetClass") +			startActivity(newInstance) +		}  	}  	// Get the screen's density scale diff --git a/platform/android/java/gradle/wrapper/gradle-wrapper.properties b/platform/android/java/gradle/wrapper/gradle-wrapper.properties index ffed3a254e..41dfb87909 100644 --- a/platform/android/java/gradle/wrapper/gradle-wrapper.properties +++ b/platform/android/java/gradle/wrapper/gradle-wrapper.properties @@ -1,5 +1,5 @@  distributionBase=GRADLE_USER_HOME  distributionPath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-7.2-bin.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-7.4-bin.zip  zipStoreBase=GRADLE_USER_HOME  zipStorePath=wrapper/dists diff --git a/platform/android/java/lib/AndroidManifest.xml b/platform/android/java/lib/AndroidManifest.xml index 79b5aadf2a..1f77e2fc34 100644 --- a/platform/android/java/lib/AndroidManifest.xml +++ b/platform/android/java/lib/AndroidManifest.xml @@ -4,9 +4,6 @@      android:versionCode="1"      android:versionName="1.0"> -    <!-- Should match the mindSdk and targetSdk values in platform/android/java/app/config.gradle --> -    <uses-sdk android:minSdkVersion="19" android:targetSdkVersion="32" /> -      <application>          <!-- Records the version of the Godot library --> diff --git a/platform/android/java/lib/build.gradle b/platform/android/java/lib/build.gradle index c9e2a5d7d2..841656a240 100644 --- a/platform/android/java/lib/build.gradle +++ b/platform/android/java/lib/build.gradle @@ -176,11 +176,10 @@ android {          }      } -    // TODO: Enable when issues with AGP 7.1+ are resolved (https://github.com/GodotVR/godot_openxr/issues/187). -//    publishing { -//        singleVariant("templateRelease") { -//            withSourcesJar() -//            withJavadocJar() -//        } -//    } +    publishing { +        singleVariant("templateRelease") { +            withSourcesJar() +            withJavadocJar() +        } +    }  } diff --git a/platform/android/java/lib/src/org/godotengine/godot/Godot.java b/platform/android/java/lib/src/org/godotengine/godot/Godot.java index 92e5e59496..a002a37ab9 100644 --- a/platform/android/java/lib/src/org/godotengine/godot/Godot.java +++ b/platform/android/java/lib/src/org/godotengine/godot/Godot.java @@ -299,7 +299,7 @@ public class Godot extends Fragment implements SensorEventListener, IDownloaderC  			for (GodotPlugin plugin : pluginRegistry.getAllPlugins()) {  				plugin.onRegisterPluginWithGodotNative();  			} -			setKeepScreenOn("True".equals(GodotLib.getGlobal("display/window/energy_saving/keep_screen_on"))); +			setKeepScreenOn(Boolean.parseBoolean(GodotLib.getGlobal("display/window/energy_saving/keep_screen_on")));  		});  		// Include the returned non-null views in the Godot view hierarchy. diff --git a/platform/android/java/lib/src/org/godotengine/godot/input/GodotEditText.java b/platform/android/java/lib/src/org/godotengine/godot/input/GodotEditText.java index 7925b54fc4..804dbaf165 100644 --- a/platform/android/java/lib/src/org/godotengine/godot/input/GodotEditText.java +++ b/platform/android/java/lib/src/org/godotengine/godot/input/GodotEditText.java @@ -127,7 +127,9 @@ public class GodotEditText extends EditText {  					edit.setText("");  					edit.append(text);  					if (msg.arg2 != -1) { -						edit.setSelection(msg.arg1, msg.arg2); +						int selectionStart = Math.min(msg.arg1, edit.length()); +						int selectionEnd = Math.min(msg.arg2, edit.length()); +						edit.setSelection(selectionStart, selectionEnd);  						edit.mInputWrapper.setSelection(true);  					} else {  						edit.mInputWrapper.setSelection(false); diff --git a/platform/android/java/lib/src/org/godotengine/godot/input/GodotGestureHandler.kt b/platform/android/java/lib/src/org/godotengine/godot/input/GodotGestureHandler.kt index a7a57621de..cde8d7cdae 100644 --- a/platform/android/java/lib/src/org/godotengine/godot/input/GodotGestureHandler.kt +++ b/platform/android/java/lib/src/org/godotengine/godot/input/GodotGestureHandler.kt @@ -77,7 +77,7 @@ internal class GodotGestureHandler : SimpleOnGestureListener(), OnScaleGestureLi  	}  	private fun contextClickRouter(event: MotionEvent) { -		if (scaleInProgress) { +		if (scaleInProgress || nextDownIsDoubleTap) {  			return  		} @@ -134,40 +134,24 @@ internal class GodotGestureHandler : SimpleOnGestureListener(), OnScaleGestureLi  	}  	private fun onActionUp(event: MotionEvent): Boolean { +		if (event.actionMasked == MotionEvent.ACTION_CANCEL && pointerCaptureInProgress) { +			// Don't dispatch the ACTION_CANCEL while a capture is in progress +			return true +		} +  		val sourceMouseRelative = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {  			event.isFromSource(InputDevice.SOURCE_MOUSE_RELATIVE)  		} else {  			false  		} -		when { -			pointerCaptureInProgress -> { -				return if (event.actionMasked == MotionEvent.ACTION_CANCEL) { -					// Don't dispatch the ACTION_CANCEL while a capture is in progress -					true -				} else { -					GodotInputHandler.handleMouseEvent( -						MotionEvent.ACTION_UP, -						event.buttonState, -						event.x, -						event.y, -						0f, -						0f, -						false, -						sourceMouseRelative -					) -					pointerCaptureInProgress = false -					true -				} -			} -			dragInProgress -> { -				GodotInputHandler.handleMotionEvent(event) -				dragInProgress = false -				return true -			} -			contextClickInProgress -> { + +		if (pointerCaptureInProgress || dragInProgress || contextClickInProgress) { +			if (contextClickInProgress || GodotInputHandler.isMouseEvent(event)) { +				// This may be an ACTION_BUTTON_RELEASE event which we don't handle, +				// so we convert it to an ACTION_UP event.  				GodotInputHandler.handleMouseEvent( -					event.actionMasked, -					0, +					MotionEvent.ACTION_UP, +					event.buttonState,  					event.x,  					event.y,  					0f, @@ -175,11 +159,16 @@ internal class GodotGestureHandler : SimpleOnGestureListener(), OnScaleGestureLi  					false,  					sourceMouseRelative  				) -				contextClickInProgress = false -				return true +			} else { +				GodotInputHandler.handleTouchEvent(event)  			} -			else -> return false +			pointerCaptureInProgress = false +			dragInProgress = false +			contextClickInProgress = false +			return true  		} + +		return false  	}  	private fun onActionMove(event: MotionEvent): Boolean { @@ -242,7 +231,7 @@ internal class GodotGestureHandler : SimpleOnGestureListener(), OnScaleGestureLi  		val x = terminusEvent.x  		val y = terminusEvent.y -		if (terminusEvent.pointerCount >= 2 && panningAndScalingEnabled) { +		if (terminusEvent.pointerCount >= 2 && panningAndScalingEnabled && !pointerCaptureInProgress) {  			GodotLib.pan(x, y, distanceX / 5f, distanceY / 5f)  		} else {  			GodotInputHandler.handleMotionEvent(terminusEvent) @@ -251,7 +240,7 @@ internal class GodotGestureHandler : SimpleOnGestureListener(), OnScaleGestureLi  	}  	override fun onScale(detector: ScaleGestureDetector?): Boolean { -		if (detector == null || !panningAndScalingEnabled) { +		if (detector == null || !panningAndScalingEnabled || pointerCaptureInProgress) {  			return false  		}  		GodotLib.magnify( @@ -263,7 +252,7 @@ internal class GodotGestureHandler : SimpleOnGestureListener(), OnScaleGestureLi  	}  	override fun onScaleBegin(detector: ScaleGestureDetector?): Boolean { -		if (detector == null || !panningAndScalingEnabled) { +		if (detector == null || !panningAndScalingEnabled || pointerCaptureInProgress) {  			return false  		}  		scaleInProgress = true diff --git a/platform/android/java/lib/src/org/godotengine/godot/input/GodotInputHandler.java b/platform/android/java/lib/src/org/godotengine/godot/input/GodotInputHandler.java index d2f3c5aed2..2f26497cc8 100644 --- a/platform/android/java/lib/src/org/godotengine/godot/input/GodotInputHandler.java +++ b/platform/android/java/lib/src/org/godotengine/godot/input/GodotInputHandler.java @@ -245,7 +245,7 @@ public class GodotInputHandler implements InputManager.InputDeviceListener {  				}  				return true;  			} -		} else if (isMouseEvent(event)) { +		} else {  			return handleMouseEvent(event);  		} @@ -473,6 +473,9 @@ public class GodotInputHandler implements InputManager.InputDeviceListener {  	}  	static boolean handleMouseEvent(int eventAction, int buttonsMask, float x, float y, float deltaX, float deltaY, boolean doubleClick, boolean sourceMouseRelative) { +		// We don't handle ACTION_BUTTON_PRESS and ACTION_BUTTON_RELEASE events as they typically +		// follow ACTION_DOWN and ACTION_UP events. As such, handling them would result in duplicate +		// stream of events to the engine.  		switch (eventAction) {  			case MotionEvent.ACTION_CANCEL:  			case MotionEvent.ACTION_UP: |