From aac539596fe4f9f829679427298217c584216a84 Mon Sep 17 00:00:00 2001 From: davinci9196 Date: Mon, 4 Nov 2024 10:58:05 +0800 Subject: [PATCH 1/2] Optimize the phenomenon of Uber route drift --- .../org/microg/gms/maps/hms/GoogleMap.kt | 27 +++++++++++++------ 1 file changed, 19 insertions(+), 8 deletions(-) diff --git a/play-services-maps/core/hms/src/main/kotlin/org/microg/gms/maps/hms/GoogleMap.kt b/play-services-maps/core/hms/src/main/kotlin/org/microg/gms/maps/hms/GoogleMap.kt index aa5911f805..7f480ac364 100644 --- a/play-services-maps/core/hms/src/main/kotlin/org/microg/gms/maps/hms/GoogleMap.kt +++ b/play-services-maps/core/hms/src/main/kotlin/org/microg/gms/maps/hms/GoogleMap.kt @@ -87,7 +87,8 @@ class GoogleMapImpl(private val context: Context, var options: GoogleMapOptions) private var storedMapType: Int = options.mapType val waitingCameraUpdates = mutableListOf() - var locationEnabled: Boolean = false + private var isCameraMoving: Boolean = false + private val updateCameraMoveRun = Runnable { isCameraMoving = false } private var markerId = 0L val markers = mutableMapOf() @@ -306,8 +307,9 @@ class GoogleMapImpl(private val context: Context, var options: GoogleMapOptions) internalOnInitializedCallbackList.add(it.getMapReadyCallback()) } - override fun getProjection(): IProjectionDelegate = - map?.projection?.let { ProjectionImpl(it) } ?: DummyProjection() + override fun getProjection(): IProjectionDelegate { + return if (isCameraMoving) DummyProjection() else map?.projection?.let { ProjectionImpl(it) } ?: DummyProjection() + } override fun setOnCameraChangeListener(listener: IOnCameraChangeListener?) = afterInitialize { Log.d(TAG, "setOnCameraChangeListener"); @@ -493,6 +495,9 @@ class GoogleMapImpl(private val context: Context, var options: GoogleMapOptions) cameraMoveStartedListener = listener hmap.setOnCameraMoveStartedListener { try { + Log.d(TAG, "setCameraMoveStartedListener: ") + view.removeCallbacks(updateCameraMoveRun) + isCameraMoving = true cameraMoveStartedListener?.onCameraMoveStarted(it) } catch (e: Exception) { Log.w(TAG, e) @@ -505,15 +510,15 @@ class GoogleMapImpl(private val context: Context, var options: GoogleMapOptions) cameraMoveListener = listener it.setOnCameraMoveListener { try { + Log.d(TAG, "setOnCameraMoveListener: ") + isCameraMoving = true if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { - if(mapView != null){ - if(mapView!!.parent != null){ - mapView!!.parent.onDescendantInvalidated(mapView!!,mapView!!) - } - } + view.onDescendantInvalidated(mapView!!, mapView!!) } + view.removeCallbacks(updateCameraMoveRun) cameraMoveListener?.onCameraMove() cameraChangeListener?.onCameraChange(map?.cameraPosition?.toGms()) + view.postDelayed(updateCameraMoveRun, 200) } catch (e: Exception) { Log.w(TAG, e) } @@ -525,6 +530,9 @@ class GoogleMapImpl(private val context: Context, var options: GoogleMapOptions) cameraMoveCanceledListener = listener it.setOnCameraMoveCanceledListener { try { + Log.d(TAG, "setOnCameraMoveCanceledListener: ") + view.removeCallbacks(updateCameraMoveRun) + isCameraMoving = false cameraMoveCanceledListener?.onCameraMoveCanceled() } catch (e: Exception) { Log.w(TAG, e) @@ -537,6 +545,9 @@ class GoogleMapImpl(private val context: Context, var options: GoogleMapOptions) cameraIdleListener = listener it.setOnCameraIdleListener { try { + Log.d(TAG, "setOnCameraIdleListener: ") + view.removeCallbacks(updateCameraMoveRun) + isCameraMoving = false cameraIdleListener?.onCameraIdle() } catch (e: Exception) { Log.w(TAG, e) From fd97807e2c92f90c965f62b02694cbd6111d930b Mon Sep 17 00:00:00 2001 From: davinci9196 Date: Tue, 12 Nov 2024 11:51:03 +0800 Subject: [PATCH 2/2] Change the processing method to fix the abnormal scaling of Uber location pin --- .../org/microg/gms/maps/hms/GoogleMap.kt | 40 +++++++++++-------- 1 file changed, 23 insertions(+), 17 deletions(-) diff --git a/play-services-maps/core/hms/src/main/kotlin/org/microg/gms/maps/hms/GoogleMap.kt b/play-services-maps/core/hms/src/main/kotlin/org/microg/gms/maps/hms/GoogleMap.kt index 7f480ac364..fe7704d2e4 100644 --- a/play-services-maps/core/hms/src/main/kotlin/org/microg/gms/maps/hms/GoogleMap.kt +++ b/play-services-maps/core/hms/src/main/kotlin/org/microg/gms/maps/hms/GoogleMap.kt @@ -18,8 +18,6 @@ import android.widget.LinearLayout import androidx.collection.LongSparseArray import com.google.android.gms.dynamic.IObjectWrapper import com.google.android.gms.dynamic.unwrap -import com.google.android.gms.maps.GoogleMap.MAP_TYPE_HYBRID -import com.google.android.gms.maps.GoogleMap.MAP_TYPE_SATELLITE import com.google.android.gms.maps.GoogleMap.MAP_TYPE_TERRAIN import com.google.android.gms.maps.GoogleMapOptions import com.google.android.gms.maps.internal.* @@ -87,8 +85,7 @@ class GoogleMapImpl(private val context: Context, var options: GoogleMapOptions) private var storedMapType: Int = options.mapType val waitingCameraUpdates = mutableListOf() - private var isCameraMoving: Boolean = false - private val updateCameraMoveRun = Runnable { isCameraMoving = false } + private val controlLayerRun = Runnable { refreshContainerLayer(false) } private var markerId = 0L val markers = mutableMapOf() @@ -308,7 +305,7 @@ class GoogleMapImpl(private val context: Context, var options: GoogleMapOptions) } override fun getProjection(): IProjectionDelegate { - return if (isCameraMoving) DummyProjection() else map?.projection?.let { ProjectionImpl(it) } ?: DummyProjection() + return map?.projection?.let { ProjectionImpl(it) } ?: DummyProjection() } override fun setOnCameraChangeListener(listener: IOnCameraChangeListener?) = afterInitialize { @@ -496,8 +493,6 @@ class GoogleMapImpl(private val context: Context, var options: GoogleMapOptions) hmap.setOnCameraMoveStartedListener { try { Log.d(TAG, "setCameraMoveStartedListener: ") - view.removeCallbacks(updateCameraMoveRun) - isCameraMoving = true cameraMoveStartedListener?.onCameraMoveStarted(it) } catch (e: Exception) { Log.w(TAG, e) @@ -511,14 +506,11 @@ class GoogleMapImpl(private val context: Context, var options: GoogleMapOptions) it.setOnCameraMoveListener { try { Log.d(TAG, "setOnCameraMoveListener: ") - isCameraMoving = true - if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { - view.onDescendantInvalidated(mapView!!, mapView!!) - } - view.removeCallbacks(updateCameraMoveRun) + view.removeCallbacks(controlLayerRun) + refreshContainerLayer(true) cameraMoveListener?.onCameraMove() cameraChangeListener?.onCameraChange(map?.cameraPosition?.toGms()) - view.postDelayed(updateCameraMoveRun, 200) + view.postDelayed(controlLayerRun, 200) } catch (e: Exception) { Log.w(TAG, e) } @@ -531,8 +523,6 @@ class GoogleMapImpl(private val context: Context, var options: GoogleMapOptions) it.setOnCameraMoveCanceledListener { try { Log.d(TAG, "setOnCameraMoveCanceledListener: ") - view.removeCallbacks(updateCameraMoveRun) - isCameraMoving = false cameraMoveCanceledListener?.onCameraMoveCanceled() } catch (e: Exception) { Log.w(TAG, e) @@ -546,8 +536,6 @@ class GoogleMapImpl(private val context: Context, var options: GoogleMapOptions) it.setOnCameraIdleListener { try { Log.d(TAG, "setOnCameraIdleListener: ") - view.removeCallbacks(updateCameraMoveRun) - isCameraMoving = false cameraIdleListener?.onCameraIdle() } catch (e: Exception) { Log.w(TAG, e) @@ -815,6 +803,24 @@ class GoogleMapImpl(private val context: Context, var options: GoogleMapOptions) } } + private fun refreshContainerLayer(hide: Boolean = false) { + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { + view.onDescendantInvalidated(mapView!!, mapView!!) + } + val parentView = view.parent?.parent + if (parentView != null) { + if (parentView is ViewGroup) { + for (i in 0 until parentView.childCount) { + val viewChild = parentView.getChildAt(i) + // Uber is prone to route drift, so here we hide the corresponding layer + if (viewChild::class.qualifiedName == "com.ubercab.android.map.fu") { + viewChild.visibility = if (hide) View.INVISIBLE else View.VISIBLE + } + } + } + } + } + override fun onTransact(code: Int, data: Parcel, reply: Parcel?, flags: Int): Boolean = if (super.onTransact(code, data, reply, flags)) { Log.d(TAG, "onTransact: $code, $data, $flags")