diff --git a/app/build.gradle b/app/build.gradle index 0cdd1b7736..696bd12edc 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -8,7 +8,7 @@ apply plugin: 'kotlin-android' apply plugin: 'kotlin-android-extensions' apply plugin: 'kotlin-kapt' -apply from: rootProject.file('gradle/bytex/bytex.gradle') +//apply from: rootProject.file('gradle/bytex/bytex.gradle') Properties properties = new Properties() properties.load(project.rootProject.file("gradle.properties").newDataInputStream()) diff --git a/core/function-impl/mogo-core-function-biz/src/main/java/com/mogo/eagle/function/biz/v2x/trafficlight/core/MogoTrafficLightManager.kt b/core/function-impl/mogo-core-function-biz/src/main/java/com/mogo/eagle/function/biz/v2x/trafficlight/core/MogoTrafficLightManager.kt index e092cf8387..53561394c6 100644 --- a/core/function-impl/mogo-core-function-biz/src/main/java/com/mogo/eagle/function/biz/v2x/trafficlight/core/MogoTrafficLightManager.kt +++ b/core/function-impl/mogo-core-function-biz/src/main/java/com/mogo/eagle/function/biz/v2x/trafficlight/core/MogoTrafficLightManager.kt @@ -2,7 +2,6 @@ package com.mogo.eagle.function.biz.v2x.trafficlight.core import android.content.Context import android.os.Handler -import android.os.HandlerThread import android.os.Looper import com.mogo.eagle.core.data.biz.trafficlight.RoadIDResult import com.mogo.eagle.core.data.biz.trafficlight.TrafficLightControl @@ -10,6 +9,7 @@ import com.mogo.eagle.core.data.biz.trafficlight.TrafficLightResult import com.mogo.eagle.core.data.biz.trafficlight.isInRange import com.mogo.eagle.core.data.map.MogoLocation import com.mogo.eagle.core.function.api.autopilot.IMoGoChassisLocationGCJ02Listener +import com.mogo.eagle.core.function.api.map.road.IMoGoMapRoadListener import com.mogo.eagle.core.function.call.autopilot.CallerChassisLocationGCJ02ListenerManager import com.mogo.eagle.core.function.call.map.CallerMapRoadListenerManager import com.mogo.eagle.core.function.call.v2x.CallerTrafficLightListenerManager @@ -23,7 +23,7 @@ import com.mogo.eagle.function.biz.v2x.trafficlight.network.TrafficLightNetWorkM import com.zhidaoauto.map.data.road.RoadCross class MogoTrafficLightManager : IMoGoChassisLocationGCJ02Listener, - CallerMapRoadListenerManager.OnRoadListener { + IMoGoMapRoadListener { companion object { @@ -52,7 +52,7 @@ class MogoTrafficLightManager : IMoGoChassisLocationGCJ02Listener, fun initServer(context: Context) { mContext = context CallerChassisLocationGCJ02ListenerManager.addListener(TAG, this) - CallerMapRoadListenerManager.registerRoadListener(TAG, this) + CallerMapRoadListenerManager.addListener(TAG, this) mThreadHandler = TrafficLightThreadHandler(Looper.getMainLooper(), { //第一次查询路口时,如果红绿灯显示,则隐藏掉 diff --git a/core/function-impl/mogo-core-function-biz/src/main/java/com/mogo/eagle/function/biz/v2x/v2n/V2XEventManager.kt b/core/function-impl/mogo-core-function-biz/src/main/java/com/mogo/eagle/function/biz/v2x/v2n/V2XEventManager.kt index 8fcf73fa29..4b074c39f6 100644 --- a/core/function-impl/mogo-core-function-biz/src/main/java/com/mogo/eagle/function/biz/v2x/v2n/V2XEventManager.kt +++ b/core/function-impl/mogo-core-function-biz/src/main/java/com/mogo/eagle/function/biz/v2x/v2n/V2XEventManager.kt @@ -32,6 +32,7 @@ import com.mogo.eagle.core.function.api.autopilot.IMoGoAutopilotStatusListener import com.mogo.eagle.core.function.api.autopilot.IMoGoChassisLocationGCJ02Listener import com.mogo.eagle.core.function.api.autopilot.IMoGoV2XListener import com.mogo.eagle.core.function.api.cloud.IMoGoCloudListener +import com.mogo.eagle.core.function.api.map.road.IMoGoMapRoadListener import com.mogo.eagle.core.function.call.autopilot.CallerAutoPilotStatusListenerManager import com.mogo.eagle.core.function.call.autopilot.CallerAutopilotIdentifyListenerManager import com.mogo.eagle.core.function.call.autopilot.CallerChassisLocationGCJ02ListenerManager @@ -42,7 +43,6 @@ import com.mogo.eagle.core.function.call.autopilot.CallerV2XListenerManager.V2NC import com.mogo.eagle.core.function.call.cloud.CallerCloudListenerManager import com.mogo.eagle.core.function.call.hmi.CallerHmiManager import com.mogo.eagle.core.function.call.map.CallerMapRoadListenerManager -import com.mogo.eagle.core.function.call.map.CallerMapRoadListenerManager.OnRoadListener import com.mogo.eagle.core.function.call.msgbox.CallerMsgBoxManager import com.mogo.eagle.core.function.call.telematic.CallerTelematicManager import com.mogo.eagle.core.utilcode.mogo.AppIdentityModeUtils @@ -79,7 +79,7 @@ import java.util.concurrent.atomic.AtomicReference object V2XEventManager : IMoGoChassisLocationGCJ02Listener, IV2XCallback, IMoGoAutopilotIdentifyListener, IMoGoCloudListener, - IMoGoV2XListener, IMoGoAutopilotStatusListener, OnRoadListener { + IMoGoV2XListener, IMoGoAutopilotStatusListener, IMoGoMapRoadListener { private const val TAG = "V2XEventManager" @@ -108,7 +108,7 @@ object V2XEventManager : IMoGoChassisLocationGCJ02Listener, IV2XCallback, v2xPoiLoader.startLoopPoi() // 注册广播接收场景弹窗使用的 SceneBroadcastReceiver.register(context) - CallerMapRoadListenerManager.registerRoadListener(TAG, this) + CallerMapRoadListenerManager.addListener(TAG, this) } } @@ -363,7 +363,7 @@ object V2XEventManager : IMoGoChassisLocationGCJ02Listener, IV2XCallback, unRegisterListener() } v2xPoiLoader.stopLoopPoi() - CallerMapRoadListenerManager.unRegisterRoadListener(TAG) + CallerMapRoadListenerManager.removeListener(TAG) } } diff --git a/core/function-impl/mogo-core-function-hmi/src/main/java/com/mogo/eagle/core/function/hmi/ui/camera/RoadCrossLiveView.kt b/core/function-impl/mogo-core-function-hmi/src/main/java/com/mogo/eagle/core/function/hmi/ui/camera/RoadCrossLiveView.kt new file mode 100644 index 0000000000..4c6a5645e1 --- /dev/null +++ b/core/function-impl/mogo-core-function-hmi/src/main/java/com/mogo/eagle/core/function/hmi/ui/camera/RoadCrossLiveView.kt @@ -0,0 +1,26 @@ +package com.mogo.eagle.core.function.hmi.ui.camera + +import android.content.Context +import android.util.AttributeSet +import android.view.LayoutInflater +import androidx.constraintlayout.widget.ConstraintLayout +import com.mogo.eagle.core.function.hmi.R + +class RoadCrossLiveView @JvmOverloads constructor( + context: Context, + attrs: AttributeSet? = null, + defStyleAttr: Int = 0 +) : ConstraintLayout(context, attrs, defStyleAttr) { + + init { + LayoutInflater.from(context).inflate(R.layout.view_road_cross_live, this, true) + } + + override fun onAttachedToWindow() { + super.onAttachedToWindow() + } + + override fun onDetachedFromWindow() { + super.onDetachedFromWindow() + } +} \ No newline at end of file diff --git a/core/function-impl/mogo-core-function-hmi/src/main/java/com/mogo/eagle/core/function/hmi/ui/setting/DebugSettingView.kt b/core/function-impl/mogo-core-function-hmi/src/main/java/com/mogo/eagle/core/function/hmi/ui/setting/DebugSettingView.kt index 96abdb293e..734ef44762 100644 --- a/core/function-impl/mogo-core-function-hmi/src/main/java/com/mogo/eagle/core/function/hmi/ui/setting/DebugSettingView.kt +++ b/core/function-impl/mogo-core-function-hmi/src/main/java/com/mogo/eagle/core/function/hmi/ui/setting/DebugSettingView.kt @@ -420,16 +420,16 @@ internal class DebugSettingView @JvmOverloads constructor( */ tbStatusCenter.setOnCheckedChangeListener { buttonView, isChecked -> val cross = RoadCross() - CallerMapRoadListenerManager.invokeRoadChange(0, cross) -// if (isChecked) { -// buttonView.setCompoundDrawables(null, null, iconDown, null) -// //展示状态中心 -// statusCenterLayout.visibility = View.VISIBLE -// } else { -// buttonView.setCompoundDrawables(null, null, iconRight, null) -// //隐藏状态中心 -// statusCenterLayout.visibility = View.GONE -// } +// CallerMapRoadListenerManager.invokeRoadChange(0, cross) + if (isChecked) { + buttonView.setCompoundDrawables(null, null, iconDown, null) + //展示状态中心 + statusCenterLayout.visibility = View.VISIBLE + } else { + buttonView.setCompoundDrawables(null, null, iconRight, null) + //隐藏状态中心 + statusCenterLayout.visibility = View.GONE + } } /** diff --git a/core/function-impl/mogo-core-function-hmi/src/main/res/layout/view_road_cross_live.xml b/core/function-impl/mogo-core-function-hmi/src/main/res/layout/view_road_cross_live.xml new file mode 100644 index 0000000000..77d9ef65f8 --- /dev/null +++ b/core/function-impl/mogo-core-function-hmi/src/main/res/layout/view_road_cross_live.xml @@ -0,0 +1,6 @@ + + + + \ No newline at end of file diff --git a/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/angle/MoGoVisualAngleChangeProvider.kt b/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/angle/MoGoVisualAngleChangeProvider.kt index 9a844bc788..9378ca4ffe 100644 --- a/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/angle/MoGoVisualAngleChangeProvider.kt +++ b/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/angle/MoGoVisualAngleChangeProvider.kt @@ -15,9 +15,9 @@ import com.mogo.eagle.core.function.angle.scenes.Default import com.mogo.eagle.core.function.angle.scenes.RoadEvent import com.mogo.eagle.core.function.api.map.angle.* import com.mogo.eagle.core.function.api.map.angle.Scene +import com.mogo.eagle.core.function.api.map.road.IMoGoMapRoadListener import com.mogo.eagle.core.function.call.autopilot.* import com.mogo.eagle.core.function.call.map.* -import com.mogo.eagle.core.function.call.map.CallerMapRoadListenerManager.OnRoadListener import com.mogo.eagle.core.utilcode.kotlin.* import com.mogo.eagle.core.utilcode.mogo.AppIdentityModeUtils import com.zhidaoauto.map.data.road.StopLine @@ -61,7 +61,7 @@ class MoGoVisualAngleChangeProvider: IMoGoVisualAngleChangeProvider { PriorityQueue() } - private val listener = object : OnRoadListener { + private val listener = object : IMoGoMapRoadListener { private val roadId = AtomicReference() private val triggerRoadId = AtomicReference() @@ -122,11 +122,11 @@ class MoGoVisualAngleChangeProvider: IMoGoVisualAngleChangeProvider { ctx.lifeCycleOwner.lifecycle.addObserver(object : LifecycleEventObserver { override fun onStateChanged(source: LifecycleOwner, event: Event) { if (event == ON_DESTROY) { - CallerMapRoadListenerManager.unRegisterRoadListener("VisualAngleChange") + CallerMapRoadListenerManager.removeListener(TAG) } } }) - CallerMapRoadListenerManager.registerRoadListener("VisualAngleChange", listener) + CallerMapRoadListenerManager.addListener(TAG, listener) } @Volatile diff --git a/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/business/roadcross/RoadCrossCameraManager.kt b/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/business/roadcross/RoadCrossCameraManager.kt index 337d39d80e..d543ce1d30 100644 --- a/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/business/roadcross/RoadCrossCameraManager.kt +++ b/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/business/roadcross/RoadCrossCameraManager.kt @@ -3,8 +3,10 @@ package com.mogo.eagle.core.function.business.roadcross import android.annotation.SuppressLint import android.content.Context import android.util.Log +import com.mogo.commons.debug.DebugConfig import com.mogo.eagle.core.data.deva.chain.ChainConstant import com.mogo.eagle.core.data.road.CameraDeviceInfo +import com.mogo.eagle.core.function.api.map.road.IMoGoMapRoadListener import com.mogo.eagle.core.function.business.roadcross.net.NDERoadCameraNetWorkModel.Companion.ndeRoadCameraNetWorkModel import com.mogo.eagle.core.function.call.autopilot.CallerChassisLocationWGS84ListenerManager import com.mogo.eagle.core.function.call.map.CallerMapRoadListenerManager @@ -12,6 +14,7 @@ import com.mogo.eagle.core.function.call.map.CallerMapUIServiceManager import com.mogo.eagle.core.function.view.CameraMarkerView import com.mogo.eagle.core.utilcode.mogo.logger.CallerLogger import com.mogo.eagle.core.utilcode.mogo.logger.scene.SceneConstant.Companion.M_MAP +import com.mogo.eagle.core.utilcode.util.ToastUtils import com.mogo.map.overlay.core.Level import com.mogo.map.overlay.point.Point import com.zhidaoauto.map.data.road.RoadCross @@ -19,7 +22,7 @@ import com.zhidaoauto.map.data.road.StopLine import com.zhjt.service.chain.ChainLog import kotlin.properties.Delegates -class RoadCrossCameraManager : CallerMapRoadListenerManager.OnRoadListener { +class RoadCrossCameraManager : IMoGoMapRoadListener { companion object { private const val TAG = "RoadCrossCameraManager" @@ -41,7 +44,7 @@ class RoadCrossCameraManager : CallerMapRoadListenerManager.OnRoadListener { fun init(context: Context?) { mContext = context - CallerMapRoadListenerManager.registerRoadListener(TAG, this) + CallerMapRoadListenerManager.addListener(TAG, this) } //todo 记录方法执行时间 @@ -56,7 +59,7 @@ class RoadCrossCameraManager : CallerMapRoadListenerManager.OnRoadListener { if (roadCrossEnd != null) { ndeRoadCameraNetWorkModel.getRoadCrossInfo(roadCrossEnd, onSuccess = { - if (it.roadUniqueId == null) { + if (it.crossingId == null) { traceError("roadUniqueId is null") return@getRoadCrossInfo } @@ -64,10 +67,6 @@ class RoadCrossCameraManager : CallerMapRoadListenerManager.OnRoadListener { traceError("deviceInfoList isEmpty") return@getRoadCrossInfo } - if (it.roadUniqueId != roadCrossEnd) { - traceError("cloud roadId :${it.roadUniqueId} is not equal currentCross : $roadCrossEnd") - return@getRoadCrossInfo - } roadCrossCameraList = it.deviceInfoList // 地图上打marker(注意marker方向),marker点击获取对应ip it.deviceInfoList.forEach { deviceInfo -> @@ -86,6 +85,7 @@ class RoadCrossCameraManager : CallerMapRoadListenerManager.OnRoadListener { } private fun addCameraDeviceMarker(cameraDeviceInfo: CameraDeviceInfo) { + Log.d("emArrow","add marker:${cameraDeviceInfo.deviceIp}") mContext?.let { val builder = Point.Options.Builder(TAG, Level.MAP_MARKER) @@ -102,11 +102,11 @@ class RoadCrossCameraManager : CallerMapRoadListenerManager.OnRoadListener { .onClick { id -> Log.d("emArrow", "Marker click :$id") ndeRoadCameraNetWorkModel.singleRequestCrossLive(id, - onSuccess = { - + onSuccess = { live -> + CallerMapRoadListenerManager.invokeRoadCrossLive(live) }, - onError = { - + onError = {errorMsg -> + traceError(" ${cameraDeviceInfo.deviceIp} click request error :$errorMsg") }) } CallerLogger.d("$M_MAP$TAG", "new road cross camera=$overlayManager") @@ -135,12 +135,12 @@ class RoadCrossCameraManager : CallerMapRoadListenerManager.OnRoadListener { override fun onRoadChange(cross: Boolean, roadCross: RoadCross?) { super.onRoadChange(cross, roadCross) -// val data = CameraDeviceInfo("172.18.1.60", 112.582913287, 26.9320508672) //todo emArrow test -// addCameraDeviceMarker(data) -// val data1 = CameraDeviceInfo("172.18.1.42", 112.582947017, 26.9328373092) -// addCameraDeviceMarker(data1) -// val data2 = CameraDeviceInfo("172.18.1.72", 112.582421, 26.932519) -// addCameraDeviceMarker(data2) + val data = CameraDeviceInfo("172.18.1.60", 112.582913287, 26.9320508672) //todo emArrow test + addCameraDeviceMarker(data) + val data1 = CameraDeviceInfo("172.18.1.42", 112.582947017, 26.9328373092) + addCameraDeviceMarker(data1) + val data2 = CameraDeviceInfo("172.18.1.72", 112.582421, 26.932519) + addCameraDeviceMarker(data2) // 出路口 if (!cross) { @@ -149,15 +149,20 @@ class RoadCrossCameraManager : CallerMapRoadListenerManager.OnRoadListener { // 清除marker roadCrossCameraList?.let { it.forEach { camera -> + Log.d("emArrow","remove marker:${camera.deviceIp}") overlayManager?.removePoint(camera.deviceIp) } } // 释放控制 isCameraRequest = false + Log.d("emArrow", "经过路口,释放控制") } } private fun traceError(msg: String) { + if(DebugConfig.isDebug()){ + ToastUtils.showLong(msg) + } val loc = CallerChassisLocationWGS84ListenerManager.getChassisLocationWGS84() roadCrossTrace( TAG, mapOf( diff --git a/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/business/roadcross/net/INDERoadCameraApiService.kt b/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/business/roadcross/net/INDERoadCameraApiService.kt index be6a630256..2b85b89edb 100644 --- a/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/business/roadcross/net/INDERoadCameraApiService.kt +++ b/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/business/roadcross/net/INDERoadCameraApiService.kt @@ -24,7 +24,7 @@ interface INDERoadCameraApiService { @Query("roadUniqueId") roadId: String, @Query("lon") lon: Double, @Query("lat") lat: Double - ): BaseResponse + ): BaseResponse> // 单ip查询设备直播流与缩略图 @GET(SINGLE_LIVE) diff --git a/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/business/roadcross/net/NDERoadCameraNetWorkModel.kt b/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/business/roadcross/net/NDERoadCameraNetWorkModel.kt index dd580e5313..299ab9e6c9 100644 --- a/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/business/roadcross/net/NDERoadCameraNetWorkModel.kt +++ b/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/business/roadcross/net/NDERoadCameraNetWorkModel.kt @@ -30,7 +30,7 @@ class NDERoadCameraNetWorkModel private constructor() { onSuccess: ((RoadCrossCamera) -> Unit), onError: ((String) -> Unit) ) { - request>("roadCross") { + request>>("roadCross") { loader { apiCall { val loc = CallerChassisLocationWGS84ListenerManager.getChassisLocationWGS84() @@ -45,7 +45,11 @@ class NDERoadCameraNetWorkModel private constructor() { } } onSuccess { - onSuccess.invoke(it.result) + if(it.result.isNotEmpty()){ + onSuccess.invoke(it.result[0]) + }else{ + onError.invoke("getRoadCrossInfo empty camera info") + } } onError { onError.invoke(it.message.toString()) @@ -112,7 +116,7 @@ class NDERoadCameraNetWorkModel private constructor() { private fun getAuth(url: String): Pair { val time = System.currentTimeMillis().toString() - val md5String = "${url.uppercase(Locale.getDefault())}$time" + val md5String = "/${url.uppercase(Locale.getDefault())}$time" val auth = Md5Util.getMD5Result(md5String) return Pair(auth, time) } diff --git a/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/view/MapBizView.kt b/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/view/MapBizView.kt index cebf36fe4f..b084403520 100644 --- a/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/view/MapBizView.kt +++ b/core/function-impl/mogo-core-function-map/src/main/java/com/mogo/eagle/core/function/view/MapBizView.kt @@ -59,7 +59,7 @@ class MapBizView(context: Context?, attrs: AttributeSet?) : MogoMapView(context, //设置倾斜手势是否可用。 it.setTiltGesturesEnabled(false) //设置双指缩放手势是否可用。 - it.setZoomGesturesEnabled(true) + it.setZoomGesturesEnabled(false) //true todo emArrow test } } diff --git a/core/mogo-core-data/src/main/java/com/mogo/eagle/core/data/deva/chain/ChainConstant.kt b/core/mogo-core-data/src/main/java/com/mogo/eagle/core/data/deva/chain/ChainConstant.kt index 1afb053c11..20a0e776ba 100644 --- a/core/mogo-core-data/src/main/java/com/mogo/eagle/core/data/deva/chain/ChainConstant.kt +++ b/core/mogo-core-data/src/main/java/com/mogo/eagle/core/data/deva/chain/ChainConstant.kt @@ -106,6 +106,7 @@ class ChainConstant { const val CHAIN_CODE_V2X_MSG = "CHAIN_CODE_V2X_MSG" const val CHAIN_CODE_HD_MAP_CALL = "CHAIN_CODE_HD_MAP_CALL" const val CHAIN_CODE_HD_MAP_ROAD_CROSS = "CHAIN_CODE_HD_MAP_ROAD_CROSS" + const val CHAIN_CODE_HD_MAP_ROAD_LIVE = "CHAIN_CODE_HD_MAP_ROAD_LIVE" const val CHAIN_CODE_HD_MAP_ICON_SET = "CHAIN_CODE_HD_MAP_ICON_SET" const val CHAIN_CODE_HMI_ACTIONS = "CHAIN_CODE_HMI_ACTIONS" const val CHAIN_CODE_CERT_REQUEST = "CHAIN_CODE_CERT_REQUEST" diff --git a/core/mogo-core-data/src/main/java/com/mogo/eagle/core/data/road/RoadCrossCamera.kt b/core/mogo-core-data/src/main/java/com/mogo/eagle/core/data/road/RoadCrossCamera.kt index 5e7c9ca480..1336f47e1c 100644 --- a/core/mogo-core-data/src/main/java/com/mogo/eagle/core/data/road/RoadCrossCamera.kt +++ b/core/mogo-core-data/src/main/java/com/mogo/eagle/core/data/road/RoadCrossCamera.kt @@ -2,7 +2,7 @@ package com.mogo.eagle.core.data.road //接口请求路侧,返回设备信息 data class RoadCrossCamera( - val crossingId: String, // 路侧对应ID(衡阳1-25号路口) + val crossingId: String? = null, // 路侧对应ID(衡阳1-25号路口) val roadUniqueId: String? = null, // 高精地图crossID val lon: Double, // 路口多设备经纬度中心点lon val lat: Double, // 路口多设备经纬度中心点lat diff --git a/core/mogo-core-function-api/src/main/java/com/mogo/eagle/core/function/api/map/road/IMoGoMapRoadListener.kt b/core/mogo-core-function-api/src/main/java/com/mogo/eagle/core/function/api/map/road/IMoGoMapRoadListener.kt new file mode 100644 index 0000000000..1110d437a1 --- /dev/null +++ b/core/mogo-core-function-api/src/main/java/com/mogo/eagle/core/function/api/map/road/IMoGoMapRoadListener.kt @@ -0,0 +1,21 @@ +package com.mogo.eagle.core.function.api.map.road + +import com.mogo.eagle.core.data.road.RoadCameraLive +import com.zhidaoauto.map.data.road.RoadCross +import com.zhidaoauto.map.data.road.StopLine + +/** + * + */ +interface IMoGoMapRoadListener { + + fun onRoadIdInfo(roadId: String) {} + + fun onStopLineInfo(info: StopLine) {} + + fun onRoadChange(cross: Boolean, roadCross: RoadCross? = null) {} + + fun onCrossLiveInfo(info: RoadCameraLive) {} + + +} \ No newline at end of file diff --git a/core/mogo-core-function-call/src/main/java/com/mogo/eagle/core/function/call/map/CallerMapRoadListenerManager.kt b/core/mogo-core-function-call/src/main/java/com/mogo/eagle/core/function/call/map/CallerMapRoadListenerManager.kt index 75922f9fc4..4cd26da1c5 100644 --- a/core/mogo-core-function-call/src/main/java/com/mogo/eagle/core/function/call/map/CallerMapRoadListenerManager.kt +++ b/core/mogo-core-function-call/src/main/java/com/mogo/eagle/core/function/call/map/CallerMapRoadListenerManager.kt @@ -1,73 +1,62 @@ package com.mogo.eagle.core.function.call.map import com.mogo.eagle.core.data.deva.chain.ChainConstant +import com.mogo.eagle.core.data.road.RoadCameraLive +import com.mogo.eagle.core.function.api.map.road.IMoGoMapRoadListener +import com.mogo.eagle.core.function.call.base.CallerBase import com.mogo.eagle.core.utilcode.mogo.logger.CallerLogger import com.mogo.eagle.core.utilcode.mogo.logger.scene.SceneConstant.Companion.M_MAP import com.zhidaoauto.map.data.road.RoadCross import com.zhidaoauto.map.data.road.StopLine import com.zhjt.service.chain.ChainLog -import java.util.concurrent.ConcurrentHashMap import kotlin.properties.Delegates -object CallerMapRoadListenerManager { +object CallerMapRoadListenerManager : CallerBase() { - interface OnRoadListener { + private var mRoadId: String? = null + private var mStopLine: StopLine? = null + private var mRoadChange = false + private var mRoadCross: RoadCross? = null - fun onRoadIdInfo(roadId: String) {} - - fun onStopLineInfo(info: StopLine) {} - - fun onRoadChange(cross: Boolean, roadCross: RoadCross? = null) {} - } - - private val listeners by lazy { - ConcurrentHashMap() - } - - fun registerRoadListener(tag: String, listener: OnRoadListener) { - if (listeners.contains(tag)) { - return + private var mCross: Int by Delegates.observable(-1) { _, oldValue, newValue -> +// if (oldValue != newValue) { //todo emArrow test + CallerLogger.d("$M_MAP onRoadChange observable", newValue) + M_LISTENERS.forEach { entry -> + // false:1,2, 离开路口,进入路段 + // true: 进入路口 + mRoadChange = !(newValue == 1 || newValue == 2) + entry.value.onRoadChange(mRoadChange, mRoadCross) } - listeners[tag] = listener +// } } - fun unRegisterRoadListener(tag: String) { - if (!listeners.contains(tag)) { - return + override fun doSomeAfterAddListener(tag: String, listener: IMoGoMapRoadListener) { + super.doSomeAfterAddListener(tag, listener) + mRoadId?.let { + listener.onRoadIdInfo(it) + } + mStopLine?.let { + listener.onStopLineInfo(it) + } + if(mCross != -1 && mRoadCross != null){ + listener.onRoadChange(mRoadChange, mRoadCross) } - listeners.remove(tag) } - fun invokeListenersOnRoadIdGet(roadId: String) { - listeners.forEach { entry -> + mRoadId = roadId + M_LISTENERS.forEach { entry -> entry.value.onRoadIdInfo(roadId) } } - private var mStopLine:StopLine? = null - fun invokeListenersOnStopLineGet(stopLine: StopLine) { mStopLine = stopLine - listeners.forEach { entry -> + M_LISTENERS.forEach { entry -> entry.value.onStopLineInfo(stopLine) } } - private var mCross: Int by Delegates.observable(-1) { _, oldValue, newValue -> -// if (oldValue != newValue) { - CallerLogger.d("$M_MAP onRoadChange observable", newValue) - listeners.forEach { entry -> - when (newValue) { - 1, 2 -> entry.value.onRoadChange(false, mRoadCross) - else -> entry.value.onRoadChange(true, mRoadCross) - } - } -// } - } - - private var mRoadCross: RoadCross? = null - fun getCrossInfo(): RoadCross? { return mRoadCross } @@ -79,10 +68,24 @@ object CallerMapRoadListenerManager { paramIndexes = [0, 1] ) fun invokeRoadChange(cross: Int, roadCross: RoadCross) { - CallerLogger.d("$M_MAP onRoadChange", "oldValue: $mCross , " + "mStopLine:${mStopLine?.distance}" + - "newValue: $cross , oldCross:$mRoadCross , newCross:$roadCross") + CallerLogger.d( + "$M_MAP onRoadChange", "oldValue: $mCross , " + "mStopLine:${mStopLine?.distance}" + + "newValue: $cross , oldCross:$mRoadCross , newCross:$roadCross" + ) mCross = cross mRoadCross = roadCross } + + @ChainLog( + linkChainLog = ChainConstant.CHAIN_TYPE_STATUS, + linkCode = ChainConstant.CHAIN_SOURCE_MAP, + nodeAliasCode = ChainConstant.CHAIN_CODE_HD_MAP_ROAD_LIVE, + paramIndexes = [0] + ) + fun invokeRoadCrossLive(info: RoadCameraLive){ + M_LISTENERS.forEach { entry -> + entry.value.onCrossLiveInfo(info) + } + } } \ No newline at end of file diff --git a/core/mogo-core-function-call/src/main/java/com/mogo/eagle/core/function/call/map/CallerMapStyleListenerManager.kt b/core/mogo-core-function-call/src/main/java/com/mogo/eagle/core/function/call/map/CallerMapStyleListenerManager.kt deleted file mode 100644 index e69de29bb2..0000000000