From 8e9d0834e4f5328efca969156af81a41fa99dce9 Mon Sep 17 00:00:00 2001
From: haijiang <181069201@qq.com>
Date: Fri, 20 Apr 2018 16:14:14 +0800
Subject: [PATCH] 提交

---
 app/src/main/java/com/moral/yunfushao/fragment/FragmentMonitor.java |  473 ++++++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 375 insertions(+), 98 deletions(-)

diff --git a/app/src/main/java/com/moral/yunfushao/fragment/FragmentMonitor.java b/app/src/main/java/com/moral/yunfushao/fragment/FragmentMonitor.java
index 6f1b46a..7df91fd 100644
--- a/app/src/main/java/com/moral/yunfushao/fragment/FragmentMonitor.java
+++ b/app/src/main/java/com/moral/yunfushao/fragment/FragmentMonitor.java
@@ -1,5 +1,6 @@
 package com.moral.yunfushao.fragment;
 
+import android.annotation.SuppressLint;
 import android.bluetooth.BluetoothGatt;
 import android.bluetooth.BluetoothGattCharacteristic;
 import android.bluetooth.BluetoothGattService;
@@ -7,9 +8,11 @@
 import android.content.Intent;
 import android.content.res.AssetManager;
 import android.media.MediaPlayer;
+import android.net.Uri;
 import android.os.Bundle;
 import android.os.Handler;
 import android.os.Message;
+import android.support.annotation.NonNull;
 import android.support.annotation.Nullable;
 import android.text.TextUtils;
 import android.util.Log;
@@ -18,6 +21,8 @@
 import android.widget.LinearLayout;
 import android.widget.TextView;
 
+import com.afollestad.materialdialogs.DialogAction;
+import com.afollestad.materialdialogs.MaterialDialog;
 import com.clj.fastble.conn.BleCharacterCallback;
 import com.clj.fastble.exception.BleException;
 import com.lzy.okgo.cache.CacheMode;
@@ -25,12 +30,14 @@
 import com.moral.andbrickslib.utils.NumberUtils;
 import com.moral.andbrickslib.utils.StringUtils;
 import com.moral.andbrickslib.utils.TimeUtil;
+import com.moral.andbrickslib.utils.dialog.MaterialDialogUtils;
 import com.moral.andbrickslib.utils.log.XLog;
 import com.moral.yunfushao.MainActivity;
 import com.moral.yunfushao.MainApp;
 import com.moral.yunfushao.R;
 import com.moral.yunfushao.activity.BLESearchActivity;
 import com.moral.yunfushao.activity.ChartActivity;
+import com.moral.yunfushao.activity.VoiceSetActivity;
 import com.moral.yunfushao.base.BaseFragment;
 import com.moral.yunfushao.ble.BLECommon;
 import com.moral.yunfushao.ble.BluetoothService;
@@ -38,6 +45,7 @@
 import com.moral.yunfushao.common.AppConfig;
 import com.moral.yunfushao.httputils.HttpCallBack;
 import com.moral.yunfushao.httputils.HttpUtils;
+import com.moral.yunfushao.imageload.ImageLoader;
 import com.moral.yunfushao.model.EventMessage;
 import com.moral.yunfushao.model.RecData;
 import com.moral.yunfushao.model.UpLoadParam;
@@ -48,6 +56,7 @@
 import org.greenrobot.eventbus.Subscribe;
 import org.greenrobot.eventbus.ThreadMode;
 
+import java.io.IOException;
 import java.util.ArrayList;
 import java.util.Calendar;
 import java.util.HashMap;
@@ -70,15 +79,17 @@
     private LinearLayout ll_status;
     private TextView tv_ljjl, tv_tishi, tv_desc, tv_shishi, tv_status;
     private PanelView pv;
-    private ImageView iv_his, iv_status, iv_search;
+    private ImageView iv_his, iv_status, iv_search, iv_bottom_status, iv_dianliang;
     private BluetoothService mBluetoothService;
     private ArrayList<String> realResult = new ArrayList<>();
+    private ArrayList<String> realHourResult = new ArrayList<>();
+    private ArrayList<String> realHisResult = new ArrayList<>();
     //������������
     private ArrayList<RecData> submitResult = new ArrayList<>();
     private ArrayList<RecData> submitHisResult = new ArrayList<>();
     //������������������������
     private ArrayList<RecData> submitTempResult = new ArrayList<>();
-    private Timer heartTimer, resTimer;
+    private Timer heartTimer, resTimer, chonglianTimer;
     Handler handler = new Handler();
 
     /**
@@ -89,9 +100,14 @@
     @Subscribe(threadMode = ThreadMode.MAIN, sticky = true)
     public void eventComing(EventMessage msg) {
         if (msg.getType() == AppConfig.GET_BLE_SERVICE) {
+            if (chonglianTimer != null) {
+                chonglianTimer.cancel();
+                chonglianTimer = null;
+            }
             pv.setStatusStr("���������");
             //������������
             mBluetoothService = ((MainActivity) getActivity()).getBluetoothService();
+            ((MainActivity) getActivity()).resetBLECallBack();
             if (mBluetoothService != null) {
                 BluetoothGatt gatt = mBluetoothService.getGatt();
                 if (gatt != null) {
@@ -130,11 +146,12 @@
                                 getActivity().runOnUiThread(new Runnable() {
                                     @Override
                                     public void run() {
-                                        Log.d("haijiang", "������������====" + StringUtils.byteArrayToHexStr(characteristic.getValue()));
+//                                        Log.d("haijiang", "������������====" + StringUtils.byteArrayToHexStr(characteristic.getValue()));
                                         String result = StringUtils.byteArrayToHexStr(characteristic.getValue());
                                         //������������
                                         parseCurrentData(result);
                                         parseHisData(result);
+                                        parseHoutData(result);
                                     }
                                 });
                             }
@@ -172,10 +189,13 @@
                 heart();
             }
         } else if (msg.getType() == AppConfig.GET_BLE_DISCONNECT) {
+            showStatus(-1);
             pv.setStatusStr("���������");
             pv.setPercent(0);
             tv_ljjl.setText("0");
             tv_shishi.setText("0");
+            chonglian();
+            stop();
         } else if (msg.getType() == AppConfig.CHANGE_SETTING) {
             if (timer != null) {
                 timer.cancel();
@@ -184,6 +204,8 @@
             submitTime = MainApp.theApp.sharedPreferencesUtil.getLoginInfo().getRefresh_frequency();
             isupLoad = MainApp.theApp.sharedPreferencesUtil.getLoginInfo().getIs_open_upload();
             doTask();
+        }else if(msg.getType()==AppConfig.SET_MAIN_CALL){
+            ((MainActivity) getActivity()).resetBLECallBack();
         }
     }
 
@@ -191,22 +213,35 @@
     public void onCreate(@Nullable Bundle savedInstanceState) {
         super.onCreate(savedInstanceState);
         EventBus.getDefault().register(this);
-        VoiceBean voiceBean = new VoiceBean();
-        voiceBean.setId(0);
-        voiceBean.setRes(R.raw.music);
-        voiceBean.setName("music");
-        voiceList.add(voiceBean);
-        voiceBean = new VoiceBean();
-        voiceBean.setId(1);
-        voiceBean.setRes(R.raw.music1);
-        voiceBean.setName("music1");
-        voiceList.add(voiceBean);
+        ArrayList<VoiceBean> temp = (ArrayList<VoiceBean>) FastJsonTools.getArrayJson(MainApp.theApp.sharedPreferencesUtil.getVideoList(), VoiceBean.class);
+        if (temp != null) {
+            voiceList.clear();
+            voiceList.addAll(temp);
+        } else {
+            voiceList.clear();
+            VoiceBean voiceBean = new VoiceBean();
+            voiceBean.setId(0);
+            voiceBean.setRes(VoiceSetActivity.voideUrl1);
+            voiceBean.setName("������������");
+            voiceList.add(voiceBean);
+            voiceBean = new VoiceBean();
+            voiceBean.setId(1);
+            voiceBean.setRes(VoiceSetActivity.voideUrl2);
+            voiceBean.setName("������������");
+            voiceList.add(voiceBean);
+            voiceBean = new VoiceBean();
+            voiceBean.setId(2);
+            voiceBean.setRes(VoiceSetActivity.voideUrl3);
+            voiceBean.setName("������������");
+            voiceList.add(voiceBean);
+        }
 
     }
 
     @Override
     public void onAttach(Context context) {
         super.onAttach(context);
+        FragmentMonitor.this.mBluetoothService = ((MainActivity) getActivity()).getBluetoothService();
     }
 
     @Override
@@ -220,6 +255,10 @@
         if (timer != null) {
             timer.cancel();
             timer = null;
+        }
+        if (chonglianTimer != null) {
+            chonglianTimer.cancel();
+            chonglianTimer = null;
         }
         stop();
     }
@@ -241,13 +280,16 @@
         iv_status = findView(R.id.iv_status);
         ll_status = findView(R.id.ll_status);
         iv_search = findView(R.id.iv_search);
+        iv_bottom_status = findView(R.id.iv_bottom_status);
+        iv_dianliang = findView(R.id.iv_dianliang);
+        showStatus(-1);
     }
 
     @Override
     protected void initListener() {
         pv.setOnClickListener(this);
         iv_his.setOnClickListener(this);
-//        iv_search.setOnClickListener(this);
+        iv_search.setOnClickListener(this);
     }
 
     int submitTime;
@@ -258,6 +300,38 @@
         submitTime = MainApp.theApp.sharedPreferencesUtil.getLoginInfo().getRefresh_frequency();
         isupLoad = MainApp.theApp.sharedPreferencesUtil.getLoginInfo().getIs_open_upload();
         doTask();
+    }
+
+    private MaterialDialog clearDialog;
+    private  void showClear(){
+        clearDialog = MaterialDialogUtils.showCallBaclDialog(getActivity(), "������������", "���������������������������������?", new MaterialDialog.SingleButtonCallback() {
+            @Override
+            public void onClick(@NonNull MaterialDialog dialog, @NonNull DialogAction which) {
+                if (MainApp.theApp.bleManager == null) {
+                    return;
+                }
+                if (!MainApp.theApp.bleManager.isConnectingOrConnected()) {
+                    return;
+                }
+                if(mBluetoothService==null){
+                    return;
+                }
+                if(mBluetoothService.getWirteCharacteristic()==null){
+                    return;
+                }
+                if(mBluetoothService.getWirteCharacteristic().getService()==null){
+                    return;
+                }
+                mBluetoothService.write(mBluetoothService.getWirteCharacteristic().getService().getUuid().toString(),mBluetoothService.getWirteCharacteristic().getUuid().toString(),BLECommon.BLE_CLEAR,null);
+                clearDialog.dismiss();
+            }
+        }, new MaterialDialog.SingleButtonCallback() {
+            @Override
+            public void onClick(@NonNull MaterialDialog dialog, @NonNull DialogAction which) {
+                clearDialog.dismiss();
+            }
+        });
+        clearDialog.show();
     }
 
     @Override
@@ -276,13 +350,7 @@
                 startActivity(intent);
                 break;
             case R.id.iv_search:
-//                if(mBluetoothService==null){
-//                    return;
-//                }
-//                if(mBluetoothService.getWirteCharacteristic()==null){
-//                    return;
-//                }
-//                mBluetoothService.write(mBluetoothService.getWirteCharacteristic().getService().getUuid().toString(),mBluetoothService.getWirteCharacteristic().getUuid().toString(),BLECommon.BLE_SEARCH,null);
+               showClear();
                 break;
         }
 
@@ -311,53 +379,97 @@
     /**
      * ���������������������3������
      */
-    Handler heartHandler = new Handler(){
+    @SuppressLint("HandlerLeak")
+    Handler heartHandler = new Handler() {
         public void handleMessage(Message msg) {
             switch (msg.what) {
                 case 1:
+                    if (MainApp.theApp.bleManager == null) {
+                        return;
+                    }
+                    if (!MainApp.theApp.bleManager.isConnectingOrConnected()) {
+                        return;
+                    }
                     //������������
-                    if (mBluetoothService == null) {
+                    if (FragmentMonitor.this.mBluetoothService == null) {
                         return;
                     }
-                    if (mBluetoothService.getWirteCharacteristic() == null) {
+                    if (FragmentMonitor.this.mBluetoothService.getWirteCharacteristic() == null) {
                         return;
                     }
-                    mBluetoothService.write(mBluetoothService.getWirteCharacteristic().getService().getUuid().toString(), mBluetoothService.getWirteCharacteristic().getUuid().toString(), BLECommon.BLE_HEART, null);
+                    if (FragmentMonitor.this.mBluetoothService.getWirteCharacteristic().getService() == null) {
+                        return;
+                    }
+                    FragmentMonitor.this.mBluetoothService.write(FragmentMonitor.this.mBluetoothService.getWirteCharacteristic().getService().getUuid().toString(), FragmentMonitor.this.mBluetoothService.getWirteCharacteristic().getUuid().toString(), BLECommon.BLE_HEART, null);
+                    Log.d("xintiao", "������������");
+                    break;
+                case 2:
+                    //������
+                    if (FragmentMonitor.this.mBluetoothService == null) {
+                        return;
+                    }
+                    String mac = MainApp.theApp.sharedPreferencesUtil.getBLE();
+                    if (!TextUtils.isEmpty(mac) && MainApp.theApp.bleManager.isBlueEnable()) {
+                        if (MainApp.theApp.bleManager.isConnectingOrConnected()) {
+                            return;
+                        }
+                        Log.d("chonglian", "������������");
+                        FragmentMonitor.this.mBluetoothService.scanAndConnect5(mac);
+                    }
                     break;
             }
             super.handleMessage(msg);
         }
 
     };
+
     private void heart() {
-        heartTimer = new Timer();
-        heartTimer.schedule(new TimerTask() {
-            @Override
-            public void run() {
-                Message message = new Message();
-                message.what = 1;
-                heartHandler.sendMessage(message);
-            }
-        }, 0, 1000 * 60*3);
+        if (heartTimer == null) {
+            heartTimer = new Timer();
+            heartTimer.schedule(new TimerTask() {
+                @Override
+                public void run() {
+                    Message message = new Message();
+                    message.what = 1;
+                    heartHandler.sendMessage(message);
+                }
+            }, 0, 1000 * 10);
+        }
+    }
+
+    private void chonglian() {
+        if (chonglianTimer == null) {
+            chonglianTimer = new Timer();
+            chonglianTimer.schedule(new TimerTask() {
+                @Override
+                public void run() {
+                    Message message = new Message();
+                    message.what = 2;
+                    heartHandler.sendMessage(message);
+                }
+            }, 0, 1000 * 8);
+        }
     }
 
     private long timeComplete = 0;
 
     private void checkResComplete(final String result) {
-        resTimer = new Timer();
-        resTimer.schedule(new TimerTask() {
-            @Override
-            public void run() {
-                if (!TextUtils.isEmpty(result) && result.startsWith("3A")) {
-                    timeComplete = 0;
-                } else {
-                    timeComplete++;
+        if (resTimer == null) {
+            resTimer = new Timer();
+            resTimer.schedule(new TimerTask() {
+                @Override
+                public void run() {
+                    if (!TextUtils.isEmpty(result) && result.startsWith("3A")) {
+                        timeComplete = 0;
+                    } else {
+                        timeComplete++;
+                    }
+                    if (timeComplete >= 120) {
+                        submitResData();
+                    }
                 }
-                if (timeComplete >= 120) {
-                    submitResData();
-                }
-            }
-        }, 0, 1000);
+            }, 0, 1000);
+        }
     }
 
     private void submitData() {
@@ -375,6 +487,7 @@
         up.setLon(MainApp.mLon);
         up.setData(submitTempResult);
         params.put("data", FastJsonTools.toJson(up));
+//        Log.d("haijiang","###################" + FastJsonTools.toJson(up));
         HttpUtils.doPost(API.UPLOAD, params, CacheMode.DEFAULT, false, new HttpCallBack() {
             @Override
             public void onSuccess(String res, String msg) {
@@ -435,19 +548,54 @@
     /**
      * ������������������������������
      *
-     * @param safe
+     * @param level
      */
-    private void showStatus(boolean safe) {
-        if (safe) {
+    private void showStatus(int level) {
+        if (level == 0) {
+            tv_tishi.setText("������������������");
+            tv_tishi.setBackgroundResource(R.mipmap.bt_green);
+            iv_bottom_status.setImageResource(R.mipmap.icon_good);
+            tv_desc.setText("���������������������������\n���������������������������������������������");
             iv_status.setImageResource(R.mipmap.icon_safe);
             tv_status.setText("������");
             tv_status.setTextColor(getResources().getColor(R.color.green_txt));
             ll_status.setBackgroundResource(R.mipmap.bg_conner_green);
-        } else {
+        } else if (level == 1) {
+            tv_tishi.setText("������������������");
+            tv_tishi.setBackgroundResource(R.mipmap.bt_blue);
+            iv_bottom_status.setImageResource(R.mipmap.icon_qingwei);
+            tv_desc.setText("���������������������������\n���������������������������������������");
+            iv_status.setImageResource(R.mipmap.icon_head_qingwei);
+            tv_status.setText("������");
+            tv_status.setTextColor(getResources().getColor(R.color.blue_txt));
+            ll_status.setBackgroundResource(R.mipmap.bg_corner_blue);
+        } else if (level == 2) {
+            tv_tishi.setText("������������������");
+            tv_tishi.setBackgroundResource(R.mipmap.bt_zise);
+            iv_bottom_status.setImageResource(R.mipmap.icon_zhongdu);
+            tv_desc.setText("���������������������������\n������������������������������������������");
+            iv_status.setImageResource(R.mipmap.icon_head_zhongfu);
+            tv_status.setText("������");
+            tv_status.setTextColor(getResources().getColor(R.color.zi_txt));
+            ll_status.setBackgroundResource(R.mipmap.bg_corner_zise);
+        } else if (level == 3) {
+            tv_tishi.setText("������������������");
+            tv_tishi.setBackgroundResource(R.mipmap.bt_red);
+            iv_bottom_status.setImageResource(R.mipmap.icon_yanzhong);
+            tv_desc.setText("���������������������������\n������������������������������������������");
             iv_status.setImageResource(R.mipmap.icon_danger);
-            tv_status.setText("������");
+            tv_status.setText("������");
             tv_status.setTextColor(getResources().getColor(R.color.red_txt));
             ll_status.setBackgroundResource(R.mipmap.bg_conner_red);
+        } else if (level == -1) {
+            tv_tishi.setText("������������������");
+            tv_tishi.setBackgroundResource(R.mipmap.bt_offline);
+            iv_bottom_status.setImageResource(R.mipmap.icon_offline);
+            tv_desc.setText("���������������������\n������������������������");
+            iv_status.setImageResource(R.mipmap.icon_head_offline);
+            tv_status.setText("������");
+            tv_status.setTextColor(getResources().getColor(R.color.gray_txt));
+            ll_status.setBackgroundResource(R.mipmap.bg_corner_gray);
         }
     }
 
@@ -467,17 +615,18 @@
         for (String s : realResult) {
             nowResult += s;
         }
-        Log.d("haijiang", "������������===nowResult=" + nowResult);
+//        Log.d("haijiang", "������������===nowResult=" + nowResult);
         /**
          * 20������������5A������  5B������
          */
         if (!TextUtils.isEmpty(nowResult) && nowResult.length() == 40 && nowResult.startsWith("5A") && nowResult.endsWith("5B")) {
-
             int shunshiValue = Integer.parseInt(nowResult.substring(24, 26), 16) * 256 + Integer.parseInt(nowResult.substring(26, 28), 16);
             int leijiValue = Integer.parseInt(nowResult.substring(28, 30), 16) * 1024 + Integer.parseInt(nowResult.substring(30, 32), 16) * 512 + Integer.parseInt(nowResult.substring(32, 34), 16) * 256 + Integer.parseInt(nowResult.substring(34, 36), 16);
-            float level = (float) (shunshiValue / 10 * 0.01);
-            XLog.d("���������" + shunshiValue + "|���������" + leijiValue);
-            tv_ljjl.setText(NumberUtils.getBigDecimalValue(leijiValue * 0.01, 3) + "");
+//            float level = (float) (shunshiValue / 10 * 0.01);
+            int b1 = Integer.parseInt(nowResult.substring(6, 8), 16);
+            int b2 = Integer.parseInt(nowResult.substring(12, 14), 16);
+//            XLog.d("���������" + shunshiValue + "|���������" + leijiValue + "-----���������" + b1 + "|" + b2);
+            tv_ljjl.setText(NumberUtils.getBigDecimalValue(leijiValue * 0.001, 3) + "");
             double shishiValue = NumberUtils.getBigDecimalValue((shunshiValue) / 100.0, 3);
             tv_shishi.setText(shishiValue + "");
 
@@ -487,38 +636,88 @@
             RecData data = new RecData();
             data.setValue(shishiValue);
             data.setTime(TimeUtil.getCurrentDate("yyyy-MM-dd HH:mm:ss"));
-            submitResult.add(data);
+            data.setType(0);
 
-            if (shishiValue<0.25) {
-                pv.setPercent((float) (shishiValue / 2.0));
-                tv_tishi.setText("������������������");
-                tv_desc.setText("���������������������������\n���������������������������������������������");
-                showStatus(true);
-                stop();
-            } else if (shishiValue >= 0.25 && shishiValue < 0.8) {
-                pv.setPercent((float) (shishiValue / 2.0));
-                tv_tishi.setText("������������������");
-                tv_desc.setText("���������������������������\n���������������������������������������������������");
-                showStatus(true);
-                play();
-            } else if (shishiValue >=0.8 && shishiValue < 2) {
-                showStatus(false);
-                tv_tishi.setText("������������������");
-                tv_desc.setText("���������������������������\n���������������������������������������������������");
-                if(shishiValue>1.8){
-                    pv.setPercent(0.9f);
-                }else{
-                    pv.setPercent((float) (shishiValue / 2.0));
+
+            /**
+             * ������������
+             */
+            if (b1 == 1) {
+                ImageLoader.setGIFByUrl(getActivity(), R.mipmap.icon_chong, iv_dianliang);
+            } else if (b1 == 2) {
+                ImageLoader.setImageViewById(getActivity(), R.mipmap.icon_full, iv_dianliang);
+            } else {
+                if (b2 == 0) {
+                    ImageLoader.setImageViewById(getActivity(), R.mipmap.icon_b00, iv_dianliang);
+                } else if (b2 == 1) {
+                    ImageLoader.setImageViewById(getActivity(), R.mipmap.icon_b01, iv_dianliang);
+                } else if (b2 == 2) {
+                    ImageLoader.setImageViewById(getActivity(), R.mipmap.icon_b02, iv_dianliang);
+                } else if (b2 == 3) {
+                    ImageLoader.setImageViewById(getActivity(), R.mipmap.icon_b03, iv_dianliang);
+                } else if (b2 == 4) {
+                    ImageLoader.setImageViewById(getActivity(), R.mipmap.icon_b04, iv_dianliang);
                 }
-                play();
-            } else if (shishiValue >= 2) {
-                showStatus(false);
-                tv_tishi.setText("������������������");
-                tv_desc.setText("���������������������������\n���������������������������������������������������");
-                pv.setPercent(1.0f);
-                play();
             }
+
+            if (shishiValue < 0.16) {
+                data.setIs_warn(0);
+                pv.setPercent((float) (shishiValue * (0.25 / 0.16)));
+                showStatus(0);
+                stop();
+            } else if (shishiValue >= 0.16 && shishiValue < 0.8) {
+                data.setIs_warn(1);
+                pv.setPercent((float) (0.25 + shishiValue * (0.25 / 0.8)));
+                showStatus(1);
+                play(0);
+            } else if (shishiValue >= 0.8 && shishiValue < 2) {
+                data.setIs_warn(1);
+                showStatus(2);
+                pv.setPercent((float) (0.5 + shishiValue * (0.25 / 2)));
+                play(1);
+            } else if (shishiValue >= 2) {
+                data.setIs_warn(1);
+                showStatus(3);
+                if ((0.75 + shishiValue / 30) < 1.0) {
+                    pv.setPercent((float) (0.75 + shishiValue / 30));
+                } else {
+                    pv.setPercent(1.0f);
+                }
+                play(2);
+            }
+            submitResult.add(data);
             realResult.clear();
+        }
+    }
+
+    /**
+     * ������������������
+     *
+     * @param result
+     */
+    private void parseHoutData(String result) {
+        if (result.startsWith("7A")) {
+            realHourResult.clear();
+            realHourResult.add(result);
+        } else {
+            realHourResult.add(result);
+        }
+        String nowResult = "";
+        for (String s : realHourResult) {
+            nowResult += s;
+        }
+        if (!TextUtils.isEmpty(nowResult)&& nowResult.length() == 8&&nowResult.startsWith("7A") && nowResult.endsWith("7B")) {
+            int hourValue = Integer.parseInt(nowResult.substring(2, 4), 16) * 256 + Integer.parseInt(nowResult.substring(4, 6), 16);
+            Log.d("haijiang", "������������������������="+ nowResult+"���������"+nowResult.substring(2, 4)+"|"+Integer.parseInt(nowResult.substring(2, 4), 16) * 256+"���������"+nowResult.substring(4, 6)+"|"+Integer.parseInt(nowResult.substring(4, 6), 16) +"���������"+(hourValue/100.0));
+            sendHourDataRec();
+            RecData data = new RecData();
+            data.setType(1);
+            data.setIs_warn(0);
+            data.setTime(TimeUtil.getCurrentDate("yyyy-MM-dd HH:mm:ss"));
+            data.setValue(hourValue / 100.0);
+            ArrayList<RecData> temp = new ArrayList<>();
+            temp.add(data);
+            submitHourData(temp);
         }
     }
 
@@ -526,16 +725,26 @@
      * ���������������������������������
      */
     private void parseHisData(String result) {
-        if (!TextUtils.isEmpty(result) && result.length() == 16 && result.startsWith("3A") && result.endsWith("3B")) {
+        if (result.startsWith("3A")) {
+            realHisResult.clear();
+            realHisResult.add(result);
+        } else {
+            realHisResult.add(result);
+        }
+        String nowResult = "";
+        for (String s : realHisResult) {
+            nowResult += s;
+        }
+        if (!TextUtils.isEmpty(nowResult) && nowResult.length() == 16 && nowResult.startsWith("3A") && nowResult.endsWith("3B")) {
             if (submitHisResult.size() == 0) {
                 //���������������������
                 checkResComplete(result);
             }
-            String year = "20" + Integer.parseInt(result.substring(2, 4), 16);
-            String month = Integer.parseInt(result.substring(4, 6), 16) + "";
-            String day = Integer.parseInt(result.substring(6, 8), 16) + "";
-            String hour = Integer.parseInt(result.substring(8, 10), 16) + "";
-            int resValue = Integer.parseInt(result.substring(10, 12), 16) * 256 + Integer.parseInt(result.substring(12, 14), 16);
+            String year = "20" + Integer.parseInt(nowResult.substring(2, 4), 16);
+            String month = Integer.parseInt(nowResult.substring(4, 6), 16) + "";
+            String day = Integer.parseInt(nowResult.substring(6, 8), 16) + "";
+            String hour = Integer.parseInt(nowResult.substring(8, 10), 16) + "";
+            int resValue = Integer.parseInt(nowResult.substring(10, 12), 16) * 256 + Integer.parseInt(nowResult.substring(12, 14), 16);
             RecData data = new RecData();
             StringBuilder time = new StringBuilder();
             //yyyy-MM-dd HH:mm:ss
@@ -577,20 +786,88 @@
         }
     }
 
-    public void play(){
-        if(mp!=null){
+    public void play(int level) {
+        if (mp != null) {
             stop();
         }
-        int index = MainApp.theApp.sharedPreferencesUtil.getLoginInfo().getVideo();
-        mp = MediaPlayer.create(getActivity(), voiceList.get(index).getRes());
-        mp.start();
+        VoiceBean voiceBean = voiceList.get(level);
+        if (voiceBean.isDefaultMusic()) {
+            mp = MediaPlayer.create(getActivity(), Uri.parse(voiceBean.getRes()));
+            mp.start();
+        } else {
+            mp = new MediaPlayer();
+            try {
+                mp.setDataSource(voiceBean.getSetMusic());
+                mp.prepare();
+                mp.start();
+            } catch (IOException e) {
+                e.printStackTrace();
+            }
+        }
     }
-    public void stop(){
-        if(mp!=null&&mp.isPlaying()){
+
+    public void stop() {
+        if (mp != null && mp.isPlaying()) {
             mp.stop();
             mp.release();
             mp = null;
         }
     }
 
+
+    private void submitHourData(ArrayList<RecData> hourdatas) {
+        //���������������������������
+        HashMap<String, String> params = new HashMap<>();
+        UpLoadParam up = new UpLoadParam();
+        up.setUserid(MainApp.userId);
+        up.setAddress(MainApp.address);
+        up.setLat(MainApp.mLat);
+        up.setLon(MainApp.mLon);
+        up.setData(hourdatas);
+        params.put("data", FastJsonTools.toJson(up));
+        HttpUtils.doPost(API.UPLOAD, params, CacheMode.DEFAULT, false, new HttpCallBack() {
+            @Override
+            public void onSuccess(String res, String msg) {
+                XLog.d("������������������������������" + msg);
+                if (resTimer != null) {
+                    resTimer.cancel();
+                    resTimer = null;
+                }
+            }
+
+            @Override
+            public void showLoadingDialog() {
+
+            }
+
+            @Override
+            public void onFail(int errno, String s) {
+
+            }
+        });
+    }
+
+    /**
+     * ������������������
+     */
+    private void  sendHourDataRec(){
+        if (MainApp.theApp.bleManager == null) {
+            return;
+        }
+        if (!MainApp.theApp.bleManager.isConnectingOrConnected()) {
+            return;
+        }
+        if (FragmentMonitor.this.mBluetoothService == null) {
+            return;
+        }
+        if (FragmentMonitor.this.mBluetoothService.getWirteCharacteristic() == null) {
+            return;
+        }
+        if (FragmentMonitor.this.mBluetoothService.getWirteCharacteristic().getService() == null) {
+            return;
+        }
+        FragmentMonitor.this.mBluetoothService.write(FragmentMonitor.this.mBluetoothService.getWirteCharacteristic().getService().getUuid().toString(), FragmentMonitor.this.mBluetoothService.getWirteCharacteristic().getUuid().toString(), BLECommon.BLE_HOUR_REC, null);
+    }
+
+
 }

--
Gitblit v1.8.0