diff --git a/app/src/main/java/com/shayu/phonelive/activity/LauncherActivity.java b/app/src/main/java/com/shayu/phonelive/activity/LauncherActivity.java index 39055c622..5afc36436 100644 --- a/app/src/main/java/com/shayu/phonelive/activity/LauncherActivity.java +++ b/app/src/main/java/com/shayu/phonelive/activity/LauncherActivity.java @@ -186,19 +186,17 @@ public class LauncherActivity extends AppCompatActivity implements View.OnClickL //解压后的文件数量必须要有2个 //如果文件存在,解压后 文件数量一致,直接进入下一步 if (fileSo.exists() && getFileCount(fileSoList.getAbsolutePath()) == 2){ - MainActivity.faceSDKIsLoadSuceness = true; + CommonAppConfig.faceSDKIsLoadSuceness = true; mHandler.sendEmptyMessageDelayed(WHAT_GET_CONFIG, 1000); return; } // https://downs.yaoulive.com/androidLibs/t3/faceunity2-so-arm64-v8a.zip - String soUrl = String.format("https://downs.yaoulive.com/androidLibs/t3/faceunity2-so-%s.zip", cpuAbi); - Log.i("download", soUrl); - + downLoadFaceSDK_OutputDir = outputDir.getAbsolutePath(); if (!fileSo.exists()) { - downloadSo(outputDir.getAbsolutePath(), soUrl,Constants.FaceUnity_SO_Name,false); + downloadSo(downLoadFaceSDK_OutputDir, downLoadFaceSDK_downloadUrl,Constants.FaceUnity_SO_Name,false); }else if (fileSo.exists() && getFileCount(outputDir.getAbsolutePath()) < 3) { fileSo.delete(); - downloadSo(outputDir.getAbsolutePath(), soUrl,Constants.FaceUnity_SO_Name,false); + downloadSo(outputDir.getAbsolutePath(), downLoadFaceSDK_downloadUrl,Constants.FaceUnity_SO_Name,false); } } @@ -244,9 +242,13 @@ public class LauncherActivity extends AppCompatActivity implements View.OnClickL } } - Dialog progressDialog; + private Dialog progressDialog; public ProgressBar progressBar; public TextView tvProgress; + private int downLoadFaceSDKCount = 0; + private int unZipFaceSDKCount = 0; + private String downLoadFaceSDK_OutputDir; + private String downLoadFaceSDK_downloadUrl = String.format("https://downs.yaoulive.com/androidLibs/t3/faceunity2-so-%s.zip", Build.CPU_ABI); private void showDialog(Activity context) { progressDialog = new Dialog(context, com.yunbao.common.R.style.dialog); @@ -268,6 +270,9 @@ public class LauncherActivity extends AppCompatActivity implements View.OnClickL progressDialog.setCancelable(false); progressDialog.show(); } + + + public void downloadSo(String outputDir, String downloadUrl,String fileName,boolean isShowDialog) { DownloadUtil downloadUtil = new DownloadUtil(); if(isShowDialog){ @@ -280,17 +285,7 @@ public class LauncherActivity extends AppCompatActivity implements View.OnClickL progressDialog.dismiss(); mHandler.sendEmptyMessageDelayed(WHAT_GET_CONFIG, 20); } - File fileSo = new File(outputDir, fileName); - try { - unzip(fileSo.getAbsolutePath(), outputDir); - MainActivity.faceSDKIsLoadSuceness = true; - if (BuildConfig.DEBUG){ - ToastUtil.showDebug("美颜SDK加载成功..."); - } - } catch (Exception e) { - Log.e("ZipCheck", "Error reading ZIP file", e); - throw new RuntimeException(e); - } + unZipFaceSDK(outputDir, fileName); } @Override @@ -304,12 +299,36 @@ public class LauncherActivity extends AppCompatActivity implements View.OnClickL @Override public void onError(Throwable e) { //资源下载失败 - + downLoadFaceSDKCount++; + if (downLoadFaceSDKCount < 3) { + downloadSo(downLoadFaceSDK_OutputDir, downLoadFaceSDK_downloadUrl,Constants.FaceUnity_SO_Name,false); + } else { + CommonAppConfig.faceSDKDownLoadOrUnZipFailed = true; + } } }); } + private void unZipFaceSDK(String outputDir, String fileName) { + File fileSo = new File(outputDir, fileName); + try { + unzip(fileSo.getAbsolutePath(), outputDir); + } catch (Exception e) { + Log.e("ZipCheck", "Error reading ZIP file", e); + unZipFaceSDKCount++; + if (unZipFaceSDKCount < 3) { + unZipFaceSDK(outputDir, fileName); + } else { + CommonAppConfig.faceSDKDownLoadOrUnZipFailed = true; + } + } + CommonAppConfig.faceSDKIsLoadSuceness = true; + if (BuildConfig.DEBUG){ + ToastUtil.showDebug("美颜SDK加载成功..."); + } + } + /** * 解压 .zip 文件到目标目录 */ diff --git a/common/src/main/java/com/yunbao/common/CommonAppConfig.java b/common/src/main/java/com/yunbao/common/CommonAppConfig.java index ddc9390bd..6002b2e80 100644 --- a/common/src/main/java/com/yunbao/common/CommonAppConfig.java +++ b/common/src/main/java/com/yunbao/common/CommonAppConfig.java @@ -145,6 +145,10 @@ public class CommonAppConfig { private int mAppIconRes; private String mAppName; private Boolean mTiBeautyEnable;//是否使用萌颜 true使用萌颜 false 使用基础美颜 + // 美颜SDK是否已经加载成功 + public static boolean faceSDKIsLoadSuceness; + // 美颜SDK是否下载失败或者解压失败(自动试3次) + public static boolean faceSDKDownLoadOrUnZipFailed = false; public String getUid() { if (TextUtils.isEmpty(mUid)) { diff --git a/common/src/main/res/values-zh/strings.xml b/common/src/main/res/values-zh/strings.xml index e599f31ea..059c891ae 100644 --- a/common/src/main/res/values-zh/strings.xml +++ b/common/src/main/res/values-zh/strings.xml @@ -827,6 +827,7 @@ 暫時只對主播開放 請稍等,美顏SDK加載中 + 美顏SDK加載失敗,請重啟App 2011402032399020 959584e054a33614996361f0044e5253 diff --git a/common/src/main/res/values/strings.xml b/common/src/main/res/values/strings.xml index 2b2f2598b..5eb0c4aef 100644 --- a/common/src/main/res/values/strings.xml +++ b/common/src/main/res/values/strings.xml @@ -787,6 +787,7 @@ For the time being, it is only open to the anchor Please wait, the beauty SDK is loading. + Beauty SDK failed to load, please restart the App 2011402032399020 959584e054a33614996361f0044e5253 diff --git a/live/src/main/java/com/yunbao/live/activity/LiveSwAnchorActivity.java b/live/src/main/java/com/yunbao/live/activity/LiveSwAnchorActivity.java index eab9047b3..dc1a3eb10 100644 --- a/live/src/main/java/com/yunbao/live/activity/LiveSwAnchorActivity.java +++ b/live/src/main/java/com/yunbao/live/activity/LiveSwAnchorActivity.java @@ -215,14 +215,14 @@ public class LiveSwAnchorActivity extends LiveActivity implements LiveFunctionCl super.main(); Bus.getOn(this); Intent intent = getIntent(); - if(CommonAppConfig.IS_GOOGLE_PLAY == 0){ + /* if(CommonAppConfig.IS_GOOGLE_PLAY == 0){ // 美颜SO设置 File file_FaceUnity = new File(mContext.getDir("lib", Context.MODE_PRIVATE).getAbsoluteFile(), com.yunbao.common.Constants.DOWNLOAD_FaceUnity_SO + File.separator + Build.CPU_ABI); faceunity.LoadConfig.loadLibrary(file_FaceUnity.getAbsolutePath()); Log.i("downLoad", "美颜SO Path = " + file_FaceUnity.getAbsolutePath()); - } + }*/ - initFaceManager(); +// initFaceManager(); leave_img = findViewById(R.id.leave_img); mLiveSDK = intent.getIntExtra(Constants.LIVE_SDK, Constants.LIVE_SDK_KSY); if (mLiveSDK == Constants.LIVE_SDK_SW) { diff --git a/main/src/main/java/com/yunbao/main/activity/MainActivity.java b/main/src/main/java/com/yunbao/main/activity/MainActivity.java index f5ecdf256..ca58d3c25 100644 --- a/main/src/main/java/com/yunbao/main/activity/MainActivity.java +++ b/main/src/main/java/com/yunbao/main/activity/MainActivity.java @@ -205,10 +205,7 @@ public class MainActivity extends AbsActivity implements MainAppBarLayoutListene private View floatWarOrder;//战令浮窗 private List startListNotifyList = new ArrayList<>(); - private String[] libNameList = new String[]{"agora-core", "agora-ffmpeg", "agora-fdkaac", "agora-soundtouch","agora-rtc-sdk"}; - // 美颜SDK是否已经加载成功 - public static boolean faceSDKIsLoadSuceness = false; - +// private String[] libNameList = new String[]{"agora-core", "agora-ffmpeg", "agora-fdkaac", "agora-soundtouch","agora-rtc-sdk"}; @Override protected int getLayoutId() { diff --git a/main/src/main/java/com/yunbao/main/dialog/MainStartDialogFragment.java b/main/src/main/java/com/yunbao/main/dialog/MainStartDialogFragment.java index aa9da03dd..457172654 100644 --- a/main/src/main/java/com/yunbao/main/dialog/MainStartDialogFragment.java +++ b/main/src/main/java/com/yunbao/main/dialog/MainStartDialogFragment.java @@ -168,11 +168,18 @@ public class MainStartDialogFragment extends AbsDialogFragment implements View.O public void onLiveClick() { boolean isAnchor = IMLoginManager.get(mContext).getUserInfo().anchorUserType(); if (isAnchor) { + if (CommonAppConfig.faceSDKDownLoadOrUnZipFailed){ + // 美颜SDK下载或解压失败并且重试三次还是失败,提示用户重启 + ToastUtil.show(getString(R.string.face_sdk_load_failed)); + return; + } + // 判断美颜SDK是否加载成功 - if (!MainActivity.faceSDKIsLoadSuceness){ + if (!CommonAppConfig.faceSDKIsLoadSuceness){ ToastUtil.show(getString(R.string.wait_face_sdk_load)); return; } + String[] permissions; if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.UPSIDE_DOWN_CAKE) { permissions = new String[]{