From 2c215172a767c6101d530da549c4dd5d570719c7 Mon Sep 17 00:00:00 2001 From: yy1717 <fctom1215@outlook.com> Date: 星期二, 14 一月 2020 11:35:02 +0800 Subject: [PATCH] Merge branch 'master' of https://gitee.com/endian11/DriveJudge --- app/src/main/java/safeluck/drive/evaluation/fragment/TrainFragment.java | 180 +++++++++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 160 insertions(+), 20 deletions(-) diff --git a/app/src/main/java/safeluck/drive/evaluation/fragment/TrainFragment.java b/app/src/main/java/safeluck/drive/evaluation/fragment/TrainFragment.java index da9a80a..8c3dc88 100644 --- a/app/src/main/java/safeluck/drive/evaluation/fragment/TrainFragment.java +++ b/app/src/main/java/safeluck/drive/evaluation/fragment/TrainFragment.java @@ -7,7 +7,11 @@ import androidx.annotation.Nullable; import androidx.lifecycle.Observer; import androidx.lifecycle.ViewModelProviders; +import androidx.work.OneTimeWorkRequest; +import androidx.work.WorkManager; +import android.os.Handler; +import android.os.Message; import android.util.Log; import android.view.LayoutInflater; import android.view.View; @@ -16,7 +20,11 @@ import android.widget.ListView; import android.widget.Toast; +import com.anyun.exam.lib.AYSdk; import com.anyun.exam.lib.MyLog; + +import org.json.JSONException; +import org.json.JSONObject; import java.util.ArrayList; import java.util.EventListener; @@ -26,6 +34,9 @@ import safeluck.drive.evaluation.Constant; import safeluck.drive.evaluation.DB.Student; import safeluck.drive.evaluation.DB.WokViewModel; +import safeluck.drive.evaluation.DB.exam_status.ExamStatus; +import safeluck.drive.evaluation.DB.exam_status.ExamStatusInitWorker; +import safeluck.drive.evaluation.DB.exam_status.ExamStatusViewModel; import safeluck.drive.evaluation.DB.failitems.FailedProjViewModel; import safeluck.drive.evaluation.DB.failitems.FailedProj_select; import safeluck.drive.evaluation.R; @@ -33,6 +44,8 @@ import safeluck.drive.evaluation.bean.ScoreBean; import safeluck.drive.evaluation.cEventCenter.CEventCenter; import safeluck.drive.evaluation.cEventCenter.ICEventListener; +import safeluck.drive.evaluation.customview.ArrowView; +import safeluck.drive.evaluation.customview.HouseView; /**鍗曟満璁粌UI * MyApplication2 @@ -48,26 +61,41 @@ private ScoreAdapter mScoreAdapter; private int item_id;//鎵e垎鍒嗘暟鎬诲拰 + private ArrowView av_zhijiao, av_curve, av_park, av_podao; + private HouseView houseView; + private List<ExamStatus> examStatusList = new ArrayList<>(); + private List<String> item_conents = new ArrayList<>();//鍧¢亾瀹氱偣鍋滆溅鍜岃捣姝� + + private ExamStatusViewModel examStatusViewModel; + private static final int ADD_DATA = 1; private List<ScoreBean> mArrayList = new ArrayList<>(); + private View tv_stop; - private ICEventListener eventListener =new ICEventListener() { + + private Handler mHandler = new Handler(new Handler.Callback() { @Override - public void onCEvent(String topic, int msgCode, int resultCode, Object obj) { - Log.i(TAG, "onCEvent: "+(String)obj); + public boolean handleMessage(Message msg) { + if (msg.what == ADD_DATA){ + houseView.setColor(whatPaintColor(examStatusList.get(0))); + av_podao.setColor(whatPaintColor(examStatusList.get(1))); + av_park.setColor(whatPaintColor(examStatusList.get(2))); + av_curve.setColor(whatPaintColor(examStatusList.get(3))); + av_zhijiao.setColor(whatPaintColor(examStatusList.get(4))); + } + return false; } - }; + }); + @Override public void onAttach(Context context) { super.onAttach(context); - CEventCenter.onBindEvent(true, eventListener,"train"); } @Override public void onDetach() { super.onDetach(); - CEventCenter.onBindEvent(false,eventListener,"train"); } public static SupportFragment newInstance(){ @@ -86,23 +114,68 @@ failedProjViewModel.getFailedProjectsForI(Constant.TEST_STU_ID).observe(this, new Observer<List<FailedProj_select>>() { @Override public void onChanged(List<FailedProj_select> failedProj_selects) { - item_id = 0; - mArrayList.clear(); - for (FailedProj_select f : - failedProj_selects) { - item_id += f.getScore_deducting(); - Log.i(TAG, "onChanged: "+f.toString()); - mArrayList.add(new ScoreBean(f.getScore_deducting(),f.getItem_content(),f.getDeducting_reason())); - mScoreAdapter.addDatas(mArrayList); + if (failedProj_selects != null && failedProj_selects.size()>0){ + + item_id = 0; + mArrayList.clear(); + item_conents.clear(); + for (FailedProj_select f : + failedProj_selects) { + item_id += f.getScore_deducting(); + Log.i(TAG, "onChanged: " + f.toString()); + mArrayList.add(new ScoreBean(f.getScore_deducting(), f.getItem_content(), f.getDeducting_reason())); + item_conents.add(f.getItem_content()); + mScoreAdapter.addDatas(mArrayList); + } + + MyLog.i(TAG,"鐩戞祴鍒版湁澶辫触椤圭洰鍔犲叆锛岄�氱煡UI鏇存柊棰滆壊"); + mHandler.obtainMessage(ADD_DATA).sendToTarget(); + + }else { + Log.i(TAG, "onChanged: 澶辫触椤圭洰"); } + } + }); + + + examStatusViewModel = ViewModelProviders.of(this).get(ExamStatusViewModel.class); + examStatusViewModel.getExamStatus().observe(this, new Observer<List<ExamStatus>>() { + @Override + public void onChanged(List<ExamStatus> examStatus) { + + for (ExamStatus e : + examStatus) { + Log.i(TAG, "onChanged: e="+e.toString()); + } + Log.i(TAG, "onChanged: "); + examStatusList.clear(); + examStatusList.addAll(examStatus); + mHandler.obtainMessage(ADD_DATA).sendToTarget(); + if (examStatus.get(0).getStartExam() == Constant.HAS_BEEN_START_EXAM){ + btn_train.setEnabled(false); + tv_stop.setEnabled(true); + }else{ + btn_train.setEnabled(true); + tv_stop.setEnabled(false); + } + } }); return view; } private void initView(View view) { - sendRTKConfig2RemoteService(); + + av_curve = view.findViewById(R.id.av3); + av_park = view.findViewById(R.id.av2); + av_podao = view.findViewById(R.id.av1); + av_zhijiao = view.findViewById(R.id.av4); + houseView = view.findViewById(R.id.hv); + + view.findViewById(R.id.btn_return).setOnClickListener(this); mListView = view.findViewById(R.id.lv); + tv_stop = view.findViewById(R.id.tv_stop); + tv_stop.setOnClickListener(this); mListView.setFocusable(false);//listview涓嶈幏鍙栫劍鐐癸紝涓嶇劧鐨勮瘽scrollview浼氶《鍒板簳閮� view.findViewById(R.id.view_map).setOnClickListener(this); btn_train = view.findViewById(R.id.btn_start); @@ -117,11 +190,52 @@ } - private void sendRTKConfig2RemoteService() { -// MyLog.d(TAG,"涓诲姩鎺ㄩ�丷TKConfig"); -// CEventCenter.dispatchEvent(Constant.BIND_RTKCONFIG_TOPIC,Constant.FETCH_RTK_PLATFORM_INFO,0,""); - } + private int whatPaintColor(ExamStatus examStat) { + int map_id = examStat.getMap_id(); + int status = examStat.getEnter(); + Log.i(TAG, "whatPaintColor: map_id="+map_id+" status="+status); + switch (status) { + case 0://鑰冭瘯瀹屾垚 + switch (map_id) { + case 1://鍊掑簱 + if (item_conents.contains("鍊掕溅鍏ュ簱")) { + return getResources().getColor(R.color.colorAccent); + }else{ + return getResources().getColor(R.color.train_btn_return); + } + case 2: + if (item_conents.contains("鍧¢亾瀹氱偣鍋滆溅鍜岃捣姝�")) { + return getResources().getColor(R.color.colorAccent); + }else{ + return getResources().getColor(R.color.train_btn_return); + } + case 3: + if (item_conents.contains("渚ф柟鍋滆溅")) { + return getResources().getColor(R.color.colorAccent); + }else{ + return getResources().getColor(R.color.train_btn_return); + } + case 4: + if (item_conents.contains("鏇茬嚎琛岄┒")) { + return getResources().getColor(R.color.colorAccent); + }else{ + return getResources().getColor(R.color.train_btn_return); + } + case 5: + if (item_conents.contains("鐩磋杞集")) { + return getResources().getColor(R.color.colorAccent); + }else{ + return getResources().getColor(R.color.train_btn_return); + } + } + case 1://杩涘叆鑰冨満椤圭洰 + return getResources().getColor(R.color.pink); + case 2://寰呰�� + return getResources().getColor(R.color.examing); + } + return getResources().getColor(R.color.examing); + } @Override public void onClick(View v) { switch (v.getId()){ @@ -135,7 +249,33 @@ } break; case R.id.btn_start: - Toast.makeText(_mActivity, "寮�濮嬪方瀵�", Toast.LENGTH_SHORT).show(); + examStatusViewModel.updateStartExam(Constant.HAS_BEEN_START_EXAM); + try { + JSONObject jsonObject = new JSONObject(); + jsonObject.put("exam", 1); + String examJson = jsonObject.toString(); + Log.i(TAG, "onClick: " + examJson); + AYSdk.getInstance().sendCmd(Constant.EXAM_STATUS, examJson); + } catch (JSONException e) { + e.printStackTrace(); + } + break; + case R.id.tv_stop: + Toast.makeText(_mActivity, "缁撴潫鑰冭瘯", Toast.LENGTH_SHORT).show(); + OneTimeWorkRequest examStatusInitWork = OneTimeWorkRequest.from(ExamStatusInitWorker.class); + WorkManager.getInstance(_mActivity).enqueue(examStatusInitWork); + try { + JSONObject jsonObject = new JSONObject(); + jsonObject.put("exam", 0); + String examJson = jsonObject.toString(); + Log.i(TAG, "onClick: " + examJson); + AYSdk.getInstance().sendCmd(Constant.EXAM_STATUS, examJson); + } catch (JSONException e) { + e.printStackTrace(); + } + break; + case R.id.btn_return: + _mActivity.onBackPressed(); break; } } -- Gitblit v1.8.0