From 3bd6e9023e011336da840e11a9d48bb31c7a0261 Mon Sep 17 00:00:00 2001
From: 陈奇 <1650699704@qq.com>
Date: Wed, 07 Nov 2018 09:31:59 +0800
Subject: [PATCH] [*]将电磁版本的唤醒心跳改成两秒,唤醒之后回到30一次心跳 [*]整体版本页面显示的绝对安全换成了安全 [*]自定义语音修改和优化,添加了无声的选择

---
 app/src/main/java/com/moral/yunfushao/fragment/FragmentMonitor.java |  242 +++++++++++++++++++++---------------------------
 1 files changed, 106 insertions(+), 136 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 e6c34c2..c4c4445 100644
--- a/app/src/main/java/com/moral/yunfushao/fragment/FragmentMonitor.java
+++ b/app/src/main/java/com/moral/yunfushao/fragment/FragmentMonitor.java
@@ -2,7 +2,6 @@
 
 import android.animation.Animator;
 import android.animation.ObjectAnimator;
-import android.annotation.SuppressLint;
 import android.bluetooth.BluetoothGatt;
 import android.bluetooth.BluetoothGattCharacteristic;
 import android.bluetooth.BluetoothGattService;
@@ -13,7 +12,6 @@
 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;
@@ -75,6 +73,7 @@
  */
 
 public class FragmentMonitor extends BaseFragment {
+    private String TGA = getClass().getSimpleName();
     /**
      * ������������
      */
@@ -96,39 +95,65 @@
 
     //������������������������
     private ArrayList<RecData> submitTempResult = new ArrayList<>();
-    private Timer heartTimer, resTimer, chonglianTimer;
 
+    //������������
+    private int HEARTTIMES = 2;
+    //������������
+    private int RECONNECTTIMES = 8000;
+    //handler������������
     private Handler handler = new Handler();
 
-    private Runnable runnable = new Runnable() {
+
+    private Runnable heartRunnable = new Runnable() {
         @Override
         public void run() {
-            checkTime();
-            checkTimeCount++;
-            handler.postDelayed(this, 5000);
+            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_HEART, null);
+            Log.d(TGA, "������������");
+            heart();
+        }
+    };
+    private Runnable reconnectRunnable = new Runnable() {
+        @Override
+        public void run() {
+            //������
+            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(TGA, "������������");
+                FragmentMonitor.this.mBluetoothService.scanAndConnect5(mac);
+            }
+            reconnect();
         }
     };
 
-    private int checkTimeCount = 0;
 
     private void doHandleData(String result) {
         if (StringUtils.isEmpty(result)) {
             return;
         }
-
-        //������������"������������������������������"���������5������������������������������������������
-        if (result.startsWith(BLECommon.BLE_REC_TIME) || checkTimeCount > 5) {
-            DebugUtils.sendData("data", result);
-
-            handler.removeCallbacks(runnable);
-            checkTimeCount = 0;
-
-            if (result.length() > 14) {
-                result = result.substring(14);
-                doHandleData(result);
-            }
-        }
-
         if (result.startsWith("3A")) {
             if (result.length() >= 16) {
                 DebugUtils.sendData("data", result);
@@ -171,12 +196,8 @@
      */
     @Subscribe(threadMode = ThreadMode.MAIN, sticky = true)
     public void eventComing(EventMessage msg) {
-        System.out.println("chenqi msge -> " + msg.getType());
         if (msg.getType() == AppConfig.GET_BLE_SERVICE) {
-            if (chonglianTimer != null) {
-                chonglianTimer.cancel();
-                chonglianTimer = null;
-            }
+            resetHandler();
             pv.setStatusStr("���������");
             //������������
             mBluetoothService = ((MainActivity) getActivity()).getBluetoothService();
@@ -203,7 +224,6 @@
                             mBluetoothService.setCharacteristic(characteristic);
                         }
                     }
-
                 }
 
                 /**
@@ -221,43 +241,30 @@
                                         String result = StringUtils.byteArrayToHexStr(characteristic.getValue());
                                         stringResult.append(result);
                                         doHandleData(result);
-
                                         stringResult = new StringBuilder();
                                     }
                                 });
+                                HEARTTIMES = 30;
                             }
 
                             @Override
                             public void onFailure(final BleException exception) {
-
                             }
 
                             @Override
                             public void onInitiatedResult(boolean result) {
-
                             }
                         });
                 /**
                  * ������������������
                  */
-                handler.postDelayed(runnable, 5000);
-
-                /**
-                 * ������������������������
-                 */
-                if (mBluetoothService == null) {
-                    return;
-                }
-                if (mBluetoothService.getWirteCharacteristic() == null) {
-                    return;
-                }
-                mBluetoothService.write(mBluetoothService.getWirteCharacteristic().getService().getUuid().toString(), mBluetoothService.getWirteCharacteristic().getUuid().toString(), BLECommon.BLE_HEART, null);
+//                handler.postDelayed(runnable, 5000);
                 heart();
             }
         } else if (msg.getType() == AppConfig.GET_BLE_DISCONNECT) {
             preLevel = -1;
             showStatus(-1);
-            chonglian();
+            handler.postDelayed(reconnectRunnable, RECONNECTTIMES);
             stop();
             isVirating = false;
             AudioUtils.virateCancle(getActivity());
@@ -336,21 +343,20 @@
     }
 
     @Override
+    public void onResume() {
+        super.onResume();
+        textShowMac();
+    }
+
+    @Override
     public void onDestroy() {
         super.onDestroy();
         EventBus.getDefault().unregister(this);
-        if (heartTimer != null) {
-            heartTimer.cancel();
-            heartTimer = null;
-        }
         if (timer != null) {
             timer.cancel();
             timer = null;
         }
-        if (chonglianTimer != null) {
-            chonglianTimer.cancel();
-            chonglianTimer = null;
-        }
+        handler.removeCallbacksAndMessages(null);
         stop();
         isVirating = false;
         AudioUtils.virateCancle(getActivity());
@@ -492,79 +498,18 @@
         }, 0, submitTime * 1000);
     }
 
-    /**
-     * ���������������������3������
-     */
-    @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 (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_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() {
-        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 * 30);
-        }
+        handler.postDelayed(heartRunnable, 1000 * HEARTTIMES);
     }
 
-    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 void reconnect() {
+        handler.postDelayed(reconnectRunnable, RECONNECTTIMES);
+    }
+
+    private void resetHandler() {
+        handler.removeCallbacks(reconnectRunnable);
+        handler.removeCallbacks(heartRunnable);
+        HEARTTIMES = 2;
     }
 
     private void submitData() {
@@ -608,6 +553,7 @@
     private void showStatus(int level) {
         int yanzhang = R.mipmap.icon_yanzhong;
         int danger = R.mipmap.icon_danger;
+        iv_dianliang.setVisibility(View.VISIBLE);
         if (type == 1) {
             //������
             yanzhang = R.mipmap.icon_yanzhong;
@@ -661,6 +607,7 @@
             tv_status.setTextColor(getResources().getColor(R.color.red_txt));
             ll_status.setBackgroundResource(R.mipmap.bg_conner_red);
         } else if (level == -1) {
+            iv_dianliang.setVisibility(View.GONE);
             tv_tishi.setText("������������������");
             tv_tishi.setBackgroundResource(R.mipmap.bt_offline);
             iv_bottom_status.setImageResource(R.mipmap.icon_offline);
@@ -682,9 +629,29 @@
             tv_status.setText("���������");
             ll_status.setBackgroundResource(R.mipmap.bg_corner_gray);
             pv.setPercent(0);
-            pv.setStatusStr("���������");
+            pv.setStatusStr("���������");
             tv_ljjl.setText("0");
             tv_shishi.setText("0");
+        }
+    }
+
+    private void textShowMac() {
+        if (BuildConfig.BUILD_TYPE.equals(VersionConstants.DEBUG)) {
+            final TextView tv_text_mac = (TextView) findView(R.id.tv_text_mac);
+            tv_desc.setOnClickListener(new View.OnClickListener() {
+                @Override
+                public void onClick(View v) {
+                    tv_text_mac.setText("Mac: " + MainApp.theApp.sharedPreferencesUtil.getBLE());
+                    FlipAnimatorXViewShow(tv_desc, tv_text_mac, 100L);
+                }
+            });
+
+            tv_text_mac.setOnClickListener(new View.OnClickListener() {
+                @Override
+                public void onClick(View v) {
+                    FlipAnimatorXViewShow(tv_text_mac, tv_desc, 100L);
+                }
+            });
         }
     }
 
@@ -776,13 +743,13 @@
         }
     }
 
+
     /**
      * 7A������������������
      * 7A0024010002D8B04CE90E6300000003000003EE0000000000000EC6000000000017347B0D0A
      * ������������������
      */
     private void parseHoutData(String nowResult) {
-        System.out.println("chenqi elec parseHoutData" + nowResult);
         if (TextUtils.isEmpty(nowResult)) {
             return;
         }
@@ -791,13 +758,11 @@
         if (strings[0].startsWith("7A") && strings[35].endsWith("7B")) {
             String realString = StringUtils.subStrings(strings, 21, 23);
             int electric_field = Integer.parseInt(realString, 16);
-            int b1 = Integer.parseInt(strings[24], 16);
-            int b2 = Integer.parseInt(strings[25], 16);
-            int baojing = Integer.parseInt(strings[29], 16);
-            int elec = Integer.parseInt(StringUtils.subStrings(strings, 13, 15));
-//            T.show("bl = " + strings[24] + " -- b2 = " + strings[25]);
-//
-//            System.out.println("bl = " + b1 + " -- b2 = " + b2);
+            int b1 = Integer.parseInt(strings[24].trim(), 16);
+            int b2 = Integer.parseInt(strings[25].trim(), 16);
+            int baojing = Integer.parseInt(strings[29].trim(), 16);
+
+            double elec = Integer.parseInt(StringUtils.subStrings(strings, 13, 15), 16);
 
             double electricFieldValue = (electric_field) / 100.0;
             double elecValue = (elec) / 100.0;
@@ -869,13 +834,11 @@
                     AudioUtils.vibrate(getActivity(), new long[]{1000, 1000, 1000, 1000}, 0);
                 }
             }
-            System.out.println("chenqi elec B-- " + b2);
             /**
              * ������������
              */
             showPower(b1, b2);
             submitResult.add(data);
-            //            realResult.clear();
         }
     }
 
@@ -985,6 +948,11 @@
         }
     }
 
+    /**
+     * ������������������
+     *
+     * @param level
+     */
     public void play(int level) {
         Log.d("music", "preLevel:" + preLevel + "----level:" + level);
         if (preLevel == level) {
@@ -996,9 +964,11 @@
         }
         VoiceBean voiceBean = voiceList.get(level);
         if (voiceBean.isDefaultMusic()) {
-            mp = MediaPlayer.create(getActivity(), Uri.parse(voiceBean.getRes()));
-            mp.start();
-            mp.setLooping(true);
+            if (voiceBean.getRes() != null) {
+                mp = MediaPlayer.create(getActivity(), Uri.parse(voiceBean.getRes()));
+                mp.start();
+                mp.setLooping(true);
+            }
         } else {
             mp = new MediaPlayer();
             try {

--
Gitblit v1.8.0