From ed0bc77b9c7168b8c3690f018da9aef230e34c61 Mon Sep 17 00:00:00 2001 From: yy1717 <fctom1215@outlook.com> Date: 星期二, 14 一月 2020 11:17:26 +0800 Subject: [PATCH] Merge branch 'master' of https://gitee.com/endian11/DriveJudge --- app/src/main/java/safeluck/drive/evaluation/Constant.java | 3 app/src/main/res/layout/layout_net_train_item.xml | 8 app/src/main/res/values/attrs.xml | 2 app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusWoker.java | 43 ++++ app/src/main/java/safeluck/drive/evaluation/customview/HouseView.java | 6 app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusInitWorker.java | 43 ++++ app/src/main/res/values/colors.xml | 3 app/src/main/java/safeluck/drive/evaluation/app.java | 13 + app/src/main/java/safeluck/drive/evaluation/MainActivity.java | 9 app/src/main/assets/vehiclemodel.json | 14 app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusViewModel.java | 35 +++ app/src/main/java/safeluck/drive/evaluation/customview/ArrowView.java | 7 app/src/main/java/safeluck/drive/evaluation/DB/WorkRoomDataBase.java | 9 app/src/main/java/safeluck/drive/evaluation/DB/appstatusdb/AppStatusDao.java | 2 app/src/main/java/safeluck/drive/evaluation/fragment/NetWorkTrainFragment.java | 156 ++++++++++++++-- app/src/main/java/safeluck/drive/evaluation/fragment/TcpFragment.java | 9 app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatus.java | 69 +++++++ app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusDao.java | 23 ++ app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusWorkRepo.java | 49 +++++ 19 files changed, 462 insertions(+), 41 deletions(-) diff --git a/app/src/main/assets/vehiclemodel.json b/app/src/main/assets/vehiclemodel.json index 64ba654..30509bf 100644 --- a/app/src/main/assets/vehiclemodel.json +++ b/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] } \ No newline at end of file diff --git a/app/src/main/java/safeluck/drive/evaluation/Constant.java b/app/src/main/java/safeluck/drive/evaluation/Constant.java index 84e427a..d93692e 100644 --- a/app/src/main/java/safeluck/drive/evaluation/Constant.java +++ b/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"; } diff --git a/app/src/main/java/safeluck/drive/evaluation/DB/WorkRoomDataBase.java b/app/src/main/java/safeluck/drive/evaluation/DB/WorkRoomDataBase.java index 203bd99..e7893da 100644 --- a/app/src/main/java/safeluck/drive/evaluation/DB/WorkRoomDataBase.java +++ b/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(); } diff --git a/app/src/main/java/safeluck/drive/evaluation/DB/appstatusdb/AppStatusDao.java b/app/src/main/java/safeluck/drive/evaluation/DB/appstatusdb/AppStatusDao.java index 76f91a1..61e3a2f 100644 --- a/app/src/main/java/safeluck/drive/evaluation/DB/appstatusdb/AppStatusDao.java +++ b/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); + } diff --git a/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatus.java b/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatus.java new file mode 100644 index 0000000..40de2af --- /dev/null +++ b/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatus.java @@ -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 + + '}'; + } +} diff --git a/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusDao.java b/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusDao.java new file mode 100644 index 0000000..bf5b3e0 --- /dev/null +++ b/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusDao.java @@ -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); +} diff --git a/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusInitWorker.java b/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusInitWorker.java new file mode 100644 index 0000000..6135535 --- /dev/null +++ b/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusInitWorker.java @@ -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琛╮eset 鍒濆鍖�"); + 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(); + } +} diff --git a/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusViewModel.java b/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusViewModel.java new file mode 100644 index 0000000..9fca3fe --- /dev/null +++ b/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusViewModel.java @@ -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); + } +} diff --git a/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusWoker.java b/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusWoker.java new file mode 100644 index 0000000..8671173 --- /dev/null +++ b/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusWoker.java @@ -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(); + + } +} diff --git a/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusWorkRepo.java b/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusWorkRepo.java new file mode 100644 index 0000000..7cda4f1 --- /dev/null +++ b/app/src/main/java/safeluck/drive/evaluation/DB/exam_status/ExamStatusWorkRepo.java @@ -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; + } +} diff --git a/app/src/main/java/safeluck/drive/evaluation/MainActivity.java b/app/src/main/java/safeluck/drive/evaluation/MainActivity.java index 65d107d..cea004a 100644 --- a/app/src/main/java/safeluck/drive/evaluation/MainActivity.java +++ b/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(); + } + } + } }); diff --git a/app/src/main/java/safeluck/drive/evaluation/app.java b/app/src/main/java/safeluck/drive/evaluation/app.java index 4da6324..8b3129e 100644 --- a/app/src/main/java/safeluck/drive/evaluation/app.java +++ b/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 闇�瑕佹竻闄pp_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; } diff --git a/app/src/main/java/safeluck/drive/evaluation/customview/ArrowView.java b/app/src/main/java/safeluck/drive/evaluation/customview/ArrowView.java index 85e3cd7..dd8262e 100644 --- a/app/src/main/java/safeluck/drive/evaluation/customview/ArrowView.java +++ b/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(); + } } diff --git a/app/src/main/java/safeluck/drive/evaluation/customview/HouseView.java b/app/src/main/java/safeluck/drive/evaluation/customview/HouseView.java index 6fb30bd..f350d35 100644 --- a/app/src/main/java/safeluck/drive/evaluation/customview/HouseView.java +++ b/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(); + } } diff --git a/app/src/main/java/safeluck/drive/evaluation/fragment/NetWorkTrainFragment.java b/app/src/main/java/safeluck/drive/evaluation/fragment/NetWorkTrainFragment.java index 6b2620d..1b59726 100644 --- a/app/src/main/java/safeluck/drive/evaluation/fragment/NetWorkTrainFragment.java +++ b/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;//鎵e垎鍒嗘暟鎬诲拰 + 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,"涓诲姩鎺ㄩ�丷TKConfig"); -// 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; diff --git a/app/src/main/java/safeluck/drive/evaluation/fragment/TcpFragment.java b/app/src/main/java/safeluck/drive/evaluation/fragment/TcpFragment.java index 296e567..9fd9d18 100644 --- a/app/src/main/java/safeluck/drive/evaluation/fragment/TcpFragment.java +++ b/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; diff --git a/app/src/main/res/layout/layout_net_train_item.xml b/app/src/main/res/layout/layout_net_train_item.xml index 867b2ed..41c2f8a 100644 --- a/app/src/main/res/layout/layout_net_train_item.xml +++ b/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> \ No newline at end of file diff --git a/app/src/main/res/values/attrs.xml b/app/src/main/res/values/attrs.xml index a2b1087..61e42b8 100644 --- a/app/src/main/res/values/attrs.xml +++ b/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> \ No newline at end of file diff --git a/app/src/main/res/values/colors.xml b/app/src/main/res/values/colors.xml index f65ffa3..9882094 100644 --- a/app/src/main/res/values/colors.xml +++ b/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> -- Gitblit v1.8.0