From f23be5d1086538d541281b84d8b093f95c545c47 Mon Sep 17 00:00:00 2001 From: lmw <125975490@qq.com> Date: 星期一, 23 九月 2024 17:08:43 +0800 Subject: [PATCH] save --- app/src/main/java/com/future/driver/ui/main/TripActivity.kt | 94 +++++++++++++++++++++++++++++++++++----------- 1 files changed, 71 insertions(+), 23 deletions(-) diff --git a/app/src/main/java/com/future/driver/ui/main/TripActivity.kt b/app/src/main/java/com/future/driver/ui/main/TripActivity.kt index a6aed92..b2a19e2 100644 --- a/app/src/main/java/com/future/driver/ui/main/TripActivity.kt +++ b/app/src/main/java/com/future/driver/ui/main/TripActivity.kt @@ -5,11 +5,13 @@ import android.os.CountDownTimer import android.os.Handler import android.os.Looper +import android.util.Log import android.view.Gravity import android.view.View import cn.sinata.xldutils.utils.* import com.amap.api.location.AMapLocationListener import com.amap.api.maps.AMap +import com.amap.api.maps.AMapUtils import com.amap.api.maps.model.LatLng import com.amap.api.maps.model.Marker import com.amap.api.maps.model.Polyline @@ -40,6 +42,7 @@ import io.reactivex.android.schedulers.AndroidSchedulers import io.reactivex.disposables.Disposable import io.reactivex.schedulers.Schedulers +import kotlinx.android.synthetic.main.activity_change_one.* import kotlinx.android.synthetic.main.activity_select_start_point.* import kotlinx.android.synthetic.main.activity_trip.* import kotlinx.android.synthetic.main.activity_trip.map_view @@ -55,7 +58,6 @@ class TripActivity : MyBaseActivity() { - /*** * // 流程操作状态(3=开始出发预约点,4=到达预约点,5=开始服务,6=服务结束) * 页面一共4个marker 1:预约地点 2:起点 3终点 4:司机点 @@ -78,6 +80,8 @@ var markerLine: Polyline? = null lateinit var aMap: AMap lateinit var orderBean: OrderBean + + var autoExitNavi = false //是否自动退出过,只自动退出一次即可 private val rxPermissions by lazy { RxPermissions(this) @@ -104,7 +108,7 @@ data?.let { when (it.orderType) { 1, 2, 3,7 -> { - if (it.status == 10 || it.status == 12) { + if ((it.status == 10 || it.status == 12)&&MyApplication.currentOrderId.isNotEmpty()&&it.orderId.toString() == orderId) { Handler(Looper.getMainLooper()).post { toast("用户已取消订单") MyApplication.getTTsManager().setVideoText("用户已取消订单") @@ -134,7 +138,7 @@ orderSimpleData?.let { if (it.status == 10 || it.status == 12) { Handler(Looper.getMainLooper()).post { - toast("用户已取消订单") +// toast("用户已取消订单") MyApplication.getTTsManager().setVideoText("用户已取消订单") MyApplication.currentOrderType = "" MyApplication.currentOrderId = "" @@ -171,7 +175,7 @@ "orderType" to orderType ) } else { - DialogUtil.getDelAndSureDialog( + val d = DialogUtil.getDelAndSureDialog( this, "现在改派将收取" + data.data.amount + "元改派费,您是否要进行改派?", {}, @@ -183,9 +187,9 @@ "money" to data.data.amount.toString() ) }) + val view = DialogUtil.getView(d) + view.tv_view_two_base.gravity = Gravity.CENTER } - - } } iv_move.setOnClickListener { @@ -273,11 +277,21 @@ return@let } if (it.data.endAddress.isNullOrEmpty()&&it.data.orderState == 4){ - DialogUtil.getDelAndSureDialog(this,"去填写","取消","乘客未填写目的地,请代乘客填写目的地后开始行程",{ - }){ + val delAndSureDialog = DialogUtil.getDelAndSureDialog( + this, + "去填写", + "取消", + "乘客未填写目的地,请代乘客填写目的地后开始行程", + { + }) { byChangeEnd = true - startActivity<SearchSiteActivity>("currentCityName" to (MyApplication.aMapLocation?.city?:""),"type" to "3") + startActivity<SearchSiteActivity>( + "currentCityName" to (MyApplication.aMapLocation?.city ?: ""), + "type" to "3" + ) } + val view = DialogUtil.getView(delAndSureDialog) + view.tv_view_two_base.gravity = Gravity.CENTER return@let } it.data.orderState++ @@ -433,25 +447,43 @@ changeCarFive(false) } } + if (it.data.orderState == 3){ + val calculateLineDistance = AMapUtils.calculateLineDistance( + carMarker!!.position, + LatLng(it.data.startLat, it.data.startLon) + ) + if (calculateLineDistance<80&&!autoExitNavi){ + EventBus.getDefault().post(BaseEvent(BaseEvent.EXIT_NAVI)) + } + } } }) } private fun changeCarThree(isMove: Boolean) { if (makeMarker != null && carMarker != null) { - AMapKit.initRouteLine( - this, - makeMarker!!.position, - carMarker!!.position, - object : (MutableList<LatLng>, Float, Long) -> Unit { - override fun invoke(p1: MutableList<LatLng>, p2: Float, p3: Long) { - var view = creatCarView("距预约点" + AMapKit.getTance(p2)) - carMarker!!.setIcon(getIcon(view)) - addline(p1) - if (isMove) - moveCamera(aMap, makeMarker!!.position, carMarker!!.position) - } - }) + val calculateLineDistance = AMapUtils.calculateLineDistance(makeMarker!!.position, carMarker!!.position) + Log.e("mmp","两点直线距离:${calculateLineDistance}m") + if (calculateLineDistance>100) //大于100米才规划路径 + AMapKit.initRouteLine( + this, + makeMarker!!.position, + carMarker!!.position, + object : (MutableList<LatLng>, Float, Long) -> Unit { + override fun invoke(p1: MutableList<LatLng>, p2: Float, p3: Long) { + var view = creatCarView("距预约点" + AMapKit.getTance(p2)) + carMarker!!.setIcon(getIcon(view)) + addline(p1) + if (isMove) + moveCamera(aMap, makeMarker!!.position, carMarker!!.position) + } + }) + else{ + var view = creatCarView("距预约点" + AMapKit.getTance(calculateLineDistance)) + carMarker!!.setIcon(getIcon(view)) + if (isMove) + moveCamera(aMap, makeMarker!!.position, carMarker!!.position) + } } } @@ -499,6 +531,7 @@ private fun showUi(orderBean: OrderBean?) { orderBean?.let { tv_name.text = orderBean.data.nickName + tv_passenger_phone.text = orderBean.data.phone tv_car_num.text = it.data.historyNum.toString() + "次乘车" tv_time.text = it.data.travelTime_ tv_start_address.text = it.data.startAddress @@ -627,7 +660,7 @@ carMarker?.isVisible = true changeCarFive(true) setTitleText("服务中") - slide_btn.changeButtonText("送达该乘客") + slide_btn.changeButtonText("乘客已到达") if (!MyApplication.isRecording){ EventBus.getDefault().post(BaseEvent(BaseEvent.START_RECORD)) } @@ -676,8 +709,23 @@ handler?.removeCallbacksAndMessages(null) } closeTimeStart() + map_view.onDestroy() } + override fun onPause() { + super.onPause() + map_view.onPause() + } + + override fun onLowMemory() { + super.onLowMemory() + map_view.onLowMemory() + } + + override fun onResume() { + super.onResume() + map_view.onResume() + } private fun addline(allLine: MutableList<LatLng>) { closeLine() -- Gitblit v1.7.1