From 4230457ee9edca6af738ec3f832ed0f49d0d99c3 Mon Sep 17 00:00:00 2001 From: zuoxiao <470321431@qq.com> Date: 星期三, 04 十二月 2024 18:10:30 +0800 Subject: [PATCH] 1.下载地图瓦片判断是否有网。 2.没有上传成功的巡检坐标有网时重新上传。 3.添加网络判断的工具类 --- app/src/main/java/com/dayu/pipirrapp/fragment/MapFragment.java | 179 ++++++++++++++++++++++++++++++++++++++--------------------- 1 files changed, 116 insertions(+), 63 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 73b3946..ac24cfa 100644 --- a/app/src/main/java/com/dayu/pipirrapp/fragment/MapFragment.java +++ b/app/src/main/java/com/dayu/pipirrapp/fragment/MapFragment.java @@ -1,8 +1,6 @@ package com.dayu.pipirrapp.fragment; import static com.dayu.pipirrapp.net.Constants.BASE_URL; -import static com.dayu.pipirrapp.tool.InspectionUtils.addInspectionLocationData; -import static com.dayu.pipirrapp.tool.InspectionUtils.updateInspectionLocationData; import android.content.Context; import android.content.Intent; @@ -10,6 +8,7 @@ import android.location.LocationManager; import android.os.Build; import android.os.Bundle; +import android.text.TextUtils; import android.util.Log; import android.view.LayoutInflater; import android.view.View; @@ -25,7 +24,6 @@ import androidx.annotation.Nullable; import androidx.lifecycle.Observer; -import com.dayu.pipirrapp.MyApplication; import com.dayu.pipirrapp.R; import com.dayu.pipirrapp.bean.db.CenterPointBean; import com.dayu.pipirrapp.bean.db.InspectionBean; @@ -33,8 +31,8 @@ import com.dayu.pipirrapp.bean.db.LatLonBean; import com.dayu.pipirrapp.bean.db.MarkerBean; import com.dayu.pipirrapp.bean.net.CenterPointResult; +import com.dayu.pipirrapp.bean.net.InsectionResult; import com.dayu.pipirrapp.bean.net.InspectionRequest; -import com.dayu.pipirrapp.bean.net.LoginResult; import com.dayu.pipirrapp.bean.net.MarkerResult; import com.dayu.pipirrapp.dao.DaoSingleton; import com.dayu.pipirrapp.databinding.FragmentMapBinding; @@ -88,9 +86,12 @@ int mInspectionState; MapFragmenObserver mapFragmenObserver; //褰撳墠宸℃璁板綍鐨勭浉鍏充俊鎭� - InspectionBean mInspectionBean; + public InspectionBean mInspectionBean; LatLonBean lastLatLonBean; InspectionRequest inspectionRequest; + volatile boolean isHaseAginData = false; + volatile boolean webViewIsFinished = false; + List<InspectionLocationBean> aginShowlocationBeans; @Override public void onAttach(@NonNull Context context) { @@ -130,7 +131,12 @@ initView(); initLocalData(); getMarkerData(); - //鏄剧ず宸℃鐘舵�� + //鏄剧ず宸℃鐘舵�佸苟涓旀樉绀哄洜鎰忓鍏抽棴鐨勫巻鍙叉暟鎹� + switch (mInspectionState) { + case InspectionUtils.STAT_INSPECTION: + case InspectionUtils.PAUSE_INSPECTION: + InspectionUtils.aginShowLocation(MapFragment.this); + } chageInspecState(mInspectionState); return binding.getRoot(); } @@ -274,14 +280,14 @@ @Override public WebResourceResponse shouldInterceptRequest(WebView view, WebResourceRequest request) { String url = request.getUrl().toString(); - Log.i(TAG, "鍔犺浇鍦板潃>>>" + url); +// Log.d(TAG, "鍔犺浇鍦板潃>>>" + url); //鍒ゆ柇褰撳墠鏄惁涓哄姞杞界摝鐗� if (MapJpgUtils.getInsatance().isTianDiTuTileRequest(url)) { String androidUrl = url.replace(CommonData.webKey, CommonData.androidKey); // 妫�鏌ユ湰鍦扮紦瀛� File cachedTile = MapJpgUtils.getInsatance().getCachedTile(androidUrl); if (cachedTile != null && cachedTile.exists()) { - Log.i(TAG, "鏈湴缂撳瓨>>>" + androidUrl); +// Log.d(TAG, "鏈湴缂撳瓨>>>" + androidUrl); // if (MapJpgUtils.getInsatance().validateImageFile(androidUrl,request.)) // 鍒ゆ柇缂撳瓨鏄惁杩囨湡 // if (!MapJpgUtils.getInsatance(MapFragment.this.getContext()).isCacheExpired(cachedTile)) { @@ -294,9 +300,9 @@ // } } else { //涓嬭浇鐡︾墖 - ApiManager.getInstance().donwLoadTile(androidUrl); + ApiManager.getInstance().donwLoadTile(MapFragment.this.getContext(),androidUrl); } - Log.i(TAG, "鍦ㄧ嚎鍔犺浇>>>" + url); +// Log.d(TAG, "鍦ㄧ嚎鍔犺浇>>>" + url); } @@ -324,10 +330,20 @@ Log.e("setWebViewClient", "statusCode:" + statusCode + ">>>>description:" + description); // 鏍规嵁HTTP鐘舵�佺爜澶勭悊閿欒 } + + @Override + public void onPageFinished(WebView view, String url) { + super.onPageFinished(view, url); + webViewIsFinished = true; + //椤甸潰鍔犺浇瀹屾垚 + if (isHaseAginData) { + aginShowLocation(null); + } + } }); //宸℃鎸夐挳 binding.inspectButton.setOnClickListener(v -> { - chageInspecState(InspectionUtils.STAT_INSPECTION); + chageInspecState(InspectionUtils.STAT_INSPECTION_ONCLICK); }); //鏆傚仠宸℃ binding.inspectPause.setOnClickListener(v -> { @@ -384,10 +400,12 @@ */ private void pushLocationData(InspectionLocationBean inspectionLocationBean) { inspectionRequest.setInspectId(inspectionLocationBean.getInspectId()); - inspectionRequest.setInspectorId(inspectionLocationBean.getInspectorId()); + inspectionRequest.setInspectorId(mInspectionBean.getInspectorId()); if (mInspectionBean != null) { inspectionRequest.setStartTime(mInspectionBean.getStartTime()); - inspectionRequest.setStopTime(mInspectionBean.getStopTime()); + if (!TextUtils.isEmpty(mInspectionBean.getStopTime())) { + inspectionRequest.setStopTime(mInspectionBean.getStopTime()); + } } InspectionRequest.Track track = new InspectionRequest.Track(); track.setLat(inspectionLocationBean.getLat()); @@ -395,13 +413,17 @@ track.setLocateTime(inspectionLocationBean.getLocateTime()); inspectionRequest.getTracks().clear(); inspectionRequest.addTracks(track); - ApiManager.getInstance().requestPostHideLoading(MapFragment.this.getContext(), BASE_URL + "/app/inspect/save", LoginResult.class, inspectionRequest.toMap(inspectionRequest), new SubscriberListener<BaseResponse<LoginResult>>() { + ApiManager.getInstance().requestPostHideLoading(MapFragment.this.getContext(), BASE_URL + "/app/inspect/save", InsectionResult.class, inspectionRequest.toMap(inspectionRequest), new SubscriberListener<BaseResponse<List<InsectionResult>>>() { @Override - public void onNext(BaseResponse<LoginResult> t) { + public void onNext(BaseResponse<List<InsectionResult>> t) { try { if (t.isSuccess()) { + if (t.getContent() != null) { + mInspectionBean.setInspectId(String.valueOf(t.getContent().get(0).getInspectId())); + InspectionUtils.upataInspectionData(MapFragment.this.getContext(), mInspectionBean); + } inspectionLocationBean.setPost(true); - updateInspectionLocationData(MapFragment.this.getContext(), inspectionLocationBean); + InspectionUtils.updateInspectionLocationData(MapFragment.this.getContext(), inspectionLocationBean); } else { } @@ -418,12 +440,7 @@ * 寮�濮嬪贰妫� */ private void startInspection() { - DaoSingleton.getAsynchInstance(this.getContext()).inspectionDao().getMostRecentInspectionWithNoStopTime() - .subscribeOn(Schedulers.io()) - .observeOn(AndroidSchedulers.mainThread()).subscribe(inspectionBean -> { - // 鏇存柊 UI - mInspectionBean = inspectionBean; - }); + } @@ -439,9 +456,11 @@ //澶т簬鏈�灏忚窛绂� lastLatLonBean = latLonBean; Log.i("chageInspecState", "lat:" + latLonBean.getLatitude() + ",log:" + latLonBean.getLongitude()); - InspectionLocationBean inspectionLocationBean = createInspectionLocation(latLonBean); - addInspectionLocationData(MapFragment.this.getContext(), inspectionLocationBean); + InspectionLocationBean inspectionLocationBean = InspectionUtils.createInspectionLocation(latLonBean, mInspectionBean); + InspectionUtils.addInspectionLocationData(MapFragment.this.getContext(), inspectionLocationBean); //鏇存柊鍒板湴鍥� + mWebView.evaluateJavascript("javascript:updateInspectionLocation(\"" + latLonBean.getLongitude() + "\",\"" + latLonBean.getLatitude() + "\")", value -> { + }); mWebView.evaluateJavascript("javascript:updateLocation(\"" + latLonBean.getLongitude() + "\",\"" + latLonBean.getLatitude() + "\")", value -> { }); //涓婁紶鍧愭爣 @@ -449,37 +468,22 @@ } else { Log.d(TAG, "isThanMinMeters>>>false"); } - - } } }; /** - * 鍒涘缓InspectionLocationBean - */ - private InspectionLocationBean createInspectionLocation(LatLonBean latLonBean) { - InspectionLocationBean inspectionLocationBean = new InspectionLocationBean(); - inspectionLocationBean.setInspectId(mInspectionBean.getInspectId()); - inspectionLocationBean.setLocateTime(DateUtils.getNowDateStr()); - inspectionLocationBean.setPost(false); - inspectionLocationBean.setInspectorId(MyApplication.myApplication.userId); - inspectionLocationBean.setLng(String.valueOf(latLonBean.getLongitude())); - inspectionLocationBean.setLat(String.valueOf(latLonBean.getLatitude())); - return inspectionLocationBean; - } - - - /** * 淇敼宸℃鐘舵�� + * + * @param inspectionState */ private void chageInspecState(int inspectionState) { Intent location = new Intent(this.getActivity(), MyLocationService.class); location.putExtra("isSingle", false); //0娌℃湁寮�濮嬶紝1寮�濮嬶紝2鏆傚仠,3鍏抽棴 switch (inspectionState) { - case 0: + case InspectionUtils.NO_INSPECTION: binding.inspectButton.setVisibility(View.VISIBLE); binding.inspectRL.setVisibility(View.GONE); binding.inspectButton.setText("宸�"); @@ -487,47 +491,49 @@ //鍏抽棴瀹氫綅 this.getActivity().stopService(location); break; - case InspectionUtils.STAT_INSPECTION://1寮�濮� + case InspectionUtils.STAT_INSPECTION_ONCLICK: //娣诲姞鏂扮殑宸℃璁板綍 - startInspection(); - //鑾峰彇瀹氫綅鏈嶅姟浼犺繃鏉ョ殑鍧愭爣鐐� - LiveEventBus.get(CommonKeyName.locationData).observeForever(locationObserver); - binding.inspectRL.setVisibility(View.VISIBLE); - binding.inspectButton.setVisibility(View.GONE); - binding.inspectPause.setText("鏆傚仠"); - binding.stateText.setText("宸插紑鍚贰妫�"); - binding.inspectRL.setBackgroundColor(this.getContext().getResources().getColor(R.color.base_blue)); - //寮�鍚畾浣� - if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { - this.getActivity().startForegroundService(location); - } else { - this.getActivity().startService(location); - } mInspectionBean = InspectionUtils.startInspection(this.getContext()); - inspectionRequest = new InspectionRequest(); - SharedPreferencesHelper.getInstance(this.getContext()).put(CommonKeyName.inspectionState, InspectionUtils.STAT_INSPECTION); + startLocation(location); break; - case 2://鏆傚仠 + case InspectionUtils.STAT_INSPECTION://1寮�濮� + startLocation(location); + break; + case InspectionUtils.PAUSE_INSPECTION://鏆傚仠 try { - LiveEventBus.get(CommonKeyName.locationData).removeObserver(locationObserver); //鍏抽棴瀹氫綅 this.getActivity().stopService(location); binding.stateText.setText("宸叉殏鍋滃贰妫�"); binding.inspectPause.setText("缁х画"); binding.inspectRL.setBackgroundColor(this.getContext().getResources().getColor(R.color.inspect_rl_bg_color)); SharedPreferencesHelper.getInstance(this.getContext()).put(CommonKeyName.inspectionState, InspectionUtils.PAUSE_INSPECTION); + //娓呴櫎鍦板浘宸℃杞ㄨ抗 + mWebView.evaluateJavascript("javascript:cleanLoclLay()", value -> { + }); } catch (Resources.NotFoundException e) { e.printStackTrace(); } break; - case 3: + case InspectionUtils.STOP_INSPECTION://鍏抽棴 ConfirmDialog confirmDialog = new ConfirmDialog(MapFragment.this.getActivity(), "鎻愮ず", "纭鍏抽棴宸℃鍚楋紵", new ConfirmDialog.ConfirmOnClickListener() { @Override public void onClick(ConfirmDialog confirmDialog, View v) { confirmDialog.dismiss(); chageInspecState(InspectionUtils.NO_INSPECTION); SharedPreferencesHelper.getInstance(MapFragment.this.getContext()).put(CommonKeyName.inspectionState, InspectionUtils.NO_INSPECTION); + //鏇存柊鏈湴鏁版嵁搴撶粨鏉熸椂闂� + mInspectionBean.setStopTime(DateUtils.getNowDateStr()); + InspectionUtils.upataInspectionData(MapFragment.this.getContext(), mInspectionBean); + //涓婃姤缁撴潫鏃堕棿 + InspectionLocationBean inspectionLocationBean = InspectionUtils.createInspectionLocation(lastLatLonBean, mInspectionBean); + InspectionUtils.addInspectionLocationData(MapFragment.this.getContext(), inspectionLocationBean); + pushLocationData(inspectionLocationBean); + mInspectionBean = new InspectionBean(); + //娓呴櫎鍦板浘宸℃杞ㄨ抗 + mWebView.evaluateJavascript("javascript:cleanLocationLay()", value -> { + }); + lastLatLonBean = null; } }); confirmDialog.show(); @@ -535,6 +541,53 @@ default: } mInspectionState = inspectionState; - } + + /** + * 鎰忓閫�鍑哄悗缁х画鏄剧ず涔嬪墠鐨勫潗鏍� + */ + public void aginShowLocation(List<InspectionLocationBean> locationBeans) { + isHaseAginData = true; + if (locationBeans != null) { + aginShowlocationBeans = locationBeans; + } + if (webViewIsFinished) { + if (aginShowlocationBeans != null) { + for (InspectionLocationBean inspectionLocationBean : aginShowlocationBeans) { + Log.i("mWebView", "aginShowLocation" + inspectionLocationBean.getLng() + "\",\"" + inspectionLocationBean.getLat()); + mWebView.evaluateJavascript("javascript:aginShowLocation(\"" + inspectionLocationBean.getLng() + "\",\"" + inspectionLocationBean.getLat() + "\")", value -> { + }); + } + // 鍚� WebView 娉ㄥ叆鏁版嵁 + + aginShowlocationBeans.clear(); + + } + + } + } + + /** + * 寮�濮嬪贰妫�鐨勭浉鍏抽�昏緫 + * + * @param location + */ + private void startLocation(Intent location) { + //鑾峰彇瀹氫綅鏈嶅姟浼犺繃鏉ョ殑鍧愭爣鐐� + LiveEventBus.get(CommonKeyName.locationData).observeForever(locationObserver); + binding.inspectRL.setVisibility(View.VISIBLE); + binding.inspectButton.setVisibility(View.GONE); + binding.inspectPause.setText("鏆傚仠"); + binding.stateText.setText("宸插紑鍚贰妫�"); + binding.inspectRL.setBackgroundColor(this.getContext().getResources().getColor(R.color.base_blue)); + //寮�鍚畾浣� + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { + this.getActivity().startForegroundService(location); + } else { + this.getActivity().startService(location); + } + inspectionRequest = new InspectionRequest(); + SharedPreferencesHelper.getInstance(this.getContext()).put(CommonKeyName.inspectionState, InspectionUtils.STAT_INSPECTION); + } + } -- Gitblit v1.8.0