diff options
Diffstat (limited to 'platform/android/java/src')
5 files changed, 111 insertions, 85 deletions
| diff --git a/platform/android/java/src/org/godotengine/godot/Godot.java b/platform/android/java/src/org/godotengine/godot/Godot.java index ab37f7a02c..88194f00d1 100644 --- a/platform/android/java/src/org/godotengine/godot/Godot.java +++ b/platform/android/java/src/org/godotengine/godot/Godot.java @@ -279,7 +279,7 @@ public class Godot extends Activity implements SensorEventListener, IDownloaderC  		// ...add to FrameLayout  		layout.addView(edittext); -		mView = new GodotView(getApplication(), io, use_gl3, use_32_bits, use_debug_opengl,this); +		mView = new GodotView(getApplication(), io, use_gl3, use_32_bits, use_debug_opengl, this);  		layout.addView(mView, new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));  		edittext.setView(mView);  		io.setEdit(edittext); diff --git a/platform/android/java/src/org/godotengine/godot/GodotView.java b/platform/android/java/src/org/godotengine/godot/GodotView.java index 181ffc3b4b..4cb4db33de 100644 --- a/platform/android/java/src/org/godotengine/godot/GodotView.java +++ b/platform/android/java/src/org/godotengine/godot/GodotView.java @@ -86,7 +86,7 @@ public class GodotView extends GLSurfaceView implements InputDeviceListener {  	private Godot activity;  	private InputManagerCompat mInputManager; -	public GodotView(Context context, GodotIO p_io, boolean p_use_gl3, boolean p_use_32_bits, boolean p_use_debug_opengl,Godot p_activity) { +	public GodotView(Context context, GodotIO p_io, boolean p_use_gl3, boolean p_use_32_bits, boolean p_use_debug_opengl, Godot p_activity) {  		super(context);  		ctx = context;  		io = p_io; @@ -204,48 +204,65 @@ public class GodotView extends GLSurfaceView implements InputDeviceListener {  				return i;  			}  		} -		onInputDeviceAdded(device_id); -		return joy_devices.size() - 1; + +		return -1;  	}  	@Override  	public void onInputDeviceAdded(int deviceId) { -		joystick joy = new joystick(); -		joy.device_id = deviceId; -		final int id = joy_devices.size(); -		InputDevice device = mInputManager.getInputDevice(deviceId); -		final String name = device.getName(); -		joy.name = device.getName(); -		joy.axes = new ArrayList<InputDevice.MotionRange>(); -		joy.hats = new ArrayList<InputDevice.MotionRange>(); -		List<InputDevice.MotionRange> ranges = device.getMotionRanges(); -		Collections.sort(ranges, new RangeComparator()); -		for (InputDevice.MotionRange range : ranges) { -			if (range.getAxis() == MotionEvent.AXIS_HAT_X || range.getAxis() == MotionEvent.AXIS_HAT_Y) { -				joy.hats.add(range); -			} else { -				joy.axes.add(range); +		int id = find_joy_device(deviceId); + +		// Check if the device has not been already added +		if (id < 0) { +			InputDevice device = mInputManager.getInputDevice(deviceId); + +			id = joy_devices.size(); + +			joystick joy = new joystick(); +			joy.device_id = deviceId; +			joy.name = device.getName(); +			joy.axes = new ArrayList<InputDevice.MotionRange>(); +			joy.hats = new ArrayList<InputDevice.MotionRange>(); + +			List<InputDevice.MotionRange> ranges = device.getMotionRanges(); +			Collections.sort(ranges, new RangeComparator()); + +			for (InputDevice.MotionRange range : ranges) { +				if (range.getAxis() == MotionEvent.AXIS_HAT_X || range.getAxis() == MotionEvent.AXIS_HAT_Y) { +					joy.hats.add(range); +				} else { +					joy.axes.add(range); +				}  			} + +			joy_devices.add(joy); + +			final int device_id = id; +			final String name = joy.name; +			queueEvent(new Runnable() { +				@Override +				public void run() { +					GodotLib.joyconnectionchanged(device_id, true, name); +				} +			});  		} -		joy_devices.add(joy); -		queueEvent(new Runnable() { -			@Override -			public void run() { -				GodotLib.joyconnectionchanged(id, true, name); -			} -		});  	}  	@Override  	public void onInputDeviceRemoved(int deviceId) { -		final int id = find_joy_device(deviceId); -		joy_devices.remove(id); -		queueEvent(new Runnable() { -			@Override -			public void run() { -				GodotLib.joyconnectionchanged(id, false, ""); -			} -		}); +		final int device_id = find_joy_device(deviceId); + +		// Check if the evice has not been already removed +		if (device_id > -1) { +			joy_devices.remove(device_id); + +			queueEvent(new Runnable() { +				@Override +				public void run() { +					GodotLib.joyconnectionchanged(device_id, false, ""); +				} +			}); +		}  	}  	@Override @@ -266,15 +283,18 @@ public class GodotView extends GLSurfaceView implements InputDeviceListener {  		if ((source & InputDevice.SOURCE_JOYSTICK) == InputDevice.SOURCE_JOYSTICK || (source & InputDevice.SOURCE_DPAD) == InputDevice.SOURCE_DPAD || (source & InputDevice.SOURCE_GAMEPAD) == InputDevice.SOURCE_GAMEPAD) {  			final int button = get_godot_button(keyCode); -			final int device = find_joy_device(event.getDeviceId()); +			final int device_id = find_joy_device(event.getDeviceId()); -			queueEvent(new Runnable() { -				@Override -				public void run() { -					GodotLib.joybutton(device, button, false); -				} -			}); -			return true; +			// Check if the device exists +			if (device_id > -1) { +				queueEvent(new Runnable() { +					@Override +					public void run() { +						GodotLib.joybutton(device_id, button, false); +					} +				}); +				return true; +			}  		} else {  			final int chr = event.getUnicodeChar(0);  			queueEvent(new Runnable() { @@ -284,6 +304,7 @@ public class GodotView extends GLSurfaceView implements InputDeviceListener {  				}  			});  		}; +  		return super.onKeyUp(keyCode, event);  	}; @@ -308,18 +329,20 @@ public class GodotView extends GLSurfaceView implements InputDeviceListener {  			if (event.getRepeatCount() > 0) // ignore key echo  				return true; -			final int button = get_godot_button(keyCode); -			final int device = find_joy_device(event.getDeviceId()); -			//Log.e(TAG, String.format("joy button down! button %x, %d, device %d", keyCode, button, device)); -			queueEvent(new Runnable() { -				@Override -				public void run() { -					GodotLib.joybutton(device, button, true); -				} -			}); -			return true; +			final int button = get_godot_button(keyCode); +			final int device_id = find_joy_device(event.getDeviceId()); +			// Check if the device exists +			if (device_id > -1) { +				queueEvent(new Runnable() { +					@Override +					public void run() { +						GodotLib.joybutton(device_id, button, true); +					} +				}); +				return true; +			}  		} else {  			final int chr = event.getUnicodeChar(0);  			queueEvent(new Runnable() { @@ -329,6 +352,7 @@ public class GodotView extends GLSurfaceView implements InputDeviceListener {  				}  			});  		}; +  		return super.onKeyDown(keyCode, event);  	} @@ -338,33 +362,35 @@ public class GodotView extends GLSurfaceView implements InputDeviceListener {  		if ((event.getSource() & InputDevice.SOURCE_JOYSTICK) == InputDevice.SOURCE_JOYSTICK && event.getAction() == MotionEvent.ACTION_MOVE) {  			final int device_id = find_joy_device(event.getDeviceId()); -			joystick joy = joy_devices.get(device_id); -			for (int i = 0; i < joy.axes.size(); i++) { -				InputDevice.MotionRange range = joy.axes.get(i); -				final float value = (event.getAxisValue(range.getAxis()) - range.getMin()) / range.getRange() * 2.0f - 1.0f; -				//Log.e(TAG, String.format("axis event: %d, value %f", i, value)); -				final int idx = i; -				queueEvent(new Runnable() { -					@Override -					public void run() { -						GodotLib.joyaxis(device_id, idx, value); -					} -				}); -			} +			// Check if the device exists +			if (device_id > -1) { +				joystick joy = joy_devices.get(device_id); + +				for (int i = 0; i < joy.axes.size(); i++) { +					InputDevice.MotionRange range = joy.axes.get(i); +					final float value = (event.getAxisValue(range.getAxis()) - range.getMin()) / range.getRange() * 2.0f - 1.0f; +					final int idx = i; +					queueEvent(new Runnable() { +						@Override +						public void run() { +							GodotLib.joyaxis(device_id, idx, value); +						} +					}); +				} -			for (int i = 0; i < joy.hats.size(); i += 2) { -				final int hatX = Math.round(event.getAxisValue(joy.hats.get(i).getAxis())); -				final int hatY = Math.round(event.getAxisValue(joy.hats.get(i + 1).getAxis())); -				//Log.e(TAG, String.format("HAT EVENT %d, %d", hatX, hatY)); -				queueEvent(new Runnable() { -					@Override -					public void run() { -						GodotLib.joyhat(device_id, hatX, hatY); -					} -				}); +				for (int i = 0; i < joy.hats.size(); i += 2) { +					final int hatX = Math.round(event.getAxisValue(joy.hats.get(i).getAxis())); +					final int hatY = Math.round(event.getAxisValue(joy.hats.get(i + 1).getAxis())); +					queueEvent(new Runnable() { +						@Override +						public void run() { +							GodotLib.joyhat(device_id, hatX, hatY); +						} +					}); +				} +				return true;  			} -			return true;  		};  		return super.onGenericMotionEvent(event); @@ -408,9 +434,9 @@ public class GodotView extends GLSurfaceView implements InputDeviceListener {  		setRenderer(new Renderer());  	} -	private static final int  _EGL_CONTEXT_FLAGS_KHR = 0x30FC; -	private static final int  _EGL_CONTEXT_OPENGL_DEBUG_BIT_KHR= 0x00000001; -	 +	private static final int _EGL_CONTEXT_FLAGS_KHR = 0x30FC; +	private static final int _EGL_CONTEXT_OPENGL_DEBUG_BIT_KHR = 0x00000001; +  	private static class ContextFactory implements GLSurfaceView.EGLContextFactory {  		private static int EGL_CONTEXT_CLIENT_VERSION = 0x3098;  		public EGLContext createContext(EGL10 egl, EGLDisplay display, EGLConfig eglConfig) { @@ -422,9 +448,9 @@ public class GodotView extends GLSurfaceView implements InputDeviceListener {  			checkEglError("Before eglCreateContext", egl);  			EGLContext context;  			if (use_debug_opengl) { -				int[] attrib_list2 = { EGL_CONTEXT_CLIENT_VERSION, 2,_EGL_CONTEXT_FLAGS_KHR,_EGL_CONTEXT_OPENGL_DEBUG_BIT_KHR, EGL10.EGL_NONE }; -				int[] attrib_list3 = { EGL_CONTEXT_CLIENT_VERSION, 3,_EGL_CONTEXT_FLAGS_KHR,_EGL_CONTEXT_OPENGL_DEBUG_BIT_KHR, EGL10.EGL_NONE }; -				context = egl.eglCreateContext(display, eglConfig, EGL10.EGL_NO_CONTEXT, use_gl3 ? attrib_list3 : attrib_list2);			 +				int[] attrib_list2 = { EGL_CONTEXT_CLIENT_VERSION, 2, _EGL_CONTEXT_FLAGS_KHR, _EGL_CONTEXT_OPENGL_DEBUG_BIT_KHR, EGL10.EGL_NONE }; +				int[] attrib_list3 = { EGL_CONTEXT_CLIENT_VERSION, 3, _EGL_CONTEXT_FLAGS_KHR, _EGL_CONTEXT_OPENGL_DEBUG_BIT_KHR, EGL10.EGL_NONE }; +				context = egl.eglCreateContext(display, eglConfig, EGL10.EGL_NO_CONTEXT, use_gl3 ? attrib_list3 : attrib_list2);  			} else {  				int[] attrib_list2 = { EGL_CONTEXT_CLIENT_VERSION, 2, EGL10.EGL_NONE };  				int[] attrib_list3 = { EGL_CONTEXT_CLIENT_VERSION, 3, EGL10.EGL_NONE }; diff --git a/platform/android/java/src/org/godotengine/godot/utils/CustomSSLSocketFactory.java b/platform/android/java/src/org/godotengine/godot/utils/CustomSSLSocketFactory.java index 7216d8b5a4..03a7a71bb1 100644 --- a/platform/android/java/src/org/godotengine/godot/utils/CustomSSLSocketFactory.java +++ b/platform/android/java/src/org/godotengine/godot/utils/CustomSSLSocketFactory.java @@ -44,7 +44,7 @@ import javax.net.ssl.TrustManagerFactory;  import org.apache.http.conn.ssl.SSLSocketFactory;  /** - *  + *   * @author Luis Linietsky <luis.linietsky@gmail.com>   */  public class CustomSSLSocketFactory extends SSLSocketFactory { diff --git a/platform/android/java/src/org/godotengine/godot/utils/HttpRequester.java b/platform/android/java/src/org/godotengine/godot/utils/HttpRequester.java index b84f5cce2e..cfe9c4fef0 100644 --- a/platform/android/java/src/org/godotengine/godot/utils/HttpRequester.java +++ b/platform/android/java/src/org/godotengine/godot/utils/HttpRequester.java @@ -69,7 +69,7 @@ import android.content.SharedPreferences;  import android.util.Log;  /** - *  + *   * @author Luis Linietsky <luis.linietsky@gmail.com>   */  public class HttpRequester { diff --git a/platform/android/java/src/org/godotengine/godot/utils/RequestParams.java b/platform/android/java/src/org/godotengine/godot/utils/RequestParams.java index 2368766afa..a1d5b26b3c 100644 --- a/platform/android/java/src/org/godotengine/godot/utils/RequestParams.java +++ b/platform/android/java/src/org/godotengine/godot/utils/RequestParams.java @@ -39,7 +39,7 @@ import org.apache.http.NameValuePair;  import org.apache.http.message.BasicNameValuePair;  /** - *  + *   * @author Luis Linietsky <luis.linietsky@gmail.com>   */  public class RequestParams { |