From a4959131b2cf5500a66c26ebd83ee3de44861feb Mon Sep 17 00:00:00 2001
From: Tobrun
Date: Thu, 30 Mar 2017 13:25:56 +0200
Subject: [PATCH] [android] - transition options in milliseconds, added test
cases, fixup test activity code (#8576)
---
platform/android/CHANGELOG.md | 1 +
.../com/mapbox/mapboxsdk/maps/MapboxMap.java | 16 +++++-----
.../mapbox/mapboxsdk/maps/MapboxMapTest.java | 32 +++++++++++++++++++
.../activity/style/RuntimeStyleActivity.java | 4 +--
platform/android/src/native_map_view.cpp | 8 ++---
5 files changed, 47 insertions(+), 14 deletions(-)
diff --git a/platform/android/CHANGELOG.md b/platform/android/CHANGELOG.md
index ec0a5f15865..bc490fc7abb 100644
--- a/platform/android/CHANGELOG.md
+++ b/platform/android/CHANGELOG.md
@@ -6,6 +6,7 @@ Mapbox welcomes participation and contributions from everyone. If you'd like to
5.1.0 builds further on 5.0.1 and adds:
+* Style wide transition duration and transition offset in milliseconds [#8576](https://github.com/mapbox/mapbox-gl-native/pull/8576)
* LatLngBounds includes with another bounds [#8517](https://github.com/mapbox/mapbox-gl-native/pull/8517)
* LatLngBounds includes takes in account LatLng on the edges (cfr. core) [#8517](https://github.com/mapbox/mapbox-gl-native/pull/8517)
* LatLngBounds facility getters/setters for LatLnbg on the edges of the bounds [#8517](https://github.com/mapbox/mapbox-gl-native/pull/8517)
diff --git a/platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/maps/MapboxMap.java b/platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/maps/MapboxMap.java
index 6edae8b9447..40585700d1a 100644
--- a/platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/maps/MapboxMap.java
+++ b/platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/maps/MapboxMap.java
@@ -194,7 +194,7 @@ void onUpdateFullyRendered() {
*
* The default value is zero, so any changes take effect without animation.
*
- * @return Duration in seconds
+ * @return Duration in milliseconds
*/
@UiThread
public long getTransitionDuration() {
@@ -204,11 +204,11 @@ public long getTransitionDuration() {
/**
* Set the animation duration for style changes.
*
- * @param duration Duration in seconds
+ * @param durationMs Duration in milliseconds
*/
@UiThread
- public void setTransitionDuration(long duration) {
- nativeMapView.setTransitionDuration(duration);
+ public void setTransitionDuration(long durationMs) {
+ nativeMapView.setTransitionDuration(durationMs);
}
/**
@@ -217,7 +217,7 @@ public void setTransitionDuration(long duration) {
*
* The default value is zero, so any changes begin to animate immediately.
*
- * @return Delay in seconds
+ * @return Delay in milliseconds
*/
@UiThread
public long getTransitionDelay() {
@@ -227,11 +227,11 @@ public long getTransitionDelay() {
/**
* Set the animation delay for style changes.
*
- * @param delay Delay in seconds
+ * @param delayMs Delay in milliseconds
*/
@UiThread
- public void setTransitionDelay(long delay) {
- nativeMapView.setTransitionDelay(delay);
+ public void setTransitionDelay(long delayMs) {
+ nativeMapView.setTransitionDelay(delayMs);
}
/**
diff --git a/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/maps/MapboxMapTest.java b/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/maps/MapboxMapTest.java
index 2cd077f510d..c110935133f 100644
--- a/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/maps/MapboxMapTest.java
+++ b/platform/android/MapboxGLAndroidSDKTestApp/src/androidTest/java/com/mapbox/mapboxsdk/maps/MapboxMapTest.java
@@ -75,6 +75,38 @@ public void testSanity() {
assertNotNull("mapboxMap should not be null", mapboxMap);
}
+ //
+ // Style wide transition options
+ //
+
+ @Test
+ public void testTransitionDuration() {
+ ViewUtils.checkViewIsDisplayed(R.id.mapView);
+ final MapboxMap mapboxMap = activity.getMapboxMap();
+ onView(withId(R.id.mapView)).perform(new MapboxMapAction(new InvokeViewAction() {
+ @Override
+ public void onViewAction(UiController uiController, View view) {
+ long transitionDuration = 600;
+ mapboxMap.setTransitionDuration(transitionDuration);
+ assertEquals("TransitionDuration should match", transitionDuration, mapboxMap.getTransitionDuration(), 0);
+ }
+ }));
+ }
+
+ @Test
+ public void testTransitionDelay() {
+ ViewUtils.checkViewIsDisplayed(R.id.mapView);
+ final MapboxMap mapboxMap = activity.getMapboxMap();
+ onView(withId(R.id.mapView)).perform(new MapboxMapAction(new InvokeViewAction() {
+ @Override
+ public void onViewAction(UiController uiController, View view) {
+ long transitionDelay = 50;
+ mapboxMap.setTransitionDelay(transitionDelay);
+ assertEquals("TransitionDelay should match", transitionDelay, mapboxMap.getTransitionDelay(), 0);
+ }
+ }));
+ }
+
//
// MinZoomLevel
//
diff --git a/platform/android/MapboxGLAndroidSDKTestApp/src/main/java/com/mapbox/mapboxsdk/testapp/activity/style/RuntimeStyleActivity.java b/platform/android/MapboxGLAndroidSDKTestApp/src/main/java/com/mapbox/mapboxsdk/testapp/activity/style/RuntimeStyleActivity.java
index af42b7a0fe9..2fc0407c7f9 100644
--- a/platform/android/MapboxGLAndroidSDKTestApp/src/main/java/com/mapbox/mapboxsdk/testapp/activity/style/RuntimeStyleActivity.java
+++ b/platform/android/MapboxGLAndroidSDKTestApp/src/main/java/com/mapbox/mapboxsdk/testapp/activity/style/RuntimeStyleActivity.java
@@ -259,8 +259,8 @@ private void setBackgroundOpacity() {
private void setWaterColor() {
Layer water = mapboxMap.getLayer("water");
if (water != null) {
- mapboxMap.setTransitionDuration(5);
- mapboxMap.setTransitionDelay(1);
+ mapboxMap.setTransitionDuration(5000);
+ mapboxMap.setTransitionDelay(1000);
water.setProperties(
visibility(VISIBLE),
fillColor(Color.RED)
diff --git a/platform/android/src/native_map_view.cpp b/platform/android/src/native_map_view.cpp
index dd4cadbcfb1..d9c24ba0f8e 100755
--- a/platform/android/src/native_map_view.cpp
+++ b/platform/android/src/native_map_view.cpp
@@ -752,23 +752,23 @@ jdouble NativeMapView::getTopOffsetPixelsForAnnotationSymbol(JNIEnv& env, jni::S
jlong NativeMapView::getTransitionDuration(JNIEnv&) {
const auto transitionOptions = map->getTransitionOptions();
- return transitionOptions.duration.value_or(mbgl::Duration::zero()).count();
+ return std::chrono::duration_cast(transitionOptions.duration.value_or(mbgl::Duration::zero())).count();
}
void NativeMapView::setTransitionDuration(JNIEnv&, jlong duration) {
auto transitionOptions = map->getTransitionOptions();
- transitionOptions.duration = std::chrono::duration_cast(std::chrono::duration(duration));
+ transitionOptions.duration.emplace(mbgl::Milliseconds(duration));
map->setTransitionOptions(transitionOptions);
}
jlong NativeMapView::getTransitionDelay(JNIEnv&) {
const auto transitionOptions = map->getTransitionOptions();
- return transitionOptions.delay.value_or(mbgl::Duration::zero()).count();
+ return std::chrono::duration_cast(transitionOptions.delay.value_or(mbgl::Duration::zero())).count();
}
void NativeMapView::setTransitionDelay(JNIEnv&, jlong delay) {
auto transitionOptions = map->getTransitionOptions();
- transitionOptions.delay = std::chrono::duration_cast(std::chrono::duration(delay));
+ transitionOptions.delay.emplace(mbgl::Milliseconds(delay));
map->setTransitionOptions(transitionOptions);
}