yy1717
2020-01-14 2c215172a767c6101d530da549c4dd5d570719c7
Merge branch 'master' of https://gitee.com/endian11/DriveJudge
10个文件已修改
1个文件已添加
273 ■■■■ 已修改文件
app/src/main/java/safeluck/drive/evaluation/Constant.java 1 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusDao.java 3 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusInitWorker.java 6 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusViewModel.java 6 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusWorkRepo.java 6 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/app.java 8 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/fragment/NetWorkTrainFragment.java 71 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/java/safeluck/drive/evaluation/fragment/TrainFragment.java 162 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/res/drawable/btn_start_bg.xml 6 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/res/layout/layout_net_train.xml 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
app/src/main/res/layout/layout_train_exit.xml 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
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"