From 1c91b62ea573082581e72fd433d02e3dc52dbf51 Mon Sep 17 00:00:00 2001
From: wjc <1243177876@qq.com>
Date: 星期一, 05 一月 2026 11:03:29 +0800
Subject: [PATCH] 2026年01月05日11:00:26 升级gradle和uni库

---
 app/src/main/java/com/hdl/photovoltaic/ui/CPowerStationActivity.java |  196 ++++++++++++++++++++++++++++++++++++-------------
 1 files changed, 144 insertions(+), 52 deletions(-)

diff --git a/app/src/main/java/com/hdl/photovoltaic/ui/CPowerStationActivity.java b/app/src/main/java/com/hdl/photovoltaic/ui/CPowerStationActivity.java
index 609020f..5318b2f 100644
--- a/app/src/main/java/com/hdl/photovoltaic/ui/CPowerStationActivity.java
+++ b/app/src/main/java/com/hdl/photovoltaic/ui/CPowerStationActivity.java
@@ -6,11 +6,14 @@
 import android.content.Intent;
 import android.os.Build;
 import android.os.Bundle;
+import android.os.Handler;
 import android.os.Process;
 import android.os.SystemClock;
 import android.text.TextUtils;
+import android.util.Log;
 
 
+import com.alibaba.fastjson.JSONObject;
 import com.google.gson.Gson;
 import com.google.gson.JsonObject;
 import com.google.gson.reflect.TypeToken;
@@ -32,18 +35,22 @@
 import com.hdl.photovoltaic.other.HdlLogLogic;
 import com.hdl.photovoltaic.other.HdlMqttLogic;
 import com.hdl.photovoltaic.other.HdlOtaLogic;
+import com.hdl.photovoltaic.other.HdlPushLogic;
 import com.hdl.photovoltaic.other.HdlResidenceLogic;
 import com.hdl.photovoltaic.other.HdlThreadLogic;
 import com.hdl.photovoltaic.other.HdlUniLogic;
-import com.hdl.photovoltaic.services.ForeService;
+import com.hdl.photovoltaic.push.PushMessageInfoBean;
 import com.hdl.photovoltaic.ui.bean.DeviceRemoteInfo;
 import com.hdl.photovoltaic.ui.bean.HouseIdBean;
+import com.hdl.photovoltaic.ui.bean.MessageBean;
 import com.hdl.photovoltaic.ui.bean.OidBean;
+import com.hdl.photovoltaic.ui.message.MessageInfoActivity;
 import com.hdl.photovoltaic.ui.newC.PowerStationsListActivity;
 import com.hdl.photovoltaic.ui.newC.PowerStationsMoveActivity;
 import com.hdl.photovoltaic.uni.HDLUniMP;
 import com.hdl.photovoltaic.uni.HDLUniMPSDKManager;
 import com.hdl.photovoltaic.utils.AppManagerUtils;
+import com.hdl.photovoltaic.utils.BadgeUtils;
 import com.hdl.sdk.link.HDLLinkLocalSdk;
 import com.hdl.sdk.link.common.event.EventListener;
 import com.hdl.sdk.link.core.bean.LinkResponse;
@@ -59,8 +66,8 @@
 
 import java.lang.reflect.Type;
 import java.util.List;
+import java.util.Objects;
 
-import cn.jpush.android.api.JPushInterface;
 
 /**
  * C绔�-鐢电珯鐣岄潰
@@ -72,6 +79,8 @@
     private EventListener allTopicsListener;
     private int backPressTimes;
 
+    private volatile boolean isRunning = false;
+
     @Override
     public Object getContentView() {
         viewBinding = ActivityCpowerStationBinding.inflate(getLayoutInflater());
@@ -80,6 +89,10 @@
 
     @Override
     public void onBindView(Bundle savedInstanceState) {
+//        //閫氱煡鏍忕偣鍑昏繘鏉ワ紝闃叉搴旂敤鍦ㄥ悗鍙版椂琚噸澶嶅惎鍔�,闃块噷浜戞帹鍔ㄩ�氱煡鎸囧畾鎵撳紑鏌愪釜Activity锛屾病鏈夎缃瓼lags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TOP);榛樿鍚姩鏂板疄渚嬶紝瀵艰嚧澶氫釜瀹炰緥
+//        if (!isTaskRoot()) {
+//            finish();
+//        }
         setStatusBarTranslucent();
         getWindow().setNavigationBarColor(getColor(R.color.text_FF000000));
         //C绔惎鍔ˋpp鑷姩鎵撳紑灏忕▼搴忕數绔欒鎯呯晫闈�
@@ -88,8 +101,12 @@
         this.registerAllTopicsListener();
         //鍒濆鍖杕qtt瀹㈡埛绔�
         this.initMqttClient();
-        //涓婁紶鏋佸厜娉ㄥ唽ID鍒颁簯绔�
-        this.pushTokens();
+//        //涓婁紶鏋佸厜娉ㄥ唽ID鍒颁簯绔�
+//        this.pushTokens();
+        //涓婁紶鎺ㄥ姩浠ょ墝鍒颁簯绔紙璋锋瓕FCM鎺ㄩ�侊級
+        this.sendPushTokenToServer(UserConfigManage.getInstance().getPushToken());
+        //鐐瑰嚮閫氱煡鏍忔秷鎭繘鏉�
+        this.OpenSpecifiedPage(getIntent(), "onBindView");
         //鑾峰彇浜戠鑴氭湰
         HdlESLocalJsonLogic.getInstance().getAllHdlESLocalJson();
 //        mForegroundService= new Intent(this, ForeService.class);
@@ -115,6 +132,45 @@
 //        this.portConflictDialog();
     }
 
+    @Override
+    protected void onNewIntent(Intent intent) {
+        super.onNewIntent(intent);
+        //AndroidManifest.xml 闇�瑕佹坊鍔犲惎鍔ㄦā寮廰ndroid:launchMode="singleTask"鎵嶆墽琛岃繖涓柟娉�
+        OpenSpecifiedPage(intent, "onNewIntent");
+    }
+
+    /**
+     * 鐐瑰嚮閫氱煡鏍忔秷鎭繘鏉�
+     */
+    private void OpenSpecifiedPage(Intent intent, String tag) {
+        Log.d("==========", tag);
+        try {
+            String data = getIntentExpantData(intent);
+            if (TextUtils.isEmpty(data)) {
+                return;
+            }
+            PushMessageInfoBean pushMessageInfoBean = HdlPushLogic.getInstance().pushDataProcessing("", "", data);
+            if (TextUtils.isEmpty(pushMessageInfoBean.getMsgId()) && !pushMessageInfoBean.isAiPrompt()) {
+                return;
+            }
+            Log.d("==========111111", tag);
+            HDLUniMPSDKManager.uinEnabled = false;
+            if (tag.equals("onNewIntent")) {
+                HDLUniMPSDKManager.uinEnabled = false;
+                //C绔惎鍔ˋpp鑷姩鎵撳紑灏忕▼搴忕數绔欒鎯呯晫闈�
+                if (null != HDLUniMPSDKManager.getInstance().getUniMP()) {
+                    HDLUniMPSDKManager.getInstance().getUniMP().closeUniMP();
+                }
+                startAppAutomaticallyOpenUni();
+            }
+            CheckUniOn(pushMessageInfoBean);
+
+
+        } catch (Exception e) {
+            Log.d("閿欒", " " + e.getMessage());
+        }
+    }
+
     public void startAppAutomaticallyOpenUni() {
         new Thread(new Runnable() {
             @Override
@@ -132,6 +188,46 @@
 //                        }
                     }
                 });
+            }
+        }).start();
+    }
+
+    /**
+     * 妫�娴媢ni鏄惁鎵撳紑锛屾娴嬫渶闀挎椂闂翠负5s锛屾娴嬫垚鍔熷悗鎵撳紑鍘熺敓娑堟伅鐣岄潰锛屽叧闂繑鍥炰富鐣岄潰
+     */
+    public void CheckUniOn(PushMessageInfoBean pushMessageInfoBean) {
+        if (pushMessageInfoBean == null) return;
+        final long startTime = System.currentTimeMillis();
+        new Thread(new Runnable() {
+            @Override
+            public void run() {
+                while (System.currentTimeMillis() - startTime < 5 * 1000) {
+                    if (HDLUniMPSDKManager.uinEnabled) {
+                        runOnUiThread(new Runnable() {
+                            @Override
+                            public void run() {
+                                if (pushMessageInfoBean.isAiPrompt()) {
+                                    HDLUniMP.UniCallBackBaseBean uniCallBackBaseBean = new HDLUniMP.UniCallBackBaseBean();
+                                    uniCallBackBaseBean.setType(HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_open_ai_push_message);
+                                    HdlUniLogic.getInstance().sendUni(HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_MODEL, uniCallBackBaseBean);
+                                    HdlLogLogic.print("uni---鍘熺敓涓诲姩鍚戝皬绋嬪簭鍙戦�侀�氱煡AI浜嬩欢---", false);
+                                } else {
+                                    MessageBean messageBean = new MessageBean();
+                                    messageBean.setMsgId(Long.valueOf(pushMessageInfoBean.getMsgId()));
+                                    Intent intentMessageInfoActivity = new Intent();
+                                    intentMessageInfoActivity.setClass(_mActivity, MessageInfoActivity.class);
+                                    intentMessageInfoActivity.putExtra("messageBean", JSONObject.toJSONString(messageBean));
+                                    startActivity(intentMessageInfoActivity);
+                                    HdlLogLogic.print("uni---鍘熺敓涓诲姩鍚戝皬绋嬪簭鍙戦�侀�氱煡AI浜嬩欢---11111", false);
+                                }
+
+                            }
+                        });
+                        break;
+                    }
+                    SystemClock.sleep(1000);
+                }
+
             }
         }).start();
     }
@@ -239,6 +335,9 @@
             MqttRecvClient.getInstance().checkAndsubscribeAllTopics(topicHome);//璁㈤槄銆愮數绔欍�戞秷鎭�
 
 
+        } else if (event.getTopic().contains(ConstantManage.refresh_push_token)) {
+            //pushToken鏇存柊
+            sendPushTokenToServer(UserConfigManage.getInstance().getPushToken());
         }
     }
 
@@ -334,65 +433,36 @@
     @Override
     protected void onDestroy() {
         super.onDestroy();
-        HdlUniLogic.getInstance().checkRemoveOtherUniMPEventCallBack();
+//        HdlUniLogic.getInstance().checkRemoveOtherUniMPEventCallBack();
         //绉婚櫎鐩戝惉
         HDLLinkLocalSdk.getInstance().removeAllTopicsListener(allTopicsListener);
 //        stopService(mForegroundService);
     }
 
     /**
-     * 涓婁紶鏋佸厜娉ㄥ唽ID鍒颁簯绔�
+     * 涓婁紶 token 鍒版湇鍔″櫒
+     *
+     * @param token 浠ょ墝
      */
-    private void pushTokens() {
-        String registrationId_tag = "registrationID_" + UserConfigManage.getInstance().getUserId();
-        String is_registrationID = HDLApp.getInstance().getKey(registrationId_tag);
-        if (is_registrationID.equals("true")) {
-            //涓婅繃灏辨病鏈夊繀瑕佸湪涓婁紶鍟�
+    private void sendPushTokenToServer(final String token) {
+        if (TextUtils.isEmpty(token)) {
             return;
         }
-
-        HdlThreadLogic.runSubThread(new Runnable() {
+        HdlPushLogic.getInstance().pushAdd(new CloudCallBeak<String>() {
             @Override
-            public void run() {
-                String registrationID = JPushInterface.getRegistrationID(_mActivity);
-                int addCount = 0;
-                while (TextUtils.isEmpty(registrationID)) {
-                    SystemClock.sleep(1000);//1s浼戠湢
-                    registrationID = JPushInterface.getRegistrationID(_mActivity);
-                    addCount++;
-                    if (addCount > 5) {
-                        //5s瓒呮椂
-                        break;
-                    }
+            public void onSuccess(String pushId) {
+
+                if (!TextUtils.isEmpty(pushId)) {
+                    UserConfigManage.getInstance().setToken(token);
+                    UserConfigManage.getInstance().setPushId(pushId);
+                    UserConfigManage.getInstance().Save();
                 }
-                if (!TextUtils.isEmpty(registrationID)) {
-//                    UserConfigManage.getInstance().setRegistrationID(registrationID);
-//                    UserConfigManage.getInstance().Save();
-                    String finalRegistrationID = registrationID;
-                    HdlResidenceLogic.getInstance().pushAdd(new CloudCallBeak<String>() {
-                        @Override
-                        public void onSuccess(String pushId) {
+                HdlLogLogic.print("娣诲姞浠ょ墝鍒颁簯绔� PushToken:" + UserConfigManage.getInstance().getPushToken() + " pushId:" + pushId, true);
+            }
 
-                            if (!TextUtils.isEmpty(pushId)) {
-                                UserConfigManage.getInstance().setRegistrationID(finalRegistrationID);
-                                UserConfigManage.getInstance().setPushId(pushId);
-                                UserConfigManage.getInstance().Save();
-                            }
-                            HDLApp.getInstance().setInfoMap(registrationId_tag, "true");//璁板綍涓�涓嬬姸鎬�,鍚庡彴鏉�姝籥pp浼氭竻绌�;
-                            HdlLogLogic.print("C绔�---娣诲姞鏋佸厜ID鍒颁簯绔�---registrationID:" + UserConfigManage.getInstance().getUserName() + "--->" + finalRegistrationID, true);
-
-                        }
-
-                        @Override
-                        public void onFailure(HDLException e) {
-                            HDLApp.getInstance().setInfoMap(registrationId_tag, "false");//璁板綍涓�涓嬬姸鎬�,鍚庡彴鏉�姝籥pp浼氭竻绌�;
-                            HdlLogLogic.print("C绔�---娣诲姞鏋佸厜ID鍒颁簯绔け璐�---registrationID:" + UserConfigManage.getInstance().getUserName() + "--->" + finalRegistrationID, true);
-                        }
-                    });
-
-                }
-
-
+            @Override
+            public void onFailure(HDLException e) {
+                HdlLogLogic.print("娣诲姞浠ょ墝鍒颁簯绔け璐� PushToken:" + UserConfigManage.getInstance().getPushToken() + " 閿欒锛�" + e.getMessage(), true);
             }
         });
     }
@@ -554,5 +624,27 @@
         HDLLinkLocalSdk.getInstance().registerAllTopicsListener(allTopicsListener);
     }
 
-
+    /**
+     * 澶勭悊浠庨�氱煡鐐瑰嚮甯︽潵鐨勬暟鎹紝杩欓噷鑾峰彇鏁版嵁锛岀劧鍚庨�忎紶缁欎富鐣岄潰鍋氬鐞�
+     *
+     * @return 杩斿洖闄勫姞鏁版嵁
+     */
+    private String getIntentExpantData(Intent intent) {
+        try {
+            if (intent == null) {
+                return "";
+            }
+            // 澶勭悊浠庨�氱煡鐐瑰嚮甯︽潵鐨勬暟鎹紝杩欓噷鑾峰彇鏁版嵁锛岀劧鍚庨�忎紶缁欎富鐣岄潰鍋氬鐞�
+            if (intent.getExtras() != null) {
+                for (String key : intent.getExtras().keySet()) {
+                    if (key.equals("pushData")) {
+                        return Objects.requireNonNull(intent.getExtras().get(key)).toString();
+                    }
+                }
+            }
+        } catch (Exception e) {
+            return "";
+        }
+        return "";
+    }
 }

--
Gitblit v1.8.0