yy1717
2020-01-14 ed0bc77b9c7168b8c3690f018da9aef230e34c61
Merge branch 'master' of https://gitee.com/endian11/DriveJudge
13个文件已修改
6个文件已添加
503 ■■■■■ 已修改文件
app/src/main/assets/vehiclemodel.json 14 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/Constant.java 3 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/DB/WorkRoomDataBase.java 9 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/DB/appstatusdb/AppStatusDao.java 2 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatus.java 69 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusDao.java 23 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusInitWorker.java 43 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusViewModel.java 35 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusWoker.java 43 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusWorkRepo.java 49 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/MainActivity.java 9 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/app.java 13 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/customview/ArrowView.java 7 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/customview/HouseView.java 6 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/fragment/NetWorkTrainFragment.java 156 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/fragment/TcpFragment.java 9 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/res/layout/layout_net_train_item.xml 8 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/res/values/attrs.xml 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/res/values/colors.xml 3 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/assets/vehiclemodel.json
@@ -1,9 +1,9 @@
{
  "main_ant": [123.3, 85.5],
  "axial": [0, 18],
  "left_front_tire": [4, 5],
  "right_front_tire": [6, 7],
  "left_rear_tire": [8, 9],
  "right_rear_tire": [10, 11],
  "point": [-11.9669, 28.013, -11.5114, 27.137, -10.8069, 27.5039, -10.2969, 26.4212, -9.2102, 26.8894, -9.6513, 28.0027, -8.9758, 28.3797, -9.5057, 29.3232]
  "main_ant": [0, 0],
  "axial": [0, 3],
  "left_front_tire": [1, 0],
  "right_front_tire": [5, 0],
  "left_rear_tire": [2, 3],
  "right_rear_tire": [4, 3],
  "point": [0, 2, -1, 2, -1, -1, 0, -1, 1, -1, 1, 2]
}
app/src/main/java/safeluck/drive/evaluation/Constant.java
@@ -60,4 +60,7 @@
    public static final String RTK_LOGIN_CODE_COLUMN = "RTK_LOGIN_CODE_COLUMN";
    public static final String RTK_CONN_STATUS_COLUMN = "RTK_CONN_STATUS_COLUMN";
    public static final String WORK_PLATFORM_STATUS_COLUMN = "WORK_PLATFORM_STATUS_COLUMN";
    public static final int ENTER_OR_EXIT_ITEM = 0x000D;
    public static String exam_enter_exitdata="exam_enter_exitdata";
}
app/src/main/java/safeluck/drive/evaluation/DB/WorkRoomDataBase.java
@@ -24,6 +24,9 @@
import safeluck.drive.evaluation.DB.criterias.CriteriaForIWorker;
import safeluck.drive.evaluation.DB.criterias.CriteriaIDao;
import safeluck.drive.evaluation.DB.criterias.CriteriaIIDao;
import safeluck.drive.evaluation.DB.exam_status.ExamStatus;
import safeluck.drive.evaluation.DB.exam_status.ExamStatusDao;
import safeluck.drive.evaluation.DB.exam_status.ExamStatusInitWorker;
import safeluck.drive.evaluation.DB.failitems.FailProjDao;
import safeluck.drive.evaluation.DB.failitems.FailedProj;
import safeluck.drive.evaluation.DB.failitems.FailedProjWorker;
@@ -40,7 +43,7 @@
 * 邮箱:632393724@qq.com
 * All Rights Saved! Chongqing AnYun Tech co. LTD
 */
@Database(entities = {Student.class, CriteriaForI.class, FailedProj.class, CriteriaForII.class, RTKConfig.class, GPSInfo.class, AppStatus.class},version = 1,exportSchema = false)
@Database(entities = {Student.class, CriteriaForI.class, FailedProj.class, CriteriaForII.class, RTKConfig.class, GPSInfo.class, AppStatus.class, ExamStatus.class},version = 1,exportSchema = false)
public abstract class WorkRoomDataBase extends RoomDatabase {
    private static final String TAG = "WorkRoomDataBase";
    public abstract StudentDao getstudentDao();
@@ -82,6 +85,7 @@
                                    OneTimeWorkRequest oneTimeWorkRequest2 = OneTimeWorkRequest.from(FailedProjWorker.class);
                                    OneTimeWorkRequest RTKConfigWorkRequest = OneTimeWorkRequest.from(RTKConfigWork.class);
                                    OneTimeWorkRequest appStatusInitWork = OneTimeWorkRequest.from(AppStatusInitWork.class);
                                    OneTimeWorkRequest examStatusInitWorker = OneTimeWorkRequest.from(ExamStatusInitWorker.class);
                                    Log.i(TAG, "onCreate: 创建数据库后建立数据表插入数据");
                                    WorkManager.getInstance(mContext).enqueue(oneTimeWorkRequest);
                                    WorkManager.getInstance(mContext).enqueue(oneTimeWorkRequest1);
@@ -89,6 +93,7 @@
                                    WorkManager.getInstance(mContext).enqueue(oneTimeWorkRequest3);
                                    WorkManager.getInstance(mContext).enqueue(RTKConfigWorkRequest);
                                    WorkManager.getInstance(mContext).enqueue(appStatusInitWork);
                                    WorkManager.getInstance(mContext).enqueue(examStatusInitWorker);
                                }
                                @Override
@@ -110,4 +115,6 @@
    public abstract GpsInfoDao getGpsInoDao();
    public abstract AppStatusDao getAppStatusDao();
    public abstract ExamStatusDao getExamStatusDao();
}
app/src/main/java/safeluck/drive/evaluation/DB/appstatusdb/AppStatusDao.java
@@ -2,6 +2,7 @@
import androidx.lifecycle.LiveData;
import androidx.room.Dao;
import androidx.room.Delete;
import androidx.room.Insert;
import androidx.room.OnConflictStrategy;
import androidx.room.Query;
@@ -22,4 +23,5 @@
    //更新业务平台连接状态
    @Query("update app_status set work_platform=:connStatus where id=0")
    void updatework_platformStatus(int connStatus);
}
app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatus.java
New file
@@ -0,0 +1,69 @@
package safeluck.drive.evaluation.DB.exam_status;
import androidx.room.Entity;
import androidx.room.Ignore;
import androidx.room.PrimaryKey;
@Entity(tableName = "exam_status")
public class ExamStatus {
//    1 - 倒库
//2 - 坡起
//3 - 侧方停车
//4 - 曲线行驶
//5 - 直角转弯
@PrimaryKey
    private int map_id;
    //0 退出(考试完毕)
    //1 进入(正在进行考试)  2-待考
    private int enter;
    //表示已经点击了开始考试,并且收到了考试应答 1-已经开始考试 0-未考试
    private int startExam;
    @Ignore
    public ExamStatus(int map_id, int enter) {
        this.map_id = map_id;
        this.enter = enter;
    }
    public ExamStatus() {
    }
    public int getMap_id() {
        return map_id;
    }
    public void setMap_id(int map_id) {
        this.map_id = map_id;
    }
    public int getEnter() {
        return enter;
    }
    public void setEnter(int enter) {
        this.enter = enter;
    }
    public int getStartExam() {
        return startExam;
    }
    public void setStartExam(int startExam) {
        this.startExam = startExam;
    }
    @Override
    public String toString() {
        return "ExamStatus{" +
                "map_id=" + map_id +
                ", enter=" + enter +
                ", startExam=" + startExam +
                '}';
    }
}
app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusDao.java
New file
@@ -0,0 +1,23 @@
package safeluck.drive.evaluation.DB.exam_status;
import androidx.lifecycle.LiveData;
import androidx.room.Dao;
import androidx.room.Insert;
import androidx.room.OnConflictStrategy;
import androidx.room.Query;
import java.util.List;
@Dao
public interface ExamStatusDao {
    @Insert(onConflict = OnConflictStrategy.REPLACE)
    void insert(ExamStatus examStatus);
    @Query("Select * from exam_status")
    LiveData<List<ExamStatus>> getExamStatus();
    @Query("update exam_status set enter =:enter where map_id =:mapid")
    void updateEnter(int enter,int mapid);
    @Query("update exam_status set startExam =:startexam")
    void updateStartExam(int startexam);
}
app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusInitWorker.java
New file
@@ -0,0 +1,43 @@
package safeluck.drive.evaluation.DB.exam_status;
import android.content.Context;
import android.util.Log;
import androidx.annotation.NonNull;
import androidx.work.Worker;
import androidx.work.WorkerParameters;
import com.anyun.exam.lib.MyLog;
import java.util.Random;
import safeluck.drive.evaluation.DB.WorkRoomDataBase;
public class ExamStatusInitWorker extends Worker {
    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
    @Override
    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.setStartExam(0);//默认没有开始考试
            examStatus.setMap_id(i+1);
            WorkRoomDataBase.getWorkRoomDataBase(getApplicationContext()).getExamStatusDao().insert(examStatus);
        }
        return Result.success();
    }
}
app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusViewModel.java
New file
@@ -0,0 +1,35 @@
package safeluck.drive.evaluation.DB.exam_status;
import android.app.Application;
import androidx.annotation.NonNull;
import androidx.lifecycle.AndroidViewModel;
import androidx.lifecycle.LiveData;
import java.util.List;
public class ExamStatusViewModel extends AndroidViewModel {
    ExamStatusWorkRepo examStatusWorkRepo;
    LiveData<List<ExamStatus>> examStatus;
    public ExamStatusViewModel(@NonNull Application application) {
        super(application);
        examStatusWorkRepo = new ExamStatusWorkRepo(application);
        examStatus = examStatusWorkRepo.getExamStatus();
    }
    public void insert(ExamStatus examStatus){
        examStatusWorkRepo.insertExamStatus(examStatus);
    }
    public LiveData<List<ExamStatus>> getExamStatus(){
        return examStatus;
    }
    public void updateExamStatus(int enter, int mapid) {
        examStatusWorkRepo.updateExamStatus(enter,mapid);
    }
    public void updateStartExam(int statExam) {
        examStatusWorkRepo.updateStartExam(statExam);
    }
}
app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusWoker.java
New file
@@ -0,0 +1,43 @@
package safeluck.drive.evaluation.DB.exam_status;
import android.content.Context;
import android.text.TextUtils;
import androidx.annotation.NonNull;
import androidx.work.WorkManager;
import androidx.work.Worker;
import androidx.work.WorkerParameters;
import org.json.JSONException;
import org.json.JSONObject;
import safeluck.drive.evaluation.Constant;
import safeluck.drive.evaluation.DB.WorkRoomDataBase;
public class ExamStatusWoker extends Worker {
    public ExamStatusWoker(@NonNull Context context, @NonNull WorkerParameters workerParams) {
        super(context, workerParams);
    }
    @NonNull
    @Override
    public Result doWork() {
        String str = getInputData().getString(Constant.exam_enter_exitdata);
        if (!TextUtils.isEmpty(str)){
            JSONObject jsonObject = null;
            try {
                jsonObject = new JSONObject(str);
                int mapId = jsonObject.getInt("map_id");
                int enter = jsonObject.getInt("enter");
                WorkRoomDataBase.getWorkRoomDataBase(getApplicationContext()).getExamStatusDao().updateEnter(enter,mapId);
                return Result.success();
            } catch (JSONException e) {
                e.printStackTrace();
                return Result.failure();
            }
        }
        return Result.success();
    }
}
app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusWorkRepo.java
New file
@@ -0,0 +1,49 @@
package safeluck.drive.evaluation.DB.exam_status;
import android.app.Application;
import androidx.lifecycle.LiveData;
import java.util.List;
import safeluck.drive.evaluation.DB.WorkRoomDataBase;
public class ExamStatusWorkRepo {
    private ExamStatusDao examStatusDao;
    private LiveData<List<ExamStatus>> examStatusLiveData;
    public ExamStatusWorkRepo(Application application) {
        examStatusDao = WorkRoomDataBase.getWorkRoomDataBase(application).getExamStatusDao();
        examStatusLiveData = examStatusDao.getExamStatus();
    }
    public void insertExamStatus(final ExamStatus examStatus){
        WorkRoomDataBase.dataBaseWriteExecutor.execute(new Runnable() {
            @Override
            public void run() {
                examStatusDao.insert(examStatus);
            }
        });
    }
    public void updateExamStatus(final int enter, final int mapid){
        WorkRoomDataBase.dataBaseWriteExecutor.execute(new Runnable() {
            @Override
            public void run() {
                examStatusDao.updateEnter(enter,mapid);
            }
        });
    }
    public void updateStartExam(final int startex){
        WorkRoomDataBase.dataBaseWriteExecutor.execute(new Runnable() {
            @Override
            public void run() {
                examStatusDao.updateStartExam(startex);
            }
        });
    }
    public LiveData<List<ExamStatus>> getExamStatus() {
        return examStatusLiveData;
    }
}
app/src/main/java/safeluck/drive/evaluation/MainActivity.java
@@ -49,6 +49,7 @@
    private Gson gson = new Gson();
    String[] PERMISSIONS = new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE, Manifest.permission.CAMERA};
    RTKConfigViewModel rtkConfigViewModel;
    private boolean onlySendOnceRTKConfig = true;
    private ICEventListener icEventListener = new ICEventListener() {
        @Override
@@ -122,7 +123,13 @@
                MyLog.i(TAG, "RTKConfig Changed: " + (rtkConfig != null ? rtkConfig.toString() : "null"));
                mRTKConfig = rtkConfig;
                sendRtkConfigInfo();
                synchronized (MainActivity.this){
                    if (onlySendOnceRTKConfig){
                        onlySendOnceRTKConfig = false;
                        sendRtkConfigInfo();
                    }
                }
            }
        });
app/src/main/java/safeluck/drive/evaluation/app.java
@@ -34,6 +34,8 @@
import safeluck.drive.evaluation.DB.WorkRoomDataBase;
import safeluck.drive.evaluation.DB.appstatusdb.AppStatusWorker;
import safeluck.drive.evaluation.DB.exam_status.ExamStatusInitWorker;
import safeluck.drive.evaluation.DB.exam_status.ExamStatusWoker;
import safeluck.drive.evaluation.DB.failitems.FailedProj;
import safeluck.drive.evaluation.DB.failitems.FailedProjRepository;
import safeluck.drive.evaluation.DB.gps.GpsInfoWorker;
@@ -119,7 +121,11 @@
        MyLog.d(TAG, String.format("收到命令[%d],Json内容为%s", cmd, json));
        switch (cmd) {
            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);
@@ -195,6 +201,11 @@
                OneTimeWorkRequest gpsinfoWorkRequest = new OneTimeWorkRequest.Builder(GpsInfoWorker.class).setInputData(gpsData).build();
                WorkManager.getInstance(getApplicationContext()).enqueue(gpsinfoWorkRequest);
                break;
            case Constant.ENTER_OR_EXIT_ITEM:
                Data exam_enter_exitdata = new Data.Builder().putString(Constant.exam_enter_exitdata,json).build();
                OneTimeWorkRequest examStatusWorker = new OneTimeWorkRequest.Builder(ExamStatusWoker.class).setInputData(exam_enter_exitdata).build();
                WorkManager.getInstance(getApplicationContext()).enqueue(examStatusWorker);
                break;
        }
app/src/main/java/safeluck/drive/evaluation/customview/ArrowView.java
@@ -11,6 +11,7 @@
import android.util.TypedValue;
import android.view.View;
import androidx.annotation.ColorRes;
import androidx.annotation.Nullable;
import safeluck.drive.evaluation.R;
@@ -44,6 +45,7 @@
        super(context, attrs, defStyleAttr);
        TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.ArrowView,defStyleAttr,0);
        text = a.getString(R.styleable.ArrowView_text);
        color = a.getColor(R.styleable.ArrowView_color,Color.parseColor("#99C3D1"));
        a.recycle();
    }
@@ -76,4 +78,9 @@
        }
        return keys;
    }
    public void setColor( int mColor){
        this.color = mColor;
        requestLayout();
    }
}
app/src/main/java/safeluck/drive/evaluation/customview/HouseView.java
@@ -41,6 +41,7 @@
        super(context, attrs, defStyleAttr);
        TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.ArrowView,defStyleAttr,0);
        text = typedArray.getString(R.styleable.ArrowView_text);
        color = typedArray.getColor(R.styleable.ArrowView_color,Color.parseColor("#99C3D1"));
        typedArray.recycle();
    }
@@ -76,4 +77,9 @@
        }
        return keys;
    }
    public void setColor(int mColor){
        this.color = mColor;
        requestLayout();
    }
}
app/src/main/java/safeluck/drive/evaluation/fragment/NetWorkTrainFragment.java
@@ -2,6 +2,8 @@
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
@@ -17,26 +19,24 @@
import androidx.lifecycle.ViewModelProviders;
import com.anyun.exam.lib.AYSdk;
import com.anyun.exam.lib.MyLog;
import com.google.gson.Gson;
import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
import org.json.JSONException;
import org.json.JSONObject;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import me.yokeyword.fragmentation.SupportFragment;
import safeluck.drive.evaluation.Constant;
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;
import safeluck.drive.evaluation.adapter.ScoreAdapter;
import safeluck.drive.evaluation.DB.exam_status.ExamStatus;
import safeluck.drive.evaluation.bean.ScoreBean;
import safeluck.drive.evaluation.cEventCenter.CEventCenter;
import safeluck.drive.evaluation.customview.ArrowView;
import safeluck.drive.evaluation.customview.HouseView;
/**
 * 联网训练UI
@@ -48,11 +48,17 @@
public class NetWorkTrainFragment extends SupportFragment implements View.OnClickListener {
    private static final String TAG = NetWorkTrainFragment.class.getSimpleName();
    private ListView mListView ;
    private ListView mListView;
    private Button btn_start_exam;
    private ScoreAdapter mScoreAdapter;
    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 int item_id;//扣分分数总和
    private ExamStatusViewModel examStatusViewModel;
    private static final int ADD_DATA = 1;
    private List<ScoreBean> mArrayList = new ArrayList<>();
@@ -60,10 +66,25 @@
        return new NetWorkTrainFragment();
    }
    private Handler mHandler = new Handler(new Handler.Callback() {
        @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)));
                av_podao.setColor(whatPaintColor(examStatusList.get(1)));
                av_park.setColor(whatPaintColor(examStatusList.get(2)));
                houseView.setColor(whatPaintColor(examStatusList.get(0)));
            }
            return false;
        }
    });
    @Nullable
    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.layout_train_fragment,container,false);
        View view = inflater.inflate(R.layout.layout_train_fragment, container, false);
        item_conents.add("侧方停车");
        initView(view);
        FailedProjViewModel failedProjViewModel = ViewModelProviders.of(this).get(FailedProjViewModel.class);
@@ -72,22 +93,108 @@
            public void onChanged(List<FailedProj_select> failedProj_selects) {
                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()));
                    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);
                }
            }
        });
        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();
            }
        });
        return view;
    }
    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);
    }
    private void initView(View view) {
        sendRTKConfig2RemoteService();
        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);
        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)));
        mListView = view.findViewById(R.id.lv);
        mListView.setFocusable(false);
        view.findViewById(R.id.view_map).setOnClickListener(this);
@@ -96,23 +203,22 @@
        btn_start_exam = view.findViewById(R.id.btn_start);
        btn_start_exam.setOnClickListener(this);
        view.findViewById(R.id.tv_stop).setOnClickListener(this);
        mListView.addHeaderView(LayoutInflater.from(_mActivity).inflate(R.layout.layout_score_item,null));
        mListView.addHeaderView(LayoutInflater.from(_mActivity).inflate(R.layout.layout_score_item, null));
    }
    private void sendRTKConfig2RemoteService() {
//        MyLog.d(TAG,"主动推送RTKConfig");
//        CEventCenter.dispatchEvent(Constant.BIND_RTKCONFIG_TOPIC,Constant.FETCH_RTK_PLATFORM_INFO,0,"");
    }
    @Override
    public void onClick(View v) {
        switch (v.getId()){
        switch (v.getId()) {
            case R.id.btn_start:
                try {
                    JSONObject jsonObject = new JSONObject();
                    jsonObject.put("exam",1);
                    jsonObject.put("exam", 1);
                    String examJson = jsonObject.toString();
                    Log.i(TAG, "onClick: "+examJson);
                    AYSdk.getInstance().sendCmd(Constant.EXAM_STATUS,examJson);
                    Log.i(TAG, "onClick: " + examJson);
                    AYSdk.getInstance().sendCmd(Constant.EXAM_STATUS, examJson);
                } catch (JSONException e) {
                    e.printStackTrace();
                }
@@ -121,18 +227,18 @@
                Toast.makeText(_mActivity, "结束考试", Toast.LENGTH_SHORT).show();
                try {
                    JSONObject jsonObject = new JSONObject();
                    jsonObject.put("exam",0);
                    jsonObject.put("exam", 0);
                    String examJson = jsonObject.toString();
                    Log.i(TAG, "onClick: "+examJson);
                    AYSdk.getInstance().sendCmd(Constant.EXAM_STATUS,examJson);
                    Log.i(TAG, "onClick: " + examJson);
                    AYSdk.getInstance().sendCmd(Constant.EXAM_STATUS, examJson);
                } catch (JSONException e) {
                    e.printStackTrace();
                }
                break;
            case R.id.view_map:
                MapFragment mapFragment = findFragment(MapFragment.class);
                if (mapFragment==null){
                    mapFragment = (MapFragment)MapFragment.newInstance();
                if (mapFragment == null) {
                    mapFragment = (MapFragment) MapFragment.newInstance();
                }
                start(mapFragment);
                break;
app/src/main/java/safeluck/drive/evaluation/fragment/TcpFragment.java
@@ -29,8 +29,12 @@
import safeluck.drive.evaluation.DB.Student;
import safeluck.drive.evaluation.DB.WokViewModel;
import safeluck.drive.evaluation.DB.WorkRoomDataBase;
import safeluck.drive.evaluation.DB.appstatusdb.AppStatusInitWork;
import safeluck.drive.evaluation.DB.criterias.CriteriaForI;
import safeluck.drive.evaluation.DB.criterias.viewmodel.CriteriaIViewModel;
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.FailedProj;
import safeluck.drive.evaluation.DB.failitems.FailedProj_select;
import safeluck.drive.evaluation.DB.gps.GpsInfoWorker;
@@ -68,6 +72,7 @@
        View view = inflater.inflate(R.layout.layout_tcpclient, container, false);
        initView(view);
//        workViewModel =ViewModelProviders.of(this).get(CriteriaIViewModel.class);
  
        return view;
@@ -133,7 +138,9 @@
//                MessageProcessor.getInstance().sendMessage(sendEditText.getText().toString().trim());
//                sendEditText.getText().clear();
                //清除app_status 表
//                OneTimeWorkRequest oneTimeWorkRequest = new OneTimeWorkRequest.Builder(AppStatusInitWork.class).build();
//                WorkManager.getInstance(_mActivity).enqueue(oneTimeWorkRequest);
                break;
app/src/main/res/layout/layout_net_train_item.xml
@@ -20,13 +20,13 @@
        android:layout_height="80dp"
        android:layout_toRightOf="@+id/hv"
        android:id="@+id/av1"
        app:text="直角转弯"
        app:text="坡道定点"
        android:layout_marginLeft="-15dp"
        />
    <safeluck.drive.evaluation.customview.ArrowView
        android:layout_width="80dp"
        android:layout_height="80dp"
        app:text="曲线行驶"
        app:text="侧方停车"
        android:layout_marginLeft="-15dp"
        android:layout_toRightOf="@+id/av1"
        android:id="@+id/av2"
@@ -35,7 +35,7 @@
        android:layout_width="80dp"
        android:layout_height="80dp"
        android:id="@+id/av3"
        app:text="侧方停车"
        app:text="曲线行驶"
        android:layout_marginLeft="-15dp"
        android:layout_toRightOf="@id/av2"
        />
@@ -45,7 +45,7 @@
        android:layout_marginLeft="-15dp"
        android:layout_toRightOf="@+id/av3"
        android:id="@+id/av4"
        app:text="坡道定点"
        app:text="直角转弯"
        />
</RelativeLayout>
app/src/main/res/values/attrs.xml
@@ -8,10 +8,10 @@
    </declare-styleable>
    <declare-styleable name="ArrowView">
        <attr name="text" format="string" />
        <attr name="color" format="color" />
    </declare-styleable>
    <declare-styleable name="HouseView">
        <attr name="item" format="string" />
    </declare-styleable>
</resources>
app/src/main/res/values/colors.xml
@@ -11,4 +11,7 @@
    <color name="train_bg">#4aabb2</color>
    <color name="train_btn_return">#16aa3c</color>
    <color name="profile_bg">#1988a3</color>
    <color name="pink">#FF3399</color>
    <color name="examing">#99C3D1</color>
    <color name="red">#DC143C</color>
</resources>