app/src/main/java/safeluck/drive/evaluation/Constant.java
@@ -62,5 +62,6 @@ public static final String WORK_PLATFORM_STATUS_COLUMN = "WORK_PLATFORM_STATUS_COLUMN"; public static final int ENTER_OR_EXIT_ITEM = 0x000D; public static final int HAS_BEEN_START_EXAM = 1; public static String exam_enter_exitdata="exam_enter_exitdata"; } app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusDao.java
@@ -20,4 +20,7 @@ void updateEnter(int enter,int mapid); @Query("update exam_status set startExam =:startexam") void updateStartExam(int startexam); @Query("select startExam from exam_status where map_id=1") LiveData<Integer> getStartExam(); } app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusInitWorker.java
@@ -17,12 +17,10 @@ private static final String TAG = ExamStatusInitWorker.class.getSimpleName(); private ExamStatus examStatus; private Random random; public ExamStatusInitWorker(@NonNull Context context, @NonNull WorkerParameters workerParams) { super(context, workerParams); examStatus = new ExamStatus(); random = new Random(3); } @NonNull @@ -30,9 +28,7 @@ public Result doWork() { MyLog.i(TAG,"exam_status表reset 初始化"); for (int i = 0; i < 5; i++) { int a = random.nextInt(3); Log.i(TAG, "doWork: a="+a); examStatus.setEnter(a);//默认待考项目 examStatus.setEnter(2);//默认待考项目 examStatus.setStartExam(0);//默认没有开始考试 examStatus.setMap_id(i+1); app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusViewModel.java
@@ -11,10 +11,12 @@ public class ExamStatusViewModel extends AndroidViewModel { ExamStatusWorkRepo examStatusWorkRepo; LiveData<List<ExamStatus>> examStatus; LiveData<Integer> startExam; public ExamStatusViewModel(@NonNull Application application) { super(application); examStatusWorkRepo = new ExamStatusWorkRepo(application); examStatus = examStatusWorkRepo.getExamStatus(); startExam = examStatusWorkRepo.getStartExam(); } public void insert(ExamStatus examStatus){ @@ -32,4 +34,8 @@ public void updateStartExam(int statExam) { examStatusWorkRepo.updateStartExam(statExam); } public LiveData<Integer> getStartExam() { return startExam; } } app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusWorkRepo.java
@@ -11,9 +11,11 @@ public class ExamStatusWorkRepo { private ExamStatusDao examStatusDao; private LiveData<List<ExamStatus>> examStatusLiveData; private LiveData<Integer> startExam; public ExamStatusWorkRepo(Application application) { examStatusDao = WorkRoomDataBase.getWorkRoomDataBase(application).getExamStatusDao(); examStatusLiveData = examStatusDao.getExamStatus(); startExam = examStatusDao.getStartExam(); } public void insertExamStatus(final ExamStatus examStatus){ @@ -46,4 +48,8 @@ public LiveData<List<ExamStatus>> getExamStatus() { return examStatusLiveData; } public LiveData<Integer> getStartExam() { return startExam; } } app/src/main/java/safeluck/drive/evaluation/app.java
@@ -123,9 +123,8 @@ case Constant.NDK_START: sendVechileInfo(); sendMapInfo(); OneTimeWorkRequest examStatusInitWork = OneTimeWorkRequest.from(ExamStatusInitWorker.class); WorkManager.getInstance(getApplicationContext()).enqueue(examStatusInitWork); //TODO 需要清除app_status数据库表 break; case Constant.RTK_PLATFORM_REGISTER_STATUS: CEventCenter.dispatchEvent(Constant.BIND_CONNECT_RTK_TOPIC,cmd,0,json); @@ -160,7 +159,8 @@ break; case Constant.EXAM_STATUS_REPLY: MyLog.d(TAG, "考试开始,需要删除上一个考试学员的数据库失败项目表"); MyLog.d(TAG, "考试开始,复位数据库失败项目表"); try { failedProjRepository.deleteAll(); JSONObject jsonObject =new JSONObject((String)json); app/src/main/java/safeluck/drive/evaluation/fragment/NetWorkTrainFragment.java
@@ -10,6 +10,7 @@ import android.view.ViewGroup; import android.widget.Button; import android.widget.ListView; import android.widget.TextView; import android.widget.Toast; @@ -17,8 +18,11 @@ import androidx.annotation.Nullable; import androidx.lifecycle.Observer; import androidx.lifecycle.ViewModelProviders; import androidx.work.OneTimeWorkRequest; import androidx.work.WorkManager; import com.anyun.exam.lib.AYSdk; import com.anyun.exam.lib.MyLog; import org.json.JSONException; import org.json.JSONObject; @@ -28,6 +32,7 @@ import me.yokeyword.fragmentation.SupportFragment; import safeluck.drive.evaluation.Constant; 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; @@ -50,6 +55,7 @@ private static final String TAG = NetWorkTrainFragment.class.getSimpleName(); private ListView mListView; private Button btn_start_exam; private TextView tv_stop;//呼叫请求(结束考试) private ScoreAdapter mScoreAdapter; private ArrowView av_zhijiao, av_curve, av_park, av_podao; private HouseView houseView; @@ -70,11 +76,11 @@ @Override public boolean handleMessage(Message msg) { if (msg.what == ADD_DATA){ av_curve.setColor(whatPaintColor(examStatusList.get(3))); av_zhijiao.setColor(whatPaintColor(examStatusList.get(4))); houseView.setColor(whatPaintColor(examStatusList.get(0))); av_podao.setColor(whatPaintColor(examStatusList.get(1))); av_park.setColor(whatPaintColor(examStatusList.get(2))); houseView.setColor(whatPaintColor(examStatusList.get(0))); av_curve.setColor(whatPaintColor(examStatusList.get(3))); av_zhijiao.setColor(whatPaintColor(examStatusList.get(4))); } return false; } @@ -84,13 +90,14 @@ @Override public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { View view = inflater.inflate(R.layout.layout_train_fragment, container, false); item_conents.add("侧方停车"); initView(view); FailedProjViewModel failedProjViewModel = ViewModelProviders.of(this).get(FailedProjViewModel.class); failedProjViewModel.getFailedProjectsForI(Constant.TEST_STU_ID).observe(this, new Observer<List<FailedProj_select>>() { @Override public void onChanged(List<FailedProj_select> failedProj_selects) { if (failedProj_selects != null && failedProj_selects.size()>0){ item_id = 0; mArrayList.clear(); item_conents.clear(); @@ -102,6 +109,10 @@ item_conents.add(f.getItem_content()); mScoreAdapter.addDatas(mArrayList); } MyLog.i(TAG,"监测到有失败项目加入,通知UI更新颜色"); mHandler.obtainMessage(ADD_DATA).sendToTarget(); } } }); @@ -111,17 +122,27 @@ @Override public void onChanged(List<ExamStatus> examStatus) { for (ExamStatus e : examStatus) { Log.i(TAG, "onChanged: e="+e.toString()); } Log.i(TAG, "onChanged: "); Log.i(TAG, "ExamStatus onChanged: "); if (examStatus!=null && examStatus.size()>0){ MyLog.i(TAG,"考试状态更新"); examStatusList.clear(); examStatusList.addAll(examStatus); mHandler.obtainMessage(ADD_DATA).sendToTarget(); if (examStatus.get(0).getStartExam() == Constant.HAS_BEEN_START_EXAM){ btn_start_exam.setEnabled(false); tv_stop.setEnabled(true); }else{ btn_start_exam.setEnabled(true); tv_stop.setEnabled(false); } } } }); return view; } @@ -175,26 +196,13 @@ private void initView(View view) { av_curve = view.findViewById(R.id.av2); av_park = view.findViewById(R.id.av3); av_podao = view.findViewById(R.id.av4); av_zhijiao = view.findViewById(R.id.av1); 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); //粉红色正在进行该项目的考试 // examStatusList.add(new ExamStatus(1, 0)); // examStatusList.add(new ExamStatus(2, 1)); // examStatusList.add(new ExamStatus(3, 0)); // examStatusList.add(new ExamStatus(4, 2)); // examStatusList.add(new ExamStatus(5, 1)); // mHandler.obtainMessage(ADD_DATA).sendToTarget(); // av_curve.setColor(whatPaintColor(examStatusList.get(3))); // av_zhijiao.setColor(whatPaintColor(examStatusList.get(4))); // av_podao.setColor(whatPaintColor(examStatusList.get(1))); // av_park.setColor(whatPaintColor(examStatusList.get(2))); // houseView.setColor(whatPaintColor(examStatusList.get(0))); view.findViewById(R.id.btn_return).setOnClickListener(this); mListView = view.findViewById(R.id.lv); mListView.setFocusable(false); view.findViewById(R.id.view_map).setOnClickListener(this); @@ -202,7 +210,8 @@ mListView.setAdapter(mScoreAdapter); btn_start_exam = view.findViewById(R.id.btn_start); btn_start_exam.setOnClickListener(this); view.findViewById(R.id.tv_stop).setOnClickListener(this); tv_stop = view.findViewById(R.id.tv_stop); tv_stop.setOnClickListener(this); mListView.addHeaderView(LayoutInflater.from(_mActivity).inflate(R.layout.layout_score_item, null)); } @@ -213,6 +222,7 @@ public void onClick(View v) { switch (v.getId()) { case R.id.btn_start: examStatusViewModel.updateStartExam(Constant.HAS_BEEN_START_EXAM); try { JSONObject jsonObject = new JSONObject(); jsonObject.put("exam", 1); @@ -225,6 +235,8 @@ 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); @@ -242,6 +254,9 @@ } start(mapFragment); break; case R.id.btn_return: _mActivity.onBackPressed(); break; } } 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;//扣分分数总和 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) { 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,"主动推送RTKConfig"); // 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; } } app/src/main/res/drawable/btn_start_bg.xml
New file @@ -0,0 +1,6 @@ <?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:state_pressed="true" android:drawable="@android:color/holo_orange_dark"/> <item android:state_enabled="false" android:drawable="@android:color/darker_gray"/> <item android:drawable="@android:color/holo_red_dark"/> </selector> app/src/main/res/layout/layout_net_train.xml
@@ -46,7 +46,7 @@ android:textColor="@android:color/white" android:padding="10dp" android:background="@color/colorAccent" android:background="@drawable/btn_start_bg" android:layout_toRightOf="@+id/tv_pos"/> </RelativeLayout> <include layout="@layout/layout_net_train_item"/> app/src/main/res/layout/layout_train_exit.xml
@@ -18,7 +18,7 @@ <Button android:layout_width="110dp" android:layout_height="wrap_content" android:background="@android:color/holo_red_dark" android:background="@drawable/btn_start_bg" android:layout_marginTop="10dp" android:textSize="20sp" android:layout_below="@+id/btn_return"