summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTobrun <tobrun.van.nuland@gmail.com>2017-11-23 08:29:50 +0100
committerTobrun <tobrun.van.nuland@gmail.com>2017-11-23 08:34:49 +0100
commit4f6efcd3f451e2c32b1c7bc8a494ae227d480528 (patch)
tree3af4f0a915effb6a6a526e9aab321a02f6093263
parent405d141b9e9453fe57af0f5d6b6e22c5e3a0ac72 (diff)
downloadqtlocation-mapboxgl-upstream/tvn-concurrent-list.tar.gz
[android] - use concurrent lists for camera change listenersupstream/tvn-concurrent-list
-rw-r--r--platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/maps/CameraChangeDispatcher.java51
1 files changed, 25 insertions, 26 deletions
diff --git a/platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/maps/CameraChangeDispatcher.java b/platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/maps/CameraChangeDispatcher.java
index cf780dcc3f..f046744c31 100644
--- a/platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/maps/CameraChangeDispatcher.java
+++ b/platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/maps/CameraChangeDispatcher.java
@@ -2,8 +2,7 @@ package com.mapbox.mapboxsdk.maps;
import android.support.annotation.NonNull;
-import java.util.ArrayList;
-import java.util.List;
+import java.util.concurrent.CopyOnWriteArrayList;
import static com.mapbox.mapboxsdk.maps.MapboxMap.OnCameraIdleListener;
import static com.mapbox.mapboxsdk.maps.MapboxMap.OnCameraMoveCanceledListener;
@@ -15,10 +14,10 @@ class CameraChangeDispatcher implements MapboxMap.OnCameraMoveStartedListener, M
private boolean idle = true;
- private final List<OnCameraMoveStartedListener> onCameraMoveStartedListenerList = new ArrayList<>();
- private final List<OnCameraMoveCanceledListener> onCameraMoveCanceledListenerList = new ArrayList<>();
- private final List<OnCameraMoveListener> onCameraMoveListenerList = new ArrayList<>();
- private final List<OnCameraIdleListener> onCameraIdleListenerList = new ArrayList<>();
+ private final CopyOnWriteArrayList<OnCameraMoveStartedListener> onCameraMoveStarted = new CopyOnWriteArrayList<>();
+ private final CopyOnWriteArrayList<OnCameraMoveCanceledListener> onCameraMoveCanceled = new CopyOnWriteArrayList<>();
+ private final CopyOnWriteArrayList<OnCameraMoveListener> onCameraMove = new CopyOnWriteArrayList<>();
+ private final CopyOnWriteArrayList<OnCameraIdleListener> onCameraIdle = new CopyOnWriteArrayList<>();
private OnCameraMoveStartedListener onCameraMoveStartedListener;
private OnCameraMoveCanceledListener onCameraMoveCanceledListener;
@@ -58,8 +57,8 @@ class CameraChangeDispatcher implements MapboxMap.OnCameraMoveStartedListener, M
}
// new API
- if (!onCameraMoveStartedListenerList.isEmpty()) {
- for (OnCameraMoveStartedListener cameraMoveStartedListener : onCameraMoveStartedListenerList) {
+ if (!onCameraMoveStarted.isEmpty()) {
+ for (OnCameraMoveStartedListener cameraMoveStartedListener : onCameraMoveStarted) {
cameraMoveStartedListener.onCameraMoveStarted(reason);
}
}
@@ -73,8 +72,8 @@ class CameraChangeDispatcher implements MapboxMap.OnCameraMoveStartedListener, M
}
// new API
- if (!onCameraMoveListenerList.isEmpty() && !idle) {
- for (OnCameraMoveListener cameraMoveListener : onCameraMoveListenerList) {
+ if (!onCameraMove.isEmpty() && !idle) {
+ for (OnCameraMoveListener cameraMoveListener : onCameraMove) {
cameraMoveListener.onCameraMove();
}
}
@@ -88,8 +87,8 @@ class CameraChangeDispatcher implements MapboxMap.OnCameraMoveStartedListener, M
}
// new API
- if (!onCameraMoveCanceledListenerList.isEmpty() && !idle) {
- for (OnCameraMoveCanceledListener cameraMoveCanceledListener : onCameraMoveCanceledListenerList) {
+ if (!onCameraMoveCanceled.isEmpty() && !idle) {
+ for (OnCameraMoveCanceledListener cameraMoveCanceledListener : onCameraMoveCanceled) {
cameraMoveCanceledListener.onCameraMoveCanceled();
}
}
@@ -105,8 +104,8 @@ class CameraChangeDispatcher implements MapboxMap.OnCameraMoveStartedListener, M
}
// new API
- if (!onCameraIdleListenerList.isEmpty()) {
- for (OnCameraIdleListener cameraIdleListener : onCameraIdleListenerList) {
+ if (!onCameraIdle.isEmpty()) {
+ for (OnCameraIdleListener cameraIdleListener : onCameraIdle) {
cameraIdleListener.onCameraIdle();
}
}
@@ -114,42 +113,42 @@ class CameraChangeDispatcher implements MapboxMap.OnCameraMoveStartedListener, M
}
void addOnCameraIdleListener(@NonNull OnCameraIdleListener listener) {
- onCameraIdleListenerList.add(listener);
+ onCameraIdle.add(listener);
}
void removeOnCameraIdleListener(@NonNull OnCameraIdleListener listener) {
- if (onCameraIdleListenerList.contains(listener)) {
- onCameraIdleListenerList.remove(listener);
+ if (onCameraIdle.contains(listener)) {
+ onCameraIdle.remove(listener);
}
}
void addOnCameraMoveCancelListener(OnCameraMoveCanceledListener listener) {
- onCameraMoveCanceledListenerList.add(listener);
+ onCameraMoveCanceled.add(listener);
}
void removeOnCameraMoveCancelListener(OnCameraMoveCanceledListener listener) {
- if (onCameraMoveCanceledListenerList.contains(listener)) {
- onCameraMoveCanceledListenerList.remove(listener);
+ if (onCameraMoveCanceled.contains(listener)) {
+ onCameraMoveCanceled.remove(listener);
}
}
void addOnCameraMoveStartedListener(OnCameraMoveStartedListener listener) {
- onCameraMoveStartedListenerList.add(listener);
+ onCameraMoveStarted.add(listener);
}
void removeOnCameraMoveStartedListener(OnCameraMoveStartedListener listener) {
- if (onCameraMoveStartedListenerList.contains(listener)) {
- onCameraMoveStartedListenerList.remove(listener);
+ if (onCameraMoveStarted.contains(listener)) {
+ onCameraMoveStarted.remove(listener);
}
}
void addOnCameraMoveListener(OnCameraMoveListener listener) {
- onCameraMoveListenerList.add(listener);
+ onCameraMove.add(listener);
}
void removeOnCameraMoveListener(OnCameraMoveListener listener) {
- if (onCameraMoveListenerList.contains(listener)) {
- onCameraMoveListenerList.remove(listener);
+ if (onCameraMove.contains(listener)) {
+ onCameraMove.remove(listener);
}
}
}