From bac3e76faaebc96dd098f41a3d800428d83270f3 Mon Sep 17 00:00:00 2001 From: fyf Date: Wed, 26 Jul 2023 17:00:11 +0800 Subject: [PATCH] =?UTF-8?q?1.=E5=A2=9E=E5=8A=A0PLC=E9=85=8D=E7=BD=AE?= =?UTF-8?q?=E3=80=81PLC=E7=9B=91=E6=8E=A7=20loading=E5=8A=A0=E8=BD=BD?= =?UTF-8?q?=E7=94=BB=E9=9D=A2=202.=E8=B0=83=E6=95=B4=E7=A8=8B=E5=BA=8F?= =?UTF-8?q?=E5=88=9D=E5=A7=8B=E5=8C=96=E4=BD=8D=E7=BD=AE,=E5=85=88?= =?UTF-8?q?=E8=AF=A2=E9=97=AE=E8=8E=B7=E5=8F=96=E6=9D=83=E9=99=90,?= =?UTF-8?q?=E5=9C=A8=E5=88=9D=E5=A7=8B=E5=8C=96=E6=95=B0=E6=8D=AE=E5=BA=93?= =?UTF-8?q?=203.=E8=B0=83=E6=95=B4=E6=96=99=E4=BB=93=E6=8C=89=E9=92=AE?= =?UTF-8?q?=E5=A4=A7=E5=B0=8F=E3=80=81=E9=80=89=E6=8B=A9=E8=8F=9C=E8=B0=B1?= =?UTF-8?q?=E6=8C=89=E9=92=AE=E5=A4=A7=E5=B0=8F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../bonait/bnframework/MainApplication.java | 232 +-------------- .../bonait/bnframework/business/MainInit.java | 276 ++++++++++++++++++ .../common/constant/ConfigName.java | 2 + .../modules/home/adapter/lc_adapter.java | 52 +++- .../fragment/SystemCsControlFragment.java | 10 +- .../from/fragment/SystemCsPLCFragment.java | 19 +- .../from/fragment/SystemDeviceinFragment.java | 12 +- .../fragment/SystemSeasoningsetFragment.java | 15 +- .../welcome/activity/WelcomeActivity.java | 41 ++- app/src/main/res/layout/activity_cpxz.xml | 2 + app/src/main/res/layout/fragment_home1.xml | 22 +- .../res/layout/fragment_system_cs_control.xml | 42 ++- .../res/layout/fragment_system_cs_plc.xml | 69 +++-- .../res/layout/fragment_system_devicein.xml | 38 +-- .../res/layout/item/layout/item_liaochang.xml | 5 +- 15 files changed, 514 insertions(+), 323 deletions(-) create mode 100644 app/src/main/java/com/bonait/bnframework/business/MainInit.java diff --git a/app/src/main/java/com/bonait/bnframework/MainApplication.java b/app/src/main/java/com/bonait/bnframework/MainApplication.java index 448e9e7a..3ab9355a 100644 --- a/app/src/main/java/com/bonait/bnframework/MainApplication.java +++ b/app/src/main/java/com/bonait/bnframework/MainApplication.java @@ -1,12 +1,16 @@ package com.bonait.bnframework; +import android.Manifest; import android.annotation.SuppressLint; import android.app.Activity; import android.app.Application; import android.content.Context; +import android.content.pm.PackageManager; import android.util.Log; +import androidx.core.content.ContextCompat; + import com.bonait.bnframework.business.ConfigData; import com.bonait.bnframework.common.constant.ConfigName; import com.bonait.bnframework.common.constant.DataBus; @@ -55,6 +59,7 @@ import java.util.concurrent.TimeUnit; import java.util.logging.Level; import okhttp3.OkHttpClient; +import pub.devrel.easypermissions.EasyPermissions; /** * Created by FYF on 2019/3/19. @@ -72,232 +77,7 @@ public class MainApplication extends Application { public void onCreate() { super.onCreate(); context = getApplicationContext(); - //0.全局异常捕获,保存为SD卡本级目录 crash - CrashHandler.getInstance().init(this); - - //1.设置程序active,初始化Main函数进程,初始化消息日志 - InitMsgLog(); ConfigName.getInstance().dishesCon = this; - - //2.初始化SD卡,数据库DB - SdCart.getInstance().initSD(); - - //4.初始化Main,并且增加本地图片库 - ConfigData.getInstance().AddImage(context); - // activity生命周期管理 - ActivityLifecycleManager.get().init(this); - - // QMUI 框架初始化 - QMUISwipeBackActivityManager.init(this); - - // LitePal 数据库初始化 - LitePal.initialize(this); - - // 全局配置OkGo - initOkGo(); - - // 配置sharedPreferences - PreferenceUtils.initPreference(this, AppUtils.getAppName(this), Activity.MODE_PRIVATE); - - // 初始化通知栏消息渠道 - MainNotification.initNotificationChannel(this); - - // 内存泄漏检测 - initLeakCanary(false); - - // Log日志打印框架 - initLogCat(); - - // SmartShow Toast框架,暂时不用,先使用ToastUtils工具类的 - //SmartShow.init(this); - - //初始化DB数据 - InitDBdata(); - DataBus.getInstance().GetLc();//获取料仓数据 - ConfigData.getInstance().LoadingCloud();//加载云端数据 - } - - //========================================================================// - /** - * 初始化数据库数据(默认数据) - */ - public void InitDBdata() { - //1.没有用户数据 默认写一个admin - if (QueryDB.GetUserALL().size() <= 0) { - BPA_USER user = new BPA_USER(); - user.id = "20230415-fyf"; - user.name = "管理员"; - user.account = "admin"; - user.pass = "123456"; - user.deviceID = ConfigName.getInstance().DeviceId; - user.userID = "20230415-fyf"; - user.exp = "管理员"; - QueryDB.AddUser(user); - //10个料仓 - if (QueryDB.GetSilosALL().size() == 0) { - for (int i = 0; i < 5; i++) { - BPA_SILOS silo = new BPA_SILOS(); - silo.id = java.util.UUID.randomUUID().toString(); - silo.num = i + 1; - silo.thrsoleValue=ConfigName.getInstance().SiloAlarmThreshold; - silo.warningValue=ConfigName.getInstance().SiloFeedThreshold; - BPA_SILOSANDMATERIAL sm = new BPA_SILOSANDMATERIAL(); - sm.silosID = silo.id; - sm.materialID = ""; - QueryDB.AddSilos(silo); - QueryDB.AddSilosAndMaterial(sm); - } - } - } - - if(QueryDB.GetPlcaddressALL().size()<=0) - { - ConfigData.getInstance().RevertPLCProcess(); - } - } - /** - * 删除表-重新生成新表 - */ - public void DBdelete() - { - DBHelper.getInstance(this).DeleteCreateTables(BPA_CLOUDDATA.class,null); - DBHelper.getInstance(this).DeleteCreateTables(BPA_PLCADDRESS.class,null); - } - - - - - /** - * 初始化消息日志接收打印 - */ - public void InitMsgLog(){ - MessageLog.MsgNotify = new IMessageLogNotify() { - @Override - public void ErrorMsg(String msg) { - Log.e("Error", msg); - } - @Override - public void InfoMsg(String msg) { - Log.i("Info", msg); - - } - @Override - public void WarnMsg(String msg) { - Log.w("Warn", msg); - } - @Override - public void UserMsg(UserLogEnum type, String msg) { - BPA_LOG log = new BPA_LOG(); - log.userID = ConfigName.getInstance().user.userID; - switch (type.toString()) - { - case "登录日志":log.type=1; - break; - case "角色操作日志":log.type=2; - break; - case "数据接收":log.type=3; - break; - case "上传日志":log.type=4; - break; - case "订单处理日志":log.type=5; - break; - } - log.text = msg; - QueryDB.Addlog(log); - } - - @Override - public void AlertMsg(AlertLogEnum type, String msg) { - BPA_ALERTLOG log = new BPA_ALERTLOG(); - log.userID = ConfigName.getInstance().user.userID; - switch (type.toString()) - { - case "异常订单未制作日志":log.type=1; - break; - case "料仓缺料日志":log.type=2; - break; - case "传感器异常日志":log.type=3; - break; - case "其他":log.type=4; - break; - } - log.text = msg; - - QueryDB.AddAlertlog(log); - } - }; - } - /** - * 内存泄漏检测,根据flag来判断要不要初始化 - */ - private void initLeakCanary(boolean flag) { - if (flag) { - // leak 内存检测注册 -// if (LeakCanary.isInAnalyzerProcess(this)) { -// return; -// } -// LeakCanary.install(this); - } + ConfigName.getInstance().app = this; } - - /** - * 初始化log日志框架 - */ - private void initLogCat() { - FormatStrategy formatStrategy = PrettyFormatStrategy.newBuilder() - .showThreadInfo(false) // (可选)是否显示线程信息。 默认值为true - .methodCount(2) // (可选)要显示的方法行数。 默认2 - .build(); - Logger.addLogAdapter(new AndroidLogAdapter(formatStrategy) { - @Override - public boolean isLoggable(int priority, String tag) { - return BuildConfig.DEBUG; - } - }); - } - - /** - * 配置OkGo - */ - private void initOkGo() { - - //---------这里给出的是示例代码,告诉你可以这么传,实际使用的时候,根据需要传,不需要就不传-------------// - /*HttpHeaders headers = new HttpHeaders(); - headers.put("commonHeaderKey1", "commonHeaderValue1"); //header不支持中文,不允许有特殊字符 - headers.put("commonHeaderKey2", "commonHeaderValue2"); - HttpParams params = new HttpParams(); - params.put("commonParamsKey1", "commonParamsValue1"); //param支持中文,直接传,不要自己编码 - params.put("commonParamsKey2", "这里支持中文参数");*/ - //----------------------------------------------------------------------------------------// - - OkHttpClient.Builder builder = new OkHttpClient.Builder(); - - //log相关 - HttpLoggingInterceptor loggingInterceptor = new HttpLoggingInterceptor("OkGo"); - //log打印级别,决定了log显示的详细程度 - loggingInterceptor.setPrintLevel(HttpLoggingInterceptor.Level.BODY); - //log颜色级别,决定了log在控制台显示的颜色 - loggingInterceptor.setColorLevel(Level.INFO); - //添加OkGo默认debug日志 - builder.addInterceptor(loggingInterceptor); - - //-------------------------配置超时时间,默认60000ms,60s------------------------------// - //OkGo.DEFAULT_MILLISECONDS - //全局的连接超时时间 - builder.connectTimeout(Constants.CONNECT_TIME_OUT, TimeUnit.MILLISECONDS); - //全局的读取超时时间 - builder.readTimeout(Constants.CONNECT_TIME_OUT, TimeUnit.MILLISECONDS); - //全局的写入超时时间 - builder.writeTimeout(OkGo.DEFAULT_MILLISECONDS, TimeUnit.MILLISECONDS); - - OkGo.getInstance().init(this) //必须调用初始化 - .setOkHttpClient(builder.build()) //建议设置OkHttpClient,不设置将使用默认的 - .setCacheMode(CacheMode.NO_CACHE) //全局统一缓存模式,默认不使用缓存,可以不传 - .setCacheTime(CacheEntity.CACHE_NEVER_EXPIRE) //全局统一缓存时间,默认永不过期,可以不传 - .setRetryCount(3); //全局统一超时重连次数,默认为三次,那么最差的情况会请求4次(一次原始请求,三次重连请求),不需要可以设置为0 - //.addCommonParams(params); //全局公共参数 - - } - - } diff --git a/app/src/main/java/com/bonait/bnframework/business/MainInit.java b/app/src/main/java/com/bonait/bnframework/business/MainInit.java new file mode 100644 index 00000000..67aba115 --- /dev/null +++ b/app/src/main/java/com/bonait/bnframework/business/MainInit.java @@ -0,0 +1,276 @@ +package com.bonait.bnframework.business; + +import android.app.Activity; +import android.app.Application; +import android.util.Log; + +import com.bonait.bnframework.BuildConfig; +import com.bonait.bnframework.common.constant.ConfigName; +import com.bonait.bnframework.common.constant.Constants; +import com.bonait.bnframework.common.constant.DataBus; +import com.bonait.bnframework.common.db.QueryDB; +import com.bonait.bnframework.common.db.file.DBHelper; +import com.bonait.bnframework.common.db.mode.BPA_ALERTLOG; +import com.bonait.bnframework.common.db.mode.BPA_CLOUDDATA; +import com.bonait.bnframework.common.db.mode.BPA_LOG; +import com.bonait.bnframework.common.db.mode.BPA_PLCADDRESS; +import com.bonait.bnframework.common.db.mode.BPA_SILOS; +import com.bonait.bnframework.common.db.mode.BPA_SILOSANDMATERIAL; +import com.bonait.bnframework.common.db.mode.BPA_USER; +import com.bonait.bnframework.common.db.res.AlertLogEnum; +import com.bonait.bnframework.common.db.res.UserLogEnum; +import com.bonait.bnframework.common.helper.CrashHandler; +import com.bonait.bnframework.common.helper.I.IMessageLogNotify; +import com.bonait.bnframework.common.helper.MessageLog; +import com.bonait.bnframework.common.helper.SdCart; +import com.bonait.bnframework.common.notification.MainNotification; +import com.bonait.bnframework.common.utils.AppUtils; +import com.bonait.bnframework.common.utils.PreferenceUtils; +import com.bonait.bnframework.manager.ActivityLifecycleManager; +import com.lzy.okgo.OkGo; +import com.lzy.okgo.cache.CacheEntity; +import com.lzy.okgo.cache.CacheMode; +import com.lzy.okgo.interceptor.HttpLoggingInterceptor; +import com.orhanobut.logger.AndroidLogAdapter; +import com.orhanobut.logger.FormatStrategy; +import com.orhanobut.logger.Logger; +import com.orhanobut.logger.PrettyFormatStrategy; +import com.qmuiteam.qmui.arch.QMUISwipeBackActivityManager; + +import org.litepal.LitePal; + +import java.util.concurrent.TimeUnit; +import java.util.logging.Level; + +import okhttp3.OkHttpClient; + +public class MainInit { + /** + * 初始化 + * @param app + */ + public static void Init(Application app) + { + //0.全局异常捕获,保存为SD卡本级目录 crash + CrashHandler.getInstance().init(app); + + //1.设置程序active,初始化Main函数进程,初始化消息日志 + InitMsgLog(); + + //2.初始化SD卡,数据库DB + SdCart.getInstance().initSD(); + + //4.初始化Main,并且增加本地图片库 + ConfigData.getInstance().AddImage(app); + // activity生命周期管理 + ActivityLifecycleManager.get().init(app); + + // QMUI 框架初始化 + QMUISwipeBackActivityManager.init(app); + + // LitePal 数据库初始化 + LitePal.initialize(app); + + // 全局配置OkGo + initOkGo(app); + + // 配置sharedPreferences + PreferenceUtils.initPreference(app, AppUtils.getAppName(app), Activity.MODE_PRIVATE); + + // 初始化通知栏消息渠道 + MainNotification.initNotificationChannel(app); + + // 内存泄漏检测 + initLeakCanary(false); + + // Log日志打印框架 + initLogCat(); + + // SmartShow Toast框架,暂时不用,先使用ToastUtils工具类的 + //SmartShow.init(this); + + //初始化DB数据 + InitDBdata(); + DataBus.getInstance().GetLc();//获取料仓数据 + ConfigData.getInstance().LoadingCloud();//加载云端数据 + } + + //========================================================================// + /** + * 初始化数据库数据(默认数据) + */ + public static void InitDBdata() { + //1.没有用户数据 默认写一个admin + if (QueryDB.GetUserALL().size() <= 0) { + BPA_USER user = new BPA_USER(); + user.id = "20230415-fyf"; + user.name = "管理员"; + user.account = "admin"; + user.pass = "123456"; + user.deviceID = ConfigName.getInstance().DeviceId; + user.userID = "20230415-fyf"; + user.exp = "管理员"; + QueryDB.AddUser(user); + //10个料仓 + if (QueryDB.GetSilosALL().size() == 0) { + for (int i = 0; i < 5; i++) { + BPA_SILOS silo = new BPA_SILOS(); + silo.id = java.util.UUID.randomUUID().toString(); + silo.num = i + 1; + silo.thrsoleValue=ConfigName.getInstance().SiloAlarmThreshold; + silo.warningValue=ConfigName.getInstance().SiloFeedThreshold; + BPA_SILOSANDMATERIAL sm = new BPA_SILOSANDMATERIAL(); + sm.silosID = silo.id; + sm.materialID = ""; + QueryDB.AddSilos(silo); + QueryDB.AddSilosAndMaterial(sm); + } + } + } + + if(QueryDB.GetPlcaddressALL().size()<=0) + { + ConfigData.getInstance().RevertPLCProcess(); + } + } + /** + * 删除表-重新生成新表 + */ + public static void DBdelete() + { +// DBHelper.getInstance(this).DeleteCreateTables(BPA_CLOUDDATA.class,null); +// DBHelper.getInstance(this).DeleteCreateTables(BPA_PLCADDRESS.class,null); + } + + /** + * 初始化消息日志接收打印 + */ + public static void InitMsgLog(){ + MessageLog.MsgNotify = new IMessageLogNotify() { + @Override + public void ErrorMsg(String msg) { + Log.e("Error", msg); + } + @Override + public void InfoMsg(String msg) { + Log.i("Info", msg); + + } + @Override + public void WarnMsg(String msg) { + Log.w("Warn", msg); + } + @Override + public void UserMsg(UserLogEnum type, String msg) { + BPA_LOG log = new BPA_LOG(); + log.userID = ConfigName.getInstance().user.userID; + switch (type.toString()) + { + case "登录日志":log.type=1; + break; + case "角色操作日志":log.type=2; + break; + case "数据接收":log.type=3; + break; + case "上传日志":log.type=4; + break; + case "订单处理日志":log.type=5; + break; + } + log.text = msg; + QueryDB.Addlog(log); + } + + @Override + public void AlertMsg(AlertLogEnum type, String msg) { + BPA_ALERTLOG log = new BPA_ALERTLOG(); + log.userID = ConfigName.getInstance().user.userID; + switch (type.toString()) + { + case "异常订单未制作日志":log.type=1; + break; + case "料仓缺料日志":log.type=2; + break; + case "传感器异常日志":log.type=3; + break; + case "其他":log.type=4; + break; + } + log.text = msg; + + QueryDB.AddAlertlog(log); + } + }; + } + /** + * 内存泄漏检测,根据flag来判断要不要初始化 + */ + private static void initLeakCanary(boolean flag) { + if (flag) { + // leak 内存检测注册 +// if (LeakCanary.isInAnalyzerProcess(this)) { +// return; +// } +// LeakCanary.install(this); + } + } + + /** + * 初始化log日志框架 + */ + private static void initLogCat() { + FormatStrategy formatStrategy = PrettyFormatStrategy.newBuilder() + .showThreadInfo(false) // (可选)是否显示线程信息。 默认值为true + .methodCount(2) // (可选)要显示的方法行数。 默认2 + .build(); + Logger.addLogAdapter(new AndroidLogAdapter(formatStrategy) { + @Override + public boolean isLoggable(int priority, String tag) { + return BuildConfig.DEBUG; + } + }); + } + + /** + * 配置OkGo + */ + private static void initOkGo(Application app) { + + //---------这里给出的是示例代码,告诉你可以这么传,实际使用的时候,根据需要传,不需要就不传-------------// + /*HttpHeaders headers = new HttpHeaders(); + headers.put("commonHeaderKey1", "commonHeaderValue1"); //header不支持中文,不允许有特殊字符 + headers.put("commonHeaderKey2", "commonHeaderValue2"); + HttpParams params = new HttpParams(); + params.put("commonParamsKey1", "commonParamsValue1"); //param支持中文,直接传,不要自己编码 + params.put("commonParamsKey2", "这里支持中文参数");*/ + //----------------------------------------------------------------------------------------// + + OkHttpClient.Builder builder = new OkHttpClient.Builder(); + + //log相关 + HttpLoggingInterceptor loggingInterceptor = new HttpLoggingInterceptor("OkGo"); + //log打印级别,决定了log显示的详细程度 + loggingInterceptor.setPrintLevel(HttpLoggingInterceptor.Level.BODY); + //log颜色级别,决定了log在控制台显示的颜色 + loggingInterceptor.setColorLevel(Level.INFO); + //添加OkGo默认debug日志 + builder.addInterceptor(loggingInterceptor); + + //-------------------------配置超时时间,默认60000ms,60s------------------------------// + //OkGo.DEFAULT_MILLISECONDS + //全局的连接超时时间 + builder.connectTimeout(Constants.CONNECT_TIME_OUT, TimeUnit.MILLISECONDS); + //全局的读取超时时间 + builder.readTimeout(Constants.CONNECT_TIME_OUT, TimeUnit.MILLISECONDS); + //全局的写入超时时间 + builder.writeTimeout(OkGo.DEFAULT_MILLISECONDS, TimeUnit.MILLISECONDS); + + OkGo.getInstance().init(app) //必须调用初始化 + .setOkHttpClient(builder.build()) //建议设置OkHttpClient,不设置将使用默认的 + .setCacheMode(CacheMode.NO_CACHE) //全局统一缓存模式,默认不使用缓存,可以不传 + .setCacheTime(CacheEntity.CACHE_NEVER_EXPIRE) //全局统一缓存时间,默认永不过期,可以不传 + .setRetryCount(3); //全局统一超时重连次数,默认为三次,那么最差的情况会请求4次(一次原始请求,三次重连请求),不需要可以设置为0 + //.addCommonParams(params); //全局公共参数 + + } +} diff --git a/app/src/main/java/com/bonait/bnframework/common/constant/ConfigName.java b/app/src/main/java/com/bonait/bnframework/common/constant/ConfigName.java index 682de8f7..e47bb40d 100644 --- a/app/src/main/java/com/bonait/bnframework/common/constant/ConfigName.java +++ b/app/src/main/java/com/bonait/bnframework/common/constant/ConfigName.java @@ -1,5 +1,6 @@ package com.bonait.bnframework.common.constant; +import android.app.Application; import android.content.Context; import com.bonait.bnframework.R; @@ -44,6 +45,7 @@ public class ConfigName { //region 程序进入界面 public Context dishesCon; public Context Home; + public Application app; //endregion //region SD卡路径设置 diff --git a/app/src/main/java/com/bonait/bnframework/modules/home/adapter/lc_adapter.java b/app/src/main/java/com/bonait/bnframework/modules/home/adapter/lc_adapter.java index 3871486c..23ed819c 100644 --- a/app/src/main/java/com/bonait/bnframework/modules/home/adapter/lc_adapter.java +++ b/app/src/main/java/com/bonait/bnframework/modules/home/adapter/lc_adapter.java @@ -9,6 +9,7 @@ import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.ImageView; +import android.widget.LinearLayout; import com.bonait.bnframework.R; import com.bonait.bnframework.common.constant.DataBus; @@ -63,16 +64,25 @@ public class lc_adapter extends RecyclerView.Adapter { myViewHolder.add.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { - //按钮点击 - String title = "料仓操作提示!"; - String message = "请问客官确定要将["+lcModes.get(position).materialName+"]加满吗?"; - AlertDialogUtils.showDialog(context, title, message, new QMUIDialogAction.ActionListener() { - @Override - public void onClick(QMUIDialog dialog, int index) { - DataBus.getInstance().TopUp(position); - dialog.dismiss(); - } - }); + show_jm(position); + } + }); + myViewHolder.m_click_layout.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View view) { + show_jm(position); + } + }); + myViewHolder.name.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View view) { + show_jm(position); + } + }); + myViewHolder.type.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View view) { + show_jm(position); } }); } @@ -81,6 +91,24 @@ public class lc_adapter extends RecyclerView.Adapter { } } + /** + * 料仓加满 + * @param index + */ + public void show_jm(int index) + { + //按钮点击 + String title = "料仓操作提示!"; + String message = "请问客官确定要将["+lcModes.get(index).materialName+"]加满吗?"; + AlertDialogUtils.showDialog(context, title, message, new QMUIDialogAction.ActionListener() { + @Override + public void onClick(QMUIDialog dialog, int index) { + DataBus.getInstance().TopUp(index); + dialog.dismiss(); + } + }); + } + private Activity findActivity(@NonNull Context context) { if (context instanceof Activity) { return (Activity) context; @@ -122,12 +150,16 @@ public class lc_adapter extends RecyclerView.Adapter { QMUILinkTextView type;//物料类型 QMUILinkTextView name;//物料名称 QMUILinkTextView bfb;//料仓余量百分比 + + LinearLayout m_click_layout; + public MyLCViewHolder(View view) { super(view); add=view.findViewById(R.id.add); type=view.findViewById(R.id.type); name=view.findViewById(R.id.name); bfb=view.findViewById(R.id.bfb); + m_click_layout=view.findViewById(R.id.m_click_layout); } } } diff --git a/app/src/main/java/com/bonait/bnframework/modules/home/fragment/from/fragment/SystemCsControlFragment.java b/app/src/main/java/com/bonait/bnframework/modules/home/fragment/from/fragment/SystemCsControlFragment.java index 2090ae8b..5137d80d 100644 --- a/app/src/main/java/com/bonait/bnframework/modules/home/fragment/from/fragment/SystemCsControlFragment.java +++ b/app/src/main/java/com/bonait/bnframework/modules/home/fragment/from/fragment/SystemCsControlFragment.java @@ -18,6 +18,8 @@ import com.bonait.bnframework.common.db.mode.BPA_PLCADDRESS; import com.bonait.bnframework.modules.home.fragment.mode.fragment_plc; import com.bonait.bnframework.modules.home.fragment.mode.fragment_plc_control; import com.orhanobut.logger.Logger; +import com.qmuiteam.qmui.widget.QMUILoadingView; +import com.qmuiteam.qmui.widget.dialog.QMUITipDialog; import java.util.ArrayList; @@ -31,6 +33,10 @@ public class SystemCsControlFragment extends BaseFragment { private Context context; @BindView(R.id.plcview) LinearLayout plcview;//工序子集 + + @BindView(R.id.load_view) + QMUILoadingView load_view;//工序子集 + @Override protected View onCreateView() { View root = LayoutInflater.from(getActivity()).inflate(R.layout.fragment_system_cs_control, null); @@ -49,6 +55,7 @@ public class SystemCsControlFragment extends BaseFragment { * 初始化 */ public void Init() { + load_view.setVisibility(View.VISIBLE); plcview.removeAllViews(); ArrayList arrayList = QueryDB.GetPlcaddressALL(); new Thread(new Runnable() { @@ -66,7 +73,8 @@ public class SystemCsControlFragment extends BaseFragment { plcview.addView(gongxu); } } catch (Exception e) { - + }finally { + load_view.setVisibility(View.INVISIBLE); } } }); diff --git a/app/src/main/java/com/bonait/bnframework/modules/home/fragment/from/fragment/SystemCsPLCFragment.java b/app/src/main/java/com/bonait/bnframework/modules/home/fragment/from/fragment/SystemCsPLCFragment.java index 955190f6..1b8f8c0f 100644 --- a/app/src/main/java/com/bonait/bnframework/modules/home/fragment/from/fragment/SystemCsPLCFragment.java +++ b/app/src/main/java/com/bonait/bnframework/modules/home/fragment/from/fragment/SystemCsPLCFragment.java @@ -29,8 +29,10 @@ import com.bonait.bnframework.common.utils.ToastUtils; import com.bonait.bnframework.modules.home.fragment.mode.fragment_gx; import com.bonait.bnframework.modules.home.fragment.mode.fragment_plc; import com.orhanobut.logger.Logger; +import com.qmuiteam.qmui.widget.QMUILoadingView; import com.qmuiteam.qmui.widget.dialog.QMUIDialog; import com.qmuiteam.qmui.widget.dialog.QMUIDialogAction; +import com.qmuiteam.qmui.widget.dialog.QMUITipDialog; import java.util.ArrayList; @@ -41,9 +43,9 @@ import butterknife.OnClick; public class SystemCsPLCFragment extends BaseFragment { @BindView(R.id.plcview) LinearLayout plcview;//工序子集 - private Context context; - + @BindView(R.id.load_view) + QMUILoadingView load_view;//工序子集 @Override protected View onCreateView() { View root = LayoutInflater.from(getActivity()).inflate(R.layout.fragment_system_cs_plc, null); @@ -63,8 +65,12 @@ public class SystemCsPLCFragment extends BaseFragment { * 初始化 */ public void Init() { - plcview.removeAllViews(); - ArrayList arrayList = QueryDB.GetPlcaddressALL(); + load_view.setVisibility(View.VISIBLE); +// QMUITipDialog loadingDialog = new QMUITipDialog.Builder(getActivity()) +// .setIconType(QMUITipDialog.Builder.ICON_TYPE_LOADING) +// .setTipWord("正在加载...") +// .create(); +// loadingDialog.show(); new Thread(new Runnable() { @Override public void run() { @@ -75,12 +81,14 @@ public class SystemCsPLCFragment extends BaseFragment { @Override public void run() { try { + ArrayList arrayList = QueryDB.GetPlcaddressALL(); for (BPA_PLCADDRESS item : arrayList) { fragment_plc gongxu = new fragment_plc(context, null, item); plcview.addView(gongxu); } } catch (Exception e) { - + }finally { + load_view.setVisibility(View.INVISIBLE); } } }); @@ -112,6 +120,7 @@ public class SystemCsPLCFragment extends BaseFragment { AlertDialogUtils.showDialog(context, title, message, new QMUIDialogAction.ActionListener() { @Override public void onClick(QMUIDialog dialog, int index) { + load_view.setVisibility(View.VISIBLE); ConfigData.getInstance().RevertPLCProcess(); Init(); ToastUtils.info("初始化成功!"); diff --git a/app/src/main/java/com/bonait/bnframework/modules/home/fragment/from/fragment/SystemDeviceinFragment.java b/app/src/main/java/com/bonait/bnframework/modules/home/fragment/from/fragment/SystemDeviceinFragment.java index decb7e47..29ede5b6 100644 --- a/app/src/main/java/com/bonait/bnframework/modules/home/fragment/from/fragment/SystemDeviceinFragment.java +++ b/app/src/main/java/com/bonait/bnframework/modules/home/fragment/from/fragment/SystemDeviceinFragment.java @@ -38,8 +38,8 @@ public class SystemDeviceinFragment extends BaseFragment { EditText edittext6; @BindView(R.id.edittext7) EditText edittext7; - @BindView(R.id.image) - ImageView image; +// @BindView(R.id.image) +// ImageView image; private Context context; @Override protected View onCreateView() { @@ -71,10 +71,10 @@ public class SystemDeviceinFragment extends BaseFragment { edittext6.setText(ConfigName.getInstance().organizeMode.id); edittext7.setText(ConfigName.getInstance().organizeMode.store_Name); - if(ConfigName.getInstance().organizeMode.logo!=null) - { - new MyBitmapUtils().disPlay(image,ConfigName.getInstance().organizeMode.logo); - } +// if(ConfigName.getInstance().organizeMode.logo!=null) +// { +// new MyBitmapUtils().disPlay(image,ConfigName.getInstance().organizeMode.logo); +// } }else { edittext1.setText(ConfigName.getInstance().DeviceId); diff --git a/app/src/main/java/com/bonait/bnframework/modules/home/fragment/from/fragment/SystemSeasoningsetFragment.java b/app/src/main/java/com/bonait/bnframework/modules/home/fragment/from/fragment/SystemSeasoningsetFragment.java index 4c3111fa..92a8810a 100644 --- a/app/src/main/java/com/bonait/bnframework/modules/home/fragment/from/fragment/SystemSeasoningsetFragment.java +++ b/app/src/main/java/com/bonait/bnframework/modules/home/fragment/from/fragment/SystemSeasoningsetFragment.java @@ -30,6 +30,7 @@ import com.bonait.bnframework.common.db.mode.BPA_PROCESS; import com.bonait.bnframework.common.db.mode.BPA_SILOSANDMATERIAL; import com.bonait.bnframework.common.db.res.lcMode; import com.bonait.bnframework.common.helper.I.MyClickListener; +import com.bonait.bnframework.common.utils.AlertDialogUtils; import com.bonait.bnframework.common.utils.NetworkUtils; import com.bonait.bnframework.common.utils.ToastUtils; import com.bonait.bnframework.modules.home.adapter.lcsz_adapter; @@ -176,8 +177,18 @@ public class SystemSeasoningsetFragment extends BaseFragment implements MyClickL } break; case R.id.huifuchuchang://恢复出 - ConfigData.getInstance().RevertPLCProcess(); - Initdata_gx(); + String title = "温馨提示!"; + String message = "客官确定要初始化PLC地址吗,小菠萝温馨提示你,此操作将会影响到实际运行哦?"; + AlertDialogUtils.showDialog(context, title, message, new QMUIDialogAction.ActionListener() { + @Override + public void onClick(QMUIDialog dialog, int index) { + ConfigData.getInstance().RevertPLCProcess(); + Initdata_gx(); + ToastUtils.info("恢复出厂设置成功!"); + dialog.dismiss(); + } + }); + break; } diff --git a/app/src/main/java/com/bonait/bnframework/modules/welcome/activity/WelcomeActivity.java b/app/src/main/java/com/bonait/bnframework/modules/welcome/activity/WelcomeActivity.java index 8f90d488..c4734695 100644 --- a/app/src/main/java/com/bonait/bnframework/modules/welcome/activity/WelcomeActivity.java +++ b/app/src/main/java/com/bonait/bnframework/modules/welcome/activity/WelcomeActivity.java @@ -1,18 +1,26 @@ package com.bonait.bnframework.modules.welcome.activity; +import android.Manifest; import android.content.Intent; import android.os.Bundle; import android.os.Handler; + +import androidx.annotation.NonNull; import androidx.appcompat.app.AppCompatActivity; import android.view.KeyEvent; import com.bonait.bnframework.R; +import com.bonait.bnframework.business.MainInit; +import com.bonait.bnframework.common.constant.ConfigName; +import com.bonait.bnframework.common.constant.Constants; import com.bonait.bnframework.manager.ActivityLifecycleManager; import com.bonait.bnframework.modules.home.activity.BottomNavigation2Activity; import com.bonait.bnframework.test.TestActivity; import com.lzy.okgo.OkGo; import okhttp3.OkHttpClient; +import pub.devrel.easypermissions.AfterPermissionGranted; +import pub.devrel.easypermissions.EasyPermissions; public class WelcomeActivity extends AppCompatActivity { @@ -72,13 +80,40 @@ public class WelcomeActivity extends AppCompatActivity { }, 2000); } + /** + * 检查权限是否授权 + */ + public void PermissionCheck() { + + String[] params = {Manifest.permission.WRITE_EXTERNAL_STORAGE, Manifest.permission.RECORD_AUDIO, Manifest.permission.CAMERA}; + //String[] params = {Manifest.permission.WRITE_EXTERNAL_STORAGE}; + //判断是否获取权限 + if (EasyPermissions.hasPermissions(this, params)) { + // 全部权限申请成功后 + //1.直接进入登录界面 + skipToLoginActivity(); + } else { + //未获取权限或拒绝权限时 + EasyPermissions.requestPermissions(this, + "小炒设备需要用到以下权限:\n\n1. 文件读取存储权限\n\n2. 录制视频权限\n\n3. 录制音频权限", + Constants.ALL_PERMISSION, params); + } + } + + @Override + public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { + super.onRequestPermissionsResult(requestCode, permissions, grantResults); + if (requestCode == Constants.ALL_PERMISSION) { + //1.直接进入登录界面 + skipToLoginActivity(); + } + } /** * 请求服务器判断token是否过期 */ private void doPost() { - //1.直接进入登录界面 - skipToLoginActivity(); + PermissionCheck(); // //判断是否用户修改过密码 // boolean isChangePwd = PreferenceUtils.getBoolean(SPConstants.CHANGE_PWD, false); // if (isChangePwd) { @@ -152,6 +187,8 @@ public class WelcomeActivity extends AppCompatActivity { * 跳转到登录页面 * */ private void skipToLoginActivity() { + //初始化 + MainInit.Init(ConfigName.getInstance().app); // 跳转到登录页面 Intent intent = new Intent(WelcomeActivity.this, LoginActivity.class); intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); diff --git a/app/src/main/res/layout/activity_cpxz.xml b/app/src/main/res/layout/activity_cpxz.xml index c8550eb9..bd64dd4c 100644 --- a/app/src/main/res/layout/activity_cpxz.xml +++ b/app/src/main/res/layout/activity_cpxz.xml @@ -29,6 +29,8 @@ android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@drawable/button"/> + + android:layout_width="wrap_content" android:layout_height="wrap_content"> - + android:layout_width="30dp" + android:layout_height="30dp" + android:src="@mipmap/stcp" + android:clickable="false"/> + + + + diff --git a/app/src/main/res/layout/fragment_system_cs_control.xml b/app/src/main/res/layout/fragment_system_cs_control.xml index 626711e7..f08d614a 100644 --- a/app/src/main/res/layout/fragment_system_cs_control.xml +++ b/app/src/main/res/layout/fragment_system_cs_control.xml @@ -5,23 +5,35 @@ android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".modules.home.fragment.from.fragment.SystemCsControlFragment"> - - + - + - - + android:layout_height="match_parent"> + + + - + + + \ No newline at end of file diff --git a/app/src/main/res/layout/fragment_system_cs_plc.xml b/app/src/main/res/layout/fragment_system_cs_plc.xml index b1381b29..3932fa6d 100644 --- a/app/src/main/res/layout/fragment_system_cs_plc.xml +++ b/app/src/main/res/layout/fragment_system_cs_plc.xml @@ -5,39 +5,52 @@ android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".modules.home.fragment.from.fragment.SystemCsPLCFragment"> - - + + android:layout_height="match_parent" + android:orientation="vertical" + android:background="@color/main_background"> + + + + + + android:layout_height="34dp" + android:gravity="center_vertical" + android:orientation="horizontal"> +