From 844af51bfcd8c4dadd1782a7fb7df3f2274807ac Mon Sep 17 00:00:00 2001 From: endian11 <Dana_Lee1016@126.com> Date: 星期一, 26 十月 2020 16:39:10 +0800 Subject: [PATCH] 完成所有设置数据从本地json文件的获取, --- app/src/main/java/safeluck/drive/evaluation/fragment/rulefragments/FragmentSetting2.java | 84 ++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 84 insertions(+), 0 deletions(-) diff --git a/app/src/main/java/safeluck/drive/evaluation/fragment/rulefragments/FragmentSetting2.java b/app/src/main/java/safeluck/drive/evaluation/fragment/rulefragments/FragmentSetting2.java index dbb2d91..e8d69a6 100644 --- a/app/src/main/java/safeluck/drive/evaluation/fragment/rulefragments/FragmentSetting2.java +++ b/app/src/main/java/safeluck/drive/evaluation/fragment/rulefragments/FragmentSetting2.java @@ -5,11 +5,18 @@ import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; +import android.widget.Toast; import androidx.annotation.Nullable; +import androidx.lifecycle.Observer; +import androidx.lifecycle.ViewModelProviders; import me.yokeyword.fragmentation.SupportFragment; import safeluck.drive.evaluation.R; +import safeluck.drive.evaluation.bean.CommonSetting; +import safeluck.drive.evaluation.fragment.rulefragments.cview.TextEditText; +import safeluck.drive.evaluation.util.Utils; +import safeluck.drive.evaluation.viewmodels.CommonSettingViewModel; /** * DriveJudge @@ -21,6 +28,15 @@ private static final String ARG_NUMBER = "arg_number"; private static final String TAG = FragmentSetting2.class.getSimpleName(); + private CommonSetting mCommonSetting; + private CommonSettingViewModel commonSettingViewModel; + + private TextEditText te_road_pause_time; + private TextEditText te_crash_dotted_line_time; + private TextEditText te_slide_yellow_distance; + private TextEditText te_slide_red_distance; + private TextEditText te_lane_min_time; + private TextEditText te_change_lane_dis; private int mNumber; @@ -47,12 +63,80 @@ public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { View view = inflater.inflate(R.layout.layout_common_judge_1, container, false); initView(view); + commonSettingViewModel = ViewModelProviders.of(this).get(CommonSettingViewModel.class); + commonSettingViewModel.getCommonSetting().observe(this, new Observer<CommonSetting>() { + @Override + public void onChanged(CommonSetting commonSetting) { + if (commonSetting != null){ + mCommonSetting = commonSetting; + setDatas(); + } + } + }); return view; } + private void setDatas() { + if (mCommonSetting != null){ + te_change_lane_dis.setInput(String.valueOf(mCommonSetting.getChange_lane_limit_distance())); + te_crash_dotted_line_time.setInput(String.valueOf(mCommonSetting.getCrash_dotted_line_cumulative_time())); + te_lane_min_time.setInput(String.valueOf(mCommonSetting.getContinuous_change_lane_min_time())); + te_road_pause_time.setInput(String.valueOf(mCommonSetting.getRoad_pause_criteria())); + te_slide_red_distance.setInput(String.valueOf(mCommonSetting.getRoad_slide_red_distance())); + te_slide_yellow_distance.setInput(String.valueOf(mCommonSetting.getRoad_slide_yellow_distance())); + } + } + private void initView(View view) { + te_change_lane_dis = view.findViewById(R.id.road_change_lane_dist); + te_crash_dotted_line_time = view.findViewById(R.id.road_crash_dotted_line_time); + te_lane_min_time = view.findViewById(R.id.road_lane_min_time); + te_road_pause_time = view.findViewById(R.id.road_pause_time); + te_slide_red_distance = view.findViewById(R.id.road_slide_red_distance); + te_slide_yellow_distance = view.findViewById(R.id.road_slide_yellow_distance); + + view.findViewById(R.id.btn_setting_save).setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + String change_lane_dis_str = te_change_lane_dis.getInput(); + String crash_dotted_line_time_str = te_crash_dotted_line_time.getInput(); + String lane_min_time_str = te_lane_min_time.getInput(); + String road_pause_time_str = te_road_pause_time.getInput(); + String slide_red_distance_str = te_slide_red_distance.getInput(); + String slide_yellow_distance_str = te_slide_yellow_distance.getInput(); + + if (mCommonSetting != null){ + + if (Utils.isDigital(change_lane_dis_str)){ + + mCommonSetting.setChange_lane_limit_distance(Integer.parseInt(change_lane_dis_str)); + } + if (Utils.isDigital(crash_dotted_line_time_str)){ + mCommonSetting.setCrash_dotted_line_cumulative_time(Integer.parseInt(crash_dotted_line_time_str)); + } + if (Utils.isDigital(lane_min_time_str)){ + mCommonSetting.setContinuous_change_lane_min_time(Integer.parseInt(lane_min_time_str)); + } + if (Utils.isDigital(road_pause_time_str)){ + + mCommonSetting.setRoad_pause_criteria(Integer.parseInt(road_pause_time_str)); + } + if (Utils.isNumber(slide_red_distance_str)){ + mCommonSetting.setRoad_slide_red_distance(Double.parseDouble(slide_red_distance_str)); + } + if (Utils.isNumber(slide_yellow_distance_str)){ + mCommonSetting.setRoad_slide_yellow_distance(Double.parseDouble(slide_yellow_distance_str)); + } + + + + commonSettingViewModel.saveCommonSetting(mCommonSetting); + Toast.makeText(_mActivity, "閫氱敤璁剧疆鎴愬姛", Toast.LENGTH_SHORT).show(); + } + } + }); } } -- Gitblit v1.8.0