From b3e7f379e72111f55a28c302804702ee7c66bfa2 Mon Sep 17 00:00:00 2001 From: zuoxiao <470321431@qq.com> Date: 星期六, 18 一月 2025 16:39:16 +0800 Subject: [PATCH] 1.管网的js相关代码 --- app/src/main/java/com/dayu/pipirrapp/fragment/MapFragment.java | 319 ++++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 292 insertions(+), 27 deletions(-) diff --git a/app/src/main/java/com/dayu/pipirrapp/fragment/MapFragment.java b/app/src/main/java/com/dayu/pipirrapp/fragment/MapFragment.java index 9266ffb..c414864 100644 --- a/app/src/main/java/com/dayu/pipirrapp/fragment/MapFragment.java +++ b/app/src/main/java/com/dayu/pipirrapp/fragment/MapFragment.java @@ -17,7 +17,6 @@ import android.webkit.WebResourceResponse; import android.webkit.WebView; import android.webkit.WebViewClient; -import android.widget.RelativeLayout; import androidx.annotation.NonNull; import androidx.annotation.Nullable; @@ -27,18 +26,23 @@ import com.dayu.pipirrapp.R; import com.dayu.pipirrapp.activity.AddIssueActivity; import com.dayu.pipirrapp.bean.db.CenterPointBean; +import com.dayu.pipirrapp.bean.db.DivideBean; import com.dayu.pipirrapp.bean.db.InspectionBean; import com.dayu.pipirrapp.bean.db.InspectionLocationBean; import com.dayu.pipirrapp.bean.db.LatLonBean; import com.dayu.pipirrapp.bean.db.MarkerBean; +import com.dayu.pipirrapp.bean.db.PipeNetworkBean; import com.dayu.pipirrapp.bean.net.CenterPointResult; +import com.dayu.pipirrapp.bean.net.DivideListResult; +import com.dayu.pipirrapp.bean.net.DivideResult; import com.dayu.pipirrapp.bean.net.InsectionResult; import com.dayu.pipirrapp.bean.net.InspectionRequest; import com.dayu.pipirrapp.bean.net.MarkerListResult; import com.dayu.pipirrapp.bean.net.MarkerResult; +import com.dayu.pipirrapp.bean.net.PipeNetworkListResult; +import com.dayu.pipirrapp.bean.net.PipeNetworkResult; import com.dayu.pipirrapp.dao.DaoSingleton; import com.dayu.pipirrapp.databinding.FragmentMapBinding; -import com.dayu.pipirrapp.tool.MyWebViewInterface; import com.dayu.pipirrapp.net.ApiManager; import com.dayu.pipirrapp.net.BaseResponse; import com.dayu.pipirrapp.net.Constants; @@ -46,6 +50,7 @@ import com.dayu.pipirrapp.observer.MapFragmenObserver; import com.dayu.pipirrapp.tool.InspectionUtils; import com.dayu.pipirrapp.tool.MarkerUtils; +import com.dayu.pipirrapp.tool.MyWebViewInterface; import com.dayu.pipirrapp.utils.CommonData; import com.dayu.pipirrapp.utils.CommonKeyName; import com.dayu.pipirrapp.utils.DateUtils; @@ -100,8 +105,11 @@ List<InspectionLocationBean> aginShowlocationBeans; //web鍔犺浇鏃剁綉椤佃繕娌″姞杞藉畬鏃剁殑鏁版嵁 List<MarkerBean> webNoFinishMarkerData = new ArrayList<>(); + List<DivideBean> webNoFinishDivideData = new ArrayList<>(); //鎵�鏈夌殑Marker鏁版嵁閿负marker鐨処d Map<String, MarkerBean> markerBeanSet = new HashMap<>(); + //鎵�鏈夊垎姘存埧 + Map<String, DivideBean> divideBeanMap = new HashMap<>(); //涓績鐐瑰潗鏍� public double centerLng; public double centerLat; @@ -143,7 +151,9 @@ getCenterPoint(); initView(); initWeb(); + getMarkerData(); + getDivideList(); chageInspecState(mInspectionState); return binding.getRoot(); @@ -208,7 +218,7 @@ super.onPageFinished(view, url); //椤甸潰鍔犺浇瀹屾垚 webViewIsFinished = true; - initLocalData(); + webFinishInitLocalData(); aginShowLocation(null); } @@ -216,9 +226,9 @@ } /** - * 鍒濆鍖栨湰鍦版暟鎹� + * web鍔犺浇瀹屽垵濮嬪寲鏈湴鏁版嵁 */ - public void initLocalData() { + public void webFinishInitLocalData() { //璺宠浆涓績鐐� centerPointBean = DaoSingleton.getInstance(MapFragment.this.getContext()).centerPointDao().findFirst(); jumpCenterPoint(); @@ -226,6 +236,11 @@ if (!webNoFinishMarkerData.isEmpty()) { for (MarkerBean bean : webNoFinishMarkerData) { setMapMarker(bean); + } + } + if (!webNoFinishDivideData.isEmpty()) { + for (DivideBean bean : webNoFinishDivideData) { + setMapDivide(bean); } } //鏄剧ず鎵�鏈夊彇姘村彛 @@ -247,9 +262,7 @@ @Override public void onNext(BaseResponse<MarkerListResult> t) { if (t.isSuccess()) { - if (t.getContent().getObj() != null && !t.getContent().getObj().isEmpty()) { - List<MarkerBean> markerBeans = t.getContent().getObj().stream() .map(result -> { MarkerBean markerBean = new MarkerBean(); @@ -339,12 +352,25 @@ MyLog.i(data); MarkerBean markerBean = markerBeanSet.get(data); if (markerBean != null) { - setWebViewParams(false); getInstakeDetail(markerBean); } } + /** + * 鏄剧ず鍒嗘按鎴胯鎯� + * + * @param data + */ + public void showDivideDetail(String data) { + MyLog.i(data); + DivideBean markerBean = divideBeanMap.get(data); + if (markerBean != null) { + binding.bottomLL.setVisibility(View.GONE); + getDivideDetail(markerBean); + } + + } /** * 鑾峰彇鍦板浘涓績鐐� @@ -398,6 +424,7 @@ try { if (t.isSuccess()) { if (t.getContent() != null) { + MyLog.d("InspectId:" + String.valueOf(t.getContent().get(0).getInspectId())); mInspectionBean.setInspectId(String.valueOf(t.getContent().get(0).getInspectId())); InspectionUtils.upataInspectionData(MapFragment.this.getContext(), mInspectionBean); } @@ -429,6 +456,7 @@ lastLatLonBean = latLonBean; Log.i("chageInspecState", "lat:" + latLonBean.getLatitude() + ",log:" + latLonBean.getLongitude()); InspectionLocationBean inspectionLocationBean = InspectionUtils.createInspectionLocation(latLonBean, mInspectionBean); + //娣诲姞宸℃璁板綍鍧愭爣 InspectionUtils.addInspectionLocationData(MapFragment.this.getContext(), inspectionLocationBean); //鏇存柊鍒板湴鍥� mWebView.evaluateJavascript("javascript:updateInspectionLocation(\"" + latLonBean.getLongitude() + "\",\"" + latLonBean.getLatitude() + "\")", value -> { @@ -556,19 +584,66 @@ public void setMapMarker(MarkerBean markerBean) { if (markerBean != null) { if (webViewIsFinished) { - mWebView.evaluateJavascript("javascript:addMarker(\"" + markerBean.getId() + "\",\"" + markerBean.getLng() + "\",\"" + markerBean.getLat() + "\",\"" + markerBean.getName() + "\")", new ValueCallback<String>() { - @Override - public void onReceiveValue(String value) { - } - }); - markerBeanSet.put(markerBean.getId(), markerBean); - + if (!TextUtils.isEmpty(markerBean.getLng()) && !TextUtils.isEmpty(markerBean.getLat())) { + mWebView.evaluateJavascript("javascript:addMarker(\"" + markerBean.getId() + "\",\"" + markerBean.getLng() + "\",\"" + markerBean.getLat() + "\",\"" + markerBean.getName() + "\")", new ValueCallback<String>() { + @Override + public void onReceiveValue(String value) { + } + }); + markerBeanSet.put(markerBean.getId(), markerBean); + } else { + MyLog.d("setMapMarker>" + markerBean.getName() + "缁忕含搴︿负绌�"); + } } else { webNoFinishMarkerData.add(markerBean); } } } + /** + * 娣诲姞鍙栨按鍙f爣娉� + */ + public void setMapDivide(DivideBean divide) { + if (divide != null) { + if (webViewIsFinished) { + if (!TextUtils.isEmpty(divide.getLng()) && !TextUtils.isEmpty(divide.getLat())) { + mWebView.evaluateJavascript("javascript:addDivide(\"" + divide.getId() + "\",\"" + divide.getLng() + "\",\"" + divide.getLat() + "\",\"" + divide.getDivideName() + "\")", new ValueCallback<String>() { + @Override + public void onReceiveValue(String value) { + } + }); + divideBeanMap.put(divide.getId(), divide); + } else { + MyLog.d("setMapDivide>" + divide.getDivideName() + "缁忕含搴︿负绌�"); + } + } else { + webNoFinishDivideData.add(divide); + } + } + } + + /** + * 娣诲姞鍙栨按鍙f爣娉� + */ + public void setMapDivide(PipeNetworkBean pipeNetworkBean) { +// if (divide != null) { +// if (webViewIsFinished) { +// for () +// if (!TextUtils.isEmpty(divide.getLng()) && !TextUtils.isEmpty(divide.getLat())) { +// mWebView.evaluateJavascript("javascript:addDivide(\"" + divide.getId() + "\",\"" + divide.getLng() + "\",\"" + divide.getLat() + "\",\"" + divide.getDivideName() + "\")", new ValueCallback<String>() { +// @Override +// public void onReceiveValue(String value) { +// } +// }); +// divideBeanMap.put(divide.getId(), divide); +// } else { +// MyLog.d("setMapDivide>" + divide.getDivideName() + "缁忕含搴︿负绌�"); +// } +// } else { +// webNoFinishDivideData.add(divide); +// } +// } + } /** * 寮�濮嬪贰妫�鐨勭浉鍏抽�昏緫 @@ -577,7 +652,7 @@ */ private void startLocation() { //鑾峰彇瀹氫綅鏈嶅姟浼犺繃鏉ョ殑鍧愭爣鐐� - LiveEventBus.get(CommonKeyName.locationData).observeForever(locationObserver); + LiveEventBus.get(CommonKeyName.locationData).observe(this, locationObserver); binding.inspectRL.setVisibility(View.VISIBLE); binding.inspectButton.setVisibility(View.GONE); binding.inspectPause.setText("鏆傚仠"); @@ -717,8 +792,32 @@ }); } + /** + * 鏄剧ず鍙栨按鍙h鎯� + */ + private void getDivideDetail(DivideBean divideBean) { + ApiManager.getInstance().requestGet(this.getContext(), Constants.BASE_URL + "/project/divide/getone/" + divideBean.getDivideId(), DivideResult.class, null, new SubscriberListener<BaseResponse<DivideResult>>() { + @Override + public void onNext(BaseResponse<DivideResult> t) { + if (t.isSuccess()) { + DivideBean divideBean = getDivideBean(t.getContent()); + showDivideMarker(divideBean); + } else { + ToastUtil.showToast(MapFragment.this.getContext(), t.getMsg()); + } + } + + }); + } + + /** + * 鏄剧ず鍙栨按鍙h鎯� + */ private void showMarker(MarkerBean markerBean) { binding.bottomLL.setVisibility(View.VISIBLE); + binding.phoneLL.setVisibility(View.GONE); + binding.headerLL.setVisibility(View.GONE); + binding.editePoint.setVisibility(View.VISIBLE); binding.markerAddress.setText(markerBean.getAddress()); binding.markerName.setText(markerBean.getName()); binding.markerBlockName.setText(markerBean.getBlockName()); @@ -726,17 +825,20 @@ binding.lng.setText(markerBean.getLng()); //淇敼缁忕含搴� binding.editePoint.setOnClickListener(v -> { + mWebView.evaluateJavascript("javascript:showPin(\"" + markerBean.getLng() + "\",\"" + markerBean.getLat() + "\")", value -> { + binding.pointRL.setVisibility(View.VISIBLE); + binding.pointCenterImg.setVisibility(View.VISIBLE); + MyLog.d("showPin>>" + value); }); - binding.pointRL.setVisibility(View.VISIBLE); - binding.pointCenterImg.setVisibility(View.VISIBLE); - setWebViewParams(true); + }); //鍙栨秷淇敼缁忕含搴� binding.pointCancel.setOnClickListener(v -> { binding.pointCenterImg.setVisibility(View.GONE); binding.pointRL.setVisibility(View.GONE); mWebView.evaluateJavascript("javascript:cancelPin()", value -> { + }); } ); @@ -750,14 +852,177 @@ }); } - private void setWebViewParams(boolean isAbove) { - RelativeLayout.LayoutParams paramsAnotherView = new RelativeLayout.LayoutParams( - RelativeLayout.LayoutParams.MATCH_PARENT, - RelativeLayout.LayoutParams.MATCH_PARENT); - if (isAbove) { - paramsAnotherView.addRule(RelativeLayout.ABOVE, binding.bottomLL.getId()); - } - binding.webViewRL.setLayoutParams(paramsAnotherView); + /** + * 鏄剧ず鍒嗘按鎴胯鎯� + * + * @param divideBean + */ + private void showDivideMarker(DivideBean divideBean) { + binding.bottomLL.setVisibility(View.VISIBLE); + binding.phoneLL.setVisibility(View.VISIBLE); + binding.headerLL.setVisibility(View.VISIBLE); + binding.editePoint.setVisibility(View.GONE); + binding.markerAddress.setText(divideBean.getAddress()); + binding.markerName.setText(divideBean.getDivideName()); + binding.markerBlockName.setText(divideBean.getBlockName()); + binding.phone.setText(divideBean.getPhone()); + binding.header.setText(divideBean.getHeader()); + binding.lat.setText(divideBean.getLat()); + binding.lng.setText(divideBean.getLng()); + //淇敼缁忕含搴� + binding.editePoint.setOnClickListener(v -> { + + mWebView.evaluateJavascript("javascript:showPin(\"" + divideBean.getLng() + "\",\"" + divideBean.getLat() + "\")", value -> { + binding.pointRL.setVisibility(View.VISIBLE); + binding.pointCenterImg.setVisibility(View.VISIBLE); + MyLog.d("showPin>>" + value); + }); + + }); + //鍙栨秷淇敼缁忕含搴� + binding.pointCancel.setOnClickListener(v -> { + binding.pointCenterImg.setVisibility(View.GONE); + binding.pointRL.setVisibility(View.GONE); + mWebView.evaluateJavascript("javascript:cancelPin()", value -> { + + }); + } + ); + //纭淇敼缁忕含搴� + binding.pointEdt.setOnClickListener(v -> { + ConfirmDialog confirmDialog = new ConfirmDialog(MapFragment.this.getActivity(), "纭淇敼鍒拌浣嶇疆鍚楋紵", (confirmDialog1, v1) -> { + confirmDialog1.dismiss(); +// updataInstake(markerBean); + }); + confirmDialog.show(); + }); } + + /** + * 鑾峰彇鍒嗘按鎴� + */ + private void getDivideList() { + ApiManager.getInstance().requestGetHideLoading(MapFragment.this.getContext(), BASE_URL + "/project/divide/getDivides", DivideListResult.class, null, new SubscriberListener<BaseResponse<DivideListResult>>() { + @Override + public void onNext(BaseResponse<DivideListResult> t) { + try { + if (t.isSuccess()) { + if (t.getContent().getObj() != null && !t.getContent().getObj().isEmpty()) { + + List<DivideBean> divideBeans = new ArrayList<>(); + for (DivideResult divideResult : t.getContent().getObj()) { + DivideBean divideBean = getDivideBean(divideResult); + setMapDivide(divideBean); + divideBeans.add(divideBean); + } + // 浣跨敤 RxJava 寮傛鎻掑叆鏁版嵁 + DaoSingleton.getAsynchInstance(MapFragment.this.getContext()).divideDao().insertAll(divideBeans) + .subscribeOn(Schedulers.io()) // 鍦� IO 绾跨▼涓婃墽琛� + .observeOn(AndroidSchedulers.mainThread()) // 鍦ㄤ富绾跨▼涓婅瀵� + .subscribe(() -> { + // 鎻掑叆鎴愬姛 + Log.i("mWebView", "鏁版嵁鎻掑叆鎴愬姛"); + }, throwable -> { + // 鎻掑叆澶辫触 + Log.e("mWebView", "鏁版嵁鎻掑叆澶辫触: " + throwable.getMessage()); + }); + } + + + } else { + ToastUtil.showToastLong(MapFragment.this.getContext(), t.getMsg()); + } + } catch (Exception e) { + e.printStackTrace(); + CrashReport.postCatchedException(e); + } + } + + }); + } + + /** + * 鑾峰彇绠$綉 + */ + private void getPipeNetworkList() { + ApiManager.getInstance().requestGetHideLoading(MapFragment.this.getContext(), BASE_URL + "/project/network/all", PipeNetworkListResult.class, null, new SubscriberListener<BaseResponse<PipeNetworkListResult>>() { + @Override + public void onNext(BaseResponse<PipeNetworkListResult> t) { + try { + if (t.isSuccess()) { + if (t.getContent().getObj() != null && !t.getContent().getObj().isEmpty()) { + + List<DivideBean> divideBeans = new ArrayList<>(); + for (PipeNetworkResult divideResult : t.getContent().getObj()) { + PipeNetworkBean divideBean = getPipeNetworkBean(divideResult); + setMapDivide(divideBean); +// divideBeans.add(divideBean); + } + // 浣跨敤 RxJava 寮傛鎻掑叆鏁版嵁 + DaoSingleton.getAsynchInstance(MapFragment.this.getContext()).divideDao().insertAll(divideBeans) + .subscribeOn(Schedulers.io()) // 鍦� IO 绾跨▼涓婃墽琛� + .observeOn(AndroidSchedulers.mainThread()) // 鍦ㄤ富绾跨▼涓婅瀵� + .subscribe(() -> { + // 鎻掑叆鎴愬姛 + Log.i("mWebView", "鏁版嵁鎻掑叆鎴愬姛"); + }, throwable -> { + // 鎻掑叆澶辫触 + Log.e("mWebView", "鏁版嵁鎻掑叆澶辫触: " + throwable.getMessage()); + }); + } + + + } else { + ToastUtil.showToastLong(MapFragment.this.getContext(), t.getMsg()); + } + } catch (Exception e) { + e.printStackTrace(); + CrashReport.postCatchedException(e); + } + } + + }); + } + + /** + * @param divideResult + * @return + */ + private static @NonNull DivideBean getDivideBean(DivideResult divideResult) { + DivideBean divideBean = new DivideBean(); + divideBean.setAddress(divideResult.getAddress()); + divideBean.setBlockId(divideResult.getBlockId()); + divideBean.setBlockName(divideResult.getBlockName()); + divideBean.setDivideId(divideResult.getDivideId()); + if (!TextUtils.isEmpty(divideResult.getDivideName())) { + divideBean.setDivideName(divideResult.getDivideName()); + } else { + divideBean.setDivideName(divideResult.getName()); + } + + divideBean.setHeader(divideResult.getHeader()); + divideBean.setId(divideResult.getId()); + divideBean.setLat(divideResult.getLat()); + divideBean.setLng(divideResult.getLng()); + divideBean.setOperateDt(divideResult.getOperateDt()); + divideBean.setOperator(divideResult.getOperator()); + divideBean.setPhone(divideResult.getPhone()); + divideBean.setRemarks(divideResult.getRemarks()); + divideBean.setVillages(divideResult.getVillages()); + divideBean.setArea(divideResult.getArea()); + return divideBean; + } + + private static @NonNull PipeNetworkBean getPipeNetworkBean(PipeNetworkResult divideResult) { + PipeNetworkBean pipeNetworkBean = new PipeNetworkBean(); + + return pipeNetworkBean; + } + + @Override + public void onDestroy() { + super.onDestroy(); + LiveEventBus.get(CommonKeyName.locationData).removeObserver(locationObserver); + } } -- Gitblit v1.8.0