From ec92a4e41838ae1954af337386a3508398602051 Mon Sep 17 00:00:00 2001
From: wjc <1243177876@qq.com>
Date: 星期日, 27 四月 2025 13:43:22 +0800
Subject: [PATCH] 2025年04月27日13:43:20

---
 app/src/main/java/com/hdl/photovoltaic/HDLApp.java |  204 ++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 176 insertions(+), 28 deletions(-)

diff --git a/app/src/main/java/com/hdl/photovoltaic/HDLApp.java b/app/src/main/java/com/hdl/photovoltaic/HDLApp.java
index 7f19bb9..9ad9cb7 100644
--- a/app/src/main/java/com/hdl/photovoltaic/HDLApp.java
+++ b/app/src/main/java/com/hdl/photovoltaic/HDLApp.java
@@ -1,10 +1,22 @@
 package com.hdl.photovoltaic;
 
+import android.app.Activity;
+import android.app.ActivityManager;
 import android.app.Application;
+import android.content.Context;
 import android.content.Intent;
+import android.content.res.Configuration;
+import android.os.Build;
+import android.os.LocaleList;
+import android.os.Process;
+import android.os.SystemClock;
 import android.text.TextUtils;
+import android.util.Log;
 
 
+import androidx.multidex.MultiDex;
+
+import com.google.gson.Gson;
 import com.hdl.hdlhttp.HxHttpConfig;
 import com.hdl.linkpm.sdk.HDLLinkPMSdk;
 import com.hdl.linkpm.sdk.user.HDLLinkPMUser;
@@ -13,11 +25,15 @@
 import com.hdl.photovoltaic.config.AppConfigManage;
 import com.hdl.photovoltaic.config.ConstantManage;
 import com.hdl.photovoltaic.config.UserConfigManage;
+import com.hdl.photovoltaic.enums.LowerTagType;
 import com.hdl.photovoltaic.enums.NetworkType;
+import com.hdl.photovoltaic.other.HdlDeviceLogic;
+import com.hdl.photovoltaic.other.HdlFileLogic;
 import com.hdl.photovoltaic.other.HdlLogLogic;
 import com.hdl.photovoltaic.other.HdlMessageLogic;
+import com.hdl.photovoltaic.other.HdlResidenceLogic;
 import com.hdl.photovoltaic.other.HdlThreadLogic;
-import com.hdl.photovoltaic.ui.HomeLoginActivity;
+import com.hdl.photovoltaic.ui.LoginActivity;
 import com.hdl.photovoltaic.uni.HDLUniMPSDKManager;
 import com.hdl.photovoltaic.utils.AppManagerUtils;
 import com.hdl.photovoltaic.utils.LocalManageUtil;
@@ -28,26 +44,41 @@
 import com.hdl.sdk.link.core.connect.HDLUdpConnect;
 import com.hdl.sdk.link.core.utils.QueueUtils;
 import com.hdl.sdk.link.core.utils.mqtt.MqttRecvClient;
+import com.umeng.commonsdk.UMConfigure;
 
 import org.greenrobot.eventbus.EventBus;
 
 import java.util.HashMap;
+import java.util.List;
+import java.util.Locale;
 import java.util.Objects;
 
 import cn.jpush.android.api.JPushInterface;
 import io.dcloud.common.util.RuningAcitvityUtil;
+import me.jessyan.autosize.AutoSize;
+import me.jessyan.autosize.AutoSizeConfig;
+import me.jessyan.autosize.onAdaptListener;
+import me.jessyan.autosize.utils.ScreenUtils;
 import okhttp3.logging.HttpLoggingInterceptor;
 
 public class HDLApp extends Application {
 
+    final String TAG=HDLApp.class.getName();
     //鎺у埗鎵撳嵃 Debug妯″紡鎵撳嵃
     private Boolean isLogEnabled = true;
     //涓夋柟sdk鍒濆鍖栨爣璇�
     private Boolean isInitThirdSDK = false;
+    //涓夋柟sdk鍒濆鍖栨爣璇�
+    /**
+     * 涓夋柟sdk鍒濆鍖栨爣璇�
+     * 鍦⊿tartActivity閲岄潰鍒濆鍖栦笁鏂筍DK鐨勬爣璇�
+     */
+    public Boolean isStartInitThirdSDK = false;
     //澹版槑涓�涓綋鍓嶅簲鐢ㄧ殑瀹炰緥
     private static HDLApp mHDLApp;
     //澹版槑涓�涓叕鍏辩殑淇℃伅鏄犲皠,鍙綋浣滃叏灞�鍙橀噺浣跨敤;
     public HashMap<String, String> mInfoMap = new HashMap<>();
+
 
     //鍒╃敤鍗曚緥妯″紡鑾峰彇褰撳墠搴旂敤鐨勫敮涓�瀹炰緥
     public static HDLApp getInstance() {
@@ -56,13 +87,21 @@
 
     @Override
     public void onCreate() {
-
         super.onCreate();
+//        // 鑾峰彇褰撳墠杩涚▼鐨凱ID
+//        String processMessage= "杩涚▼ID:"+Process.myPid()+" 杩涚▼鍚嶏細"+RuningAcitvityUtil.getAppName(getBaseContext());
+//        Log.d(TAG, processMessage);
+//        if (RuningAcitvityUtil.getAppName(getBaseContext()).contains(":")) {
+//            //闈炲師鐢熻繘绋嬶紝鐢ㄥ垵濮嬪寲鍚庨潰鐨�
+//            return;
+//        }
         mHDLApp = this;
         SharedPreUtils.init(this);
         getAppLanguage();
-        initThirdSDK();
-//        appLocationInfo();
+        //棰勫垱寤鸿剼鏈琷son鏂囦欢澶�
+        HdlFileLogic.getInstance().createHdlESLocalJsonDirectory();
+        init();
+
 
     }
 
@@ -70,8 +109,8 @@
         String language = UserConfigManage.getInstance().getCurrentAppLanguage();
         if (TextUtils.isEmpty(language)) {
             //浠庡唴瀛橀噷闈㈣幏鍙栦笉鍒拌瑷�,鑾峰彇褰撳墠绯荤粺鐨�;
-            String str = getResources().getConfiguration().locale.getCountry();
-            if (str.equals("CN") || str.equals("TW")) {
+            String str = getResources().getConfiguration().locale.getLanguage();
+            if (str.equals(LocalManageUtil.zh)) {
                 UserConfigManage.getInstance().setCurrentAppLanguage(LocalManageUtil.zh);
             } else {
                 UserConfigManage.getInstance().setCurrentAppLanguage(LocalManageUtil.en);
@@ -108,16 +147,15 @@
     /**
      * 鍒濆鍖栦笁鏂圭浉鍏砈DK
      */
-    public void initThirdSDK() {
+    public void init() {
         // 灏忕▼搴忚繘绋�
-        if (RuningAcitvityUtil.getAppName(getBaseContext()).contains("unimp")) {
+        if (RuningAcitvityUtil.getAppName(getBaseContext()).contains(":")) {
             return;
         }
         if (isInitThirdSDK) {
             return;
         }
         isInitThirdSDK = true;
-
 //        //5.鍒濆鍖朆ugly
 //        CrashReport.initCrashReport(this, Constant.BUGLY_APP_ID, true);
         //6.鍒濆鍖朌CUniMPSDK
@@ -129,18 +167,36 @@
 //        TypeUtils.compatibleWithFieldName = true;
 //        //9.鍒濆鍖栫綉缁滃伐鍏�
 //        NetWorkUtil.init(this);
-        //鍒濆鍖栨瀬鍏夋帹閫�
-        initJPush();
+        initAutoSize();
+//        //鍒濆鍖栨瀬鍏夋帹閫�
+//        initJPush();
         initHDLLinkPMSdk();
         HDLLinkLocalSdk.getInstance().init(getInstance());
         initSocket();
         //4.鍒濆鍖朞KHttpLog 鏄惁寮�鍚�
         setOKHttpLogOpen(isLogEnabled);
+//        initMqttClient();
         //鐩戝惉缃戠粶鐘舵�佸彉鍖�
         this.networkMonitoring();
         //鍒濆鍖栨湰鍦癮ssets鏂囦欢澶硅祫婧愭枃浠�
-        this.initLocalAssetsData();
+//        this.initLocalAssetsData();
+        //鍒濆鍖栧弸鐩烻DK
+        initUMengSDK();
 
+
+    }
+
+    /**
+     * 鍒濆鍖栧弸鐩烻DK锛屾姄闂��鏃ュ織
+     * 闆嗘垚鏁欑▼鍦板潃锛歨ttps://developer.umeng.com/docs/119267/detail/118588
+     */
+    private void initUMengSDK() {
+        UMConfigure.preInit(this, "6801aec0bc47b67d833fd76d", "XenterraSolar");
+        //appkey鍜宑hannl蹇呴』淇濇寔鍜岄鍒濆鍖栦竴鑷达紒锛侊紒
+        //deviceType锛氳澶囩被鍨嬶紝UMConfigure.DEVICE_TYPE_PHONE涓烘墜鏈恒�乁MConfigure.DEVICE_TYPE_BOX涓虹洅瀛�
+        //pushSecret锛歅ush鎺ㄩ�佷笟鍔$殑secret
+        UMConfigure.init(this, "6801aec0bc47b67d833fd76d", "XenterraSolar", UMConfigure.DEVICE_TYPE_PHONE, "");
+        UMConfigure.setLogEnabled(false);//AppConfigManage.isDebug()
     }
 
 
@@ -149,12 +205,13 @@
      */
     private void initHDLLinkPMSdk() {
         //1.鍒濆鍖朣DK
-        HDLLinkPMSdk.initWithAppKey(getInstance(), AppConfigManage.getAppKey(), AppConfigManage.getAppSecret(), AppConfigManage.getAPPRegionUrl());
+        HDLLinkPMSdk.initWithAppKey(this, AppConfigManage.getAppKey(), AppConfigManage.getAppSecret(), AppConfigManage.getAPPRegionUrl());
         //2.璁剧疆鎵撳嵃
         HDLLinkPMSdk.setLogEnabled(isLogEnabled);
+
         if (TextUtils.isEmpty(UserConfigManage.getInstance().getCurrentAppLanguage())) {
-            //榛樿閰嶇疆鎺ュ彛璇锋眰璇█鏄腑鏂�
-            UserConfigManage.getInstance().setCurrentAppLanguage(LocalManageUtil.zh);
+            //榛樿閰嶇疆鎺ュ彛璇锋眰璇█鏄嫳鏂�
+            UserConfigManage.getInstance().setCurrentAppLanguage(LocalManageUtil.en);
         }
         //3.閰嶇疆鎺ュ彛璇锋眰璇█
         HDLLinkPMSdk.setLanguage(UserConfigManage.getInstance().getCurrentAppLanguage());
@@ -171,33 +228,62 @@
         HDLLinkPMUser.getInstance().setOnReloginListener(new IOnReloginListener() {
             @Override
             public void onReLogin(int type) {
+
+
+                boolean isLoginActivity = false;
+                // 鑾峰彇褰撳墠Activity鐨勫垪琛�
+                ActivityManager activityManager = (ActivityManager) getSystemService(Context.ACTIVITY_SERVICE);
+                List<ActivityManager.RunningTaskInfo> taskInfo = activityManager.getRunningTasks(1);
+                // 閬嶅巻Activity鍒楄〃锛屽垽鏂洰鏍嘇ctivity鏄惁鍦ㄥ垪琛ㄤ腑
+                for (ActivityManager.RunningTaskInfo info : taskInfo) {
+                    if (info.topActivity.getClassName().equals("com.hdl.photovoltaic.ui.LoginActivity")) {
+                        // 鐩爣Activity瀛樺湪
+                        // 鍦ㄨ繖閲屽彲浠ヨ繘琛岀浉搴斿鐞�
+                        isLoginActivity = true;
+                        break;
+                    }
+                }
+                if (!isLoginActivity) {
+
+                }
+
+
+                HdlLogLogic.print("鐩戝惉鍒扮櫥褰曢��鍑�---" + type, true);
                 //type:  0:姝e父閫�鍑�   1锛氭瀬鍏夋帹閫佸己鍒堕��鍑�
                 //鏀跺埌鐧诲綍澶勭悊閫氱煡锛屽叧闂墍鏈夐〉闈㈠苟鎵撳紑鐧诲綍椤甸潰
                 AppManagerUtils.getAppManager().finishAllActivity();
-                HDLSDKSPUtils.clear();
+//                HDLSDKSPUtils.clear();//搴曞眰鑷繁娓呯┖
 
                 //閲嶆柊鐧婚檰,榛樿鍚屾剰闅愮鏀跨瓥
-                UserConfigManage.getInstance().setAcceiptPolicy(true);
+                UserConfigManage.getInstance().setAcceiptPolicy(false);
                 //閲嶆柊璁惧畾涓�涓椂闂�
                 UserConfigManage.getInstance().setLoginDateTime(0);
                 UserConfigManage.getInstance().Save();
+
                 //娓呯┖娑堟伅缂撳瓨鏁版嵁
                 HdlMessageLogic.getInstance().clearListMessage();
-
+                //娓呯┖鐢电珯缂撳瓨鏁版嵁
+                HdlResidenceLogic.getInstance().clearHouseList();
+                //娓呯┖璁惧缂撳瓨鏁版嵁
+                HdlDeviceLogic.getInstance().clearDeviceList();
+                //娓呯┖缂撳瓨鏁版嵁
+                if (mInfoMap != null) {
+                    mInfoMap.clear();
+                }
                 //鏂紑mqtt杩炴帴
                 if (MqttRecvClient.getInstance() != null) {
-                    MqttRecvClient.getInstance().stop();
+                    MqttRecvClient.getInstance().disConnect();
                 }
                 //鏂紑鎵�鏈塼cp杩炴帴涓旀竻绌鸿繛鎺ョ紦瀛�
                 // TODO: 10/10/23
 //                TcpSocketBoot.stopAllConnectLinkGateway();
-//                    if(null!=HDLUniMPSDKManager.getInstance().getUniMP()){
-//                        LogUtils.d("asdfasdfasdfsdf鎴戣鍒犻櫎鍟�");
-//                        HDLUniMPSDKManager.getInstance().getUniMP().closeUniMP();
-//                    }
-//                    initDCUniMPSDK();
-                Intent intent = new Intent(getInstance(), HomeLoginActivity.class);
-                intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
+                if (null != HDLUniMPSDKManager.getInstance().getUniMP()) {
+                    HDLUniMPSDKManager.getInstance().getUniMP().closeUniMP();
+                }
+                SystemClock.sleep(200);
+                initDCUniMPSDK();
+                Intent intent = new Intent(getInstance(), LoginActivity.class);
+                intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TOP);
                 if (type == 1) {
                     intent.putExtra("isJpush", true);
                 }
@@ -238,7 +324,6 @@
     private void initJPush() {
         JPushInterface.setDebugMode(true);
         JPushInterface.init(getBaseContext());
-
     }
 
     /**
@@ -286,13 +371,36 @@
 
     }
 
+    /**
+     * 钃濇箹涓� 淇敼瀹藉害 640dp 瀹藉害鎸夌収dp銆乻p鏉ラ�傞厤
+     * 鏃嬭浆鍚庨珮鍙樺,鎸夋棆杞悗楂樺害閫傞厤,鎵�浠ュ搴︿笉鍐欐
+     */
+    private void initAutoSize() {
+        AutoSize.initCompatMultiProcess(this);
+        boolean isBaseOnWidth = getResources().getConfiguration().orientation == Configuration.ORIENTATION_PORTRAIT;
+        AutoSizeConfig.getInstance().setBaseOnWidth(true).setCustomFragment(true).setDesignWidthInDp(375).setDesignHeightInDp(812).setUseDeviceSize(false).setOnAdaptListener(new onAdaptListener() {
+            @Override
+            public void onAdaptBefore(Object target, Activity activity) {
+
+                AutoSizeConfig.getInstance().setScreenWidth(ScreenUtils.getScreenSize(activity)[0]);
+                AutoSizeConfig.getInstance().setScreenHeight(ScreenUtils.getScreenSize(activity)[1] + ScreenUtils.getHeightOfNavigationBar(activity) + ScreenUtils.getStatusBarHeight());
+
+            }
+
+            @Override
+            public void onAdaptAfter(Object target, Activity activity) {
+
+            }
+        });
+    }
+
 
     /**
      * 鍒濆鍖杣ni app mqtt
      */
     private void initUniMqtt() {
         try {
-            String ip = NetworkUtils.getIPAddress(this);
+            String ip = "192.168.1.100";//NetworkUtils.getIPAddress(this);
             if (TextUtils.isEmpty(ip)) {
                 return;
             }
@@ -304,4 +412,44 @@
         }
     }
 
+
+    @Override
+    protected void attachBaseContext(Context base) {
+        MultiDex.install(base);
+        super.attachBaseContext(base);
+    }
+
+    /**
+     * 鏀寔涓嫳鏂囧垏鎹�
+     */
+    public Context getAppLocaleContext(Context context) {
+        try {
+            Locale locale = new Locale(UserConfigManage.getInstance().getCurrentAppLanguage());
+            Configuration configuration = context.getResources().getConfiguration();
+            configuration.setLocale(locale);
+            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
+                configuration.setLocales(new LocaleList(locale));
+            }
+            return context.createConfigurationContext(configuration);
+        } catch (Exception e) {
+            return context;
+        }
+    }
+
+    /**
+     * 鏀寔涓嫳鏂囧垏鎹�
+     */
+    public Context getAppLocaleContext() {
+        try {
+            Locale locale = new Locale(UserConfigManage.getInstance().getCurrentAppLanguage());
+            Configuration configuration = getResources().getConfiguration();
+            configuration.setLocale(locale);
+            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
+                configuration.setLocales(new LocaleList(locale));
+            }
+            return createConfigurationContext(configuration);
+        } catch (Exception e) {
+            return this;
+        }
+    }
 }

--
Gitblit v1.8.0