From 4e43b5d048edad190b499021a6dc44632843ac97 Mon Sep 17 00:00:00 2001 From: wangh <123456> Date: Wed, 22 Nov 2023 17:28:46 +0800 Subject: [PATCH] =?UTF-8?q?=E5=A2=9E=E5=8A=A0=20-=20=E8=B4=A8=E6=A3=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 15 ++ .idea/.gitignore | 3 + .idea/.name | 1 + .idea/codeStyles | 119 +++++++++++ .idea/compiler.xml | 6 + .idea/dictionaries | 6 + .idea/gradle.xml | 21 ++ .idea/inspectionProfiles/Project_Default.xml | 6 + .idea/misc.xml | 9 + .idea/vcs.xml | 6 + app/.gitignore | 1 + app/build.gradle | 51 +++++ app/proguard-rules.pro | 21 ++ .../aucma_mes/ExampleInstrumentedTest.java | 26 +++ app/src/main/AndroidManifest.xml | 49 +++++ .../example/aucma_mes/BindingActivity.java | 90 +++++++++ .../com/example/aucma_mes/CheckActivity.java | 143 ++++++++++++++ .../example/aucma_mes/HomePageActivity.java | 87 ++++++++ .../com/example/aucma_mes/MainActivity.java | 132 +++++++++++++ .../com/example/aucma_mes/RepairActivity.java | 19 ++ .../aucma_mes/adapter/CheckAdapter.java | 88 +++++++++ .../example/aucma_mes/base/BaseActivity.java | 59 ++++++ .../example/aucma_mes/base/MyApplication.java | 71 +++++++ .../example/aucma_mes/dialog/InfoDialog.java | 38 ++++ .../example/aucma_mes/entity/DefectBeen.java | 43 ++++ .../example/aucma_mes/entity/DictBeen.java | 26 +++ .../example/aucma_mes/entity/LoginBack.java | 47 +++++ .../aucma_mes/entity/LoginInfoBeen.java | 67 +++++++ .../com/example/aucma_mes/entity/Result.java | 43 ++++ .../example/aucma_mes/utils/MyRecultCall.java | 52 +++++ .../utils/SharedPreferencesUtils.java | 86 ++++++++ .../example/aucma_mes/vm/CheckViewModel.java | 111 +++++++++++ .../java/com/example/aucma_mes/vm/User.java | 70 +++++++ app/src/main/res/anim/dialog_in.xml | 7 + app/src/main/res/anim/dialog_out.xml | 11 ++ app/src/main/res/drawable/button_true.xml | 7 + app/src/main/res/drawable/button_w.xml | 7 + app/src/main/res/drawable/dialog_bg.xml | 5 + app/src/main/res/drawable/home_bg.xml | 16 ++ .../res/drawable/ic_launcher_background.xml | 170 ++++++++++++++++ .../res/drawable/ic_launcher_foreground.xml | 30 +++ app/src/main/res/drawable/san_text_bg.xml | 6 + app/src/main/res/drawable/text_bg.xml | 5 + app/src/main/res/drawable/title_bg.xml | 5 + app/src/main/res/layout-land/dialog_info.xml | 15 ++ app/src/main/res/layout/activity_binding.xml | 99 ++++++++++ app/src/main/res/layout/activity_check.xml | 140 +++++++++++++ .../main/res/layout/activity_home_page.xml | 79 ++++++++ app/src/main/res/layout/activity_main.xml | 106 ++++++++++ app/src/main/res/layout/activity_repair.xml | 110 +++++++++++ app/src/main/res/layout/dialog_info.xml | 159 +++++++++++++++ app/src/main/res/layout/item_layout.xml | 62 ++++++ .../res/mipmap-anydpi-v26/ic_launcher.xml | 6 + .../mipmap-anydpi-v26/ic_launcher_round.xml | 6 + app/src/main/res/mipmap-hdpi/ic_launcher.webp | Bin 0 -> 1404 bytes .../res/mipmap-hdpi/ic_launcher_round.webp | Bin 0 -> 2898 bytes app/src/main/res/mipmap-mdpi/ic_launcher.webp | Bin 0 -> 982 bytes .../res/mipmap-mdpi/ic_launcher_round.webp | Bin 0 -> 1772 bytes .../main/res/mipmap-xhdpi/ic_launcher.webp | Bin 0 -> 1900 bytes .../res/mipmap-xhdpi/ic_launcher_round.webp | Bin 0 -> 3918 bytes app/src/main/res/mipmap-xhdpi/icon_back.png | Bin 0 -> 1089 bytes app/src/main/res/mipmap-xhdpi/icon_bd.png | Bin 0 -> 2526 bytes app/src/main/res/mipmap-xhdpi/icon_bd2.png | Bin 0 -> 2522 bytes app/src/main/res/mipmap-xhdpi/icon_check.png | Bin 0 -> 2620 bytes app/src/main/res/mipmap-xhdpi/icon_fx.png | Bin 0 -> 2832 bytes app/src/main/res/mipmap-xhdpi/icon_info.png | Bin 0 -> 3103 bytes app/src/main/res/mipmap-xhdpi/icon_select.png | Bin 0 -> 466 bytes app/src/main/res/mipmap-xhdpi/logo2.png | Bin 0 -> 59345 bytes .../main/res/mipmap-xxhdpi/ic_launcher.webp | Bin 0 -> 2884 bytes .../res/mipmap-xxhdpi/ic_launcher_round.webp | Bin 0 -> 5914 bytes .../main/res/mipmap-xxxhdpi/ic_launcher.webp | Bin 0 -> 3844 bytes .../res/mipmap-xxxhdpi/ic_launcher_round.webp | Bin 0 -> 7778 bytes app/src/main/res/values-land/dimens.xml | 3 + app/src/main/res/values-night/themes.xml | 16 ++ app/src/main/res/values-w1240dp/dimens.xml | 3 + app/src/main/res/values-w600dp/dimens.xml | 3 + app/src/main/res/values/arrays.xml | 13 ++ app/src/main/res/values/colors.xml | 14 ++ app/src/main/res/values/dimens.xml | 5 + app/src/main/res/values/strings.xml | 12 ++ app/src/main/res/values/themes.xml | 89 +++++++++ app/src/main/res/xml/backup_rules.xml | 13 ++ .../main/res/xml/data_extraction_rules.xml | 19 ++ .../example/aucma_mes/ExampleUnitTest.java | 17 ++ build.gradle | 4 + gradle.properties | 21 ++ gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 59203 bytes gradle/wrapper/gradle-wrapper.properties | 6 + gradlew | 185 ++++++++++++++++++ gradlew.bat | 89 +++++++++ settings.gradle | 31 +++ 91 files changed, 3206 insertions(+) create mode 100644 .gitignore create mode 100644 .idea/.gitignore create mode 100644 .idea/.name create mode 100644 .idea/codeStyles create mode 100644 .idea/compiler.xml create mode 100644 .idea/dictionaries create mode 100644 .idea/gradle.xml create mode 100644 .idea/inspectionProfiles/Project_Default.xml create mode 100644 .idea/misc.xml create mode 100644 .idea/vcs.xml create mode 100644 app/.gitignore create mode 100644 app/build.gradle create mode 100644 app/proguard-rules.pro create mode 100644 app/src/androidTest/java/com/example/aucma_mes/ExampleInstrumentedTest.java create mode 100644 app/src/main/AndroidManifest.xml create mode 100644 app/src/main/java/com/example/aucma_mes/BindingActivity.java create mode 100644 app/src/main/java/com/example/aucma_mes/CheckActivity.java create mode 100644 app/src/main/java/com/example/aucma_mes/HomePageActivity.java create mode 100644 app/src/main/java/com/example/aucma_mes/MainActivity.java create mode 100644 app/src/main/java/com/example/aucma_mes/RepairActivity.java create mode 100644 app/src/main/java/com/example/aucma_mes/adapter/CheckAdapter.java create mode 100644 app/src/main/java/com/example/aucma_mes/base/BaseActivity.java create mode 100644 app/src/main/java/com/example/aucma_mes/base/MyApplication.java create mode 100644 app/src/main/java/com/example/aucma_mes/dialog/InfoDialog.java create mode 100644 app/src/main/java/com/example/aucma_mes/entity/DefectBeen.java create mode 100644 app/src/main/java/com/example/aucma_mes/entity/DictBeen.java create mode 100644 app/src/main/java/com/example/aucma_mes/entity/LoginBack.java create mode 100644 app/src/main/java/com/example/aucma_mes/entity/LoginInfoBeen.java create mode 100644 app/src/main/java/com/example/aucma_mes/entity/Result.java create mode 100644 app/src/main/java/com/example/aucma_mes/utils/MyRecultCall.java create mode 100644 app/src/main/java/com/example/aucma_mes/utils/SharedPreferencesUtils.java create mode 100644 app/src/main/java/com/example/aucma_mes/vm/CheckViewModel.java create mode 100644 app/src/main/java/com/example/aucma_mes/vm/User.java create mode 100644 app/src/main/res/anim/dialog_in.xml create mode 100644 app/src/main/res/anim/dialog_out.xml create mode 100644 app/src/main/res/drawable/button_true.xml create mode 100644 app/src/main/res/drawable/button_w.xml create mode 100644 app/src/main/res/drawable/dialog_bg.xml create mode 100644 app/src/main/res/drawable/home_bg.xml create mode 100644 app/src/main/res/drawable/ic_launcher_background.xml create mode 100644 app/src/main/res/drawable/ic_launcher_foreground.xml create mode 100644 app/src/main/res/drawable/san_text_bg.xml create mode 100644 app/src/main/res/drawable/text_bg.xml create mode 100644 app/src/main/res/drawable/title_bg.xml create mode 100644 app/src/main/res/layout-land/dialog_info.xml create mode 100644 app/src/main/res/layout/activity_binding.xml create mode 100644 app/src/main/res/layout/activity_check.xml create mode 100644 app/src/main/res/layout/activity_home_page.xml create mode 100644 app/src/main/res/layout/activity_main.xml create mode 100644 app/src/main/res/layout/activity_repair.xml create mode 100644 app/src/main/res/layout/dialog_info.xml create mode 100644 app/src/main/res/layout/item_layout.xml create mode 100644 app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml create mode 100644 app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml create mode 100644 app/src/main/res/mipmap-hdpi/ic_launcher.webp create mode 100644 app/src/main/res/mipmap-hdpi/ic_launcher_round.webp create mode 100644 app/src/main/res/mipmap-mdpi/ic_launcher.webp create mode 100644 app/src/main/res/mipmap-mdpi/ic_launcher_round.webp create mode 100644 app/src/main/res/mipmap-xhdpi/ic_launcher.webp create mode 100644 app/src/main/res/mipmap-xhdpi/ic_launcher_round.webp create mode 100644 app/src/main/res/mipmap-xhdpi/icon_back.png create mode 100644 app/src/main/res/mipmap-xhdpi/icon_bd.png create mode 100644 app/src/main/res/mipmap-xhdpi/icon_bd2.png create mode 100644 app/src/main/res/mipmap-xhdpi/icon_check.png create mode 100644 app/src/main/res/mipmap-xhdpi/icon_fx.png create mode 100644 app/src/main/res/mipmap-xhdpi/icon_info.png create mode 100644 app/src/main/res/mipmap-xhdpi/icon_select.png create mode 100644 app/src/main/res/mipmap-xhdpi/logo2.png create mode 100644 app/src/main/res/mipmap-xxhdpi/ic_launcher.webp create mode 100644 app/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp create mode 100644 app/src/main/res/mipmap-xxxhdpi/ic_launcher.webp create mode 100644 app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp create mode 100644 app/src/main/res/values-land/dimens.xml create mode 100644 app/src/main/res/values-night/themes.xml create mode 100644 app/src/main/res/values-w1240dp/dimens.xml create mode 100644 app/src/main/res/values-w600dp/dimens.xml create mode 100644 app/src/main/res/values/arrays.xml create mode 100644 app/src/main/res/values/colors.xml create mode 100644 app/src/main/res/values/dimens.xml create mode 100644 app/src/main/res/values/strings.xml create mode 100644 app/src/main/res/values/themes.xml create mode 100644 app/src/main/res/xml/backup_rules.xml create mode 100644 app/src/main/res/xml/data_extraction_rules.xml create mode 100644 app/src/test/java/com/example/aucma_mes/ExampleUnitTest.java create mode 100644 build.gradle create mode 100644 gradle.properties create mode 100644 gradle/wrapper/gradle-wrapper.jar create mode 100644 gradle/wrapper/gradle-wrapper.properties create mode 100644 gradlew create mode 100644 gradlew.bat create mode 100644 settings.gradle diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..aa724b7 --- /dev/null +++ b/.gitignore @@ -0,0 +1,15 @@ +*.iml +.gradle +/local.properties +/.idea/caches +/.idea/libraries +/.idea/modules.xml +/.idea/workspace.xml +/.idea/navEditor.xml +/.idea/assetWizardSettings.xml +.DS_Store +/build +/captures +.externalNativeBuild +.cxx +local.properties diff --git a/.idea/.gitignore b/.idea/.gitignore new file mode 100644 index 0000000..26d3352 --- /dev/null +++ b/.idea/.gitignore @@ -0,0 +1,3 @@ +# Default ignored files +/shelf/ +/workspace.xml diff --git a/.idea/.name b/.idea/.name new file mode 100644 index 0000000..5d6df20 --- /dev/null +++ b/.idea/.name @@ -0,0 +1 @@ +aucma-mes \ No newline at end of file diff --git a/.idea/codeStyles b/.idea/codeStyles new file mode 100644 index 0000000..e2e415d --- /dev/null +++ b/.idea/codeStyles @@ -0,0 +1,119 @@ + + + + + + + + + +
+ + + + xmlns:android + + ^$ + + + +
+
+ + + + xmlns:.* + + ^$ + + + BY_NAME + +
+
+ + + + .*:id + + http://schemas.android.com/apk/res/android + + + +
+
+ + + + .*:name + + http://schemas.android.com/apk/res/android + + + +
+
+ + + + name + + ^$ + + + +
+
+ + + + style + + ^$ + + + +
+
+ + + + .* + + ^$ + + + BY_NAME + +
+
+ + + + .* + + http://schemas.android.com/apk/res/android + + + ANDROID_ATTRIBUTE_ORDER + +
+
+ + + + .* + + .* + + + BY_NAME + +
+
+
+
+
+
+
\ No newline at end of file diff --git a/.idea/compiler.xml b/.idea/compiler.xml new file mode 100644 index 0000000..b589d56 --- /dev/null +++ b/.idea/compiler.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/.idea/dictionaries b/.idea/dictionaries new file mode 100644 index 0000000..58d4f30 --- /dev/null +++ b/.idea/dictionaries @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/.idea/gradle.xml b/.idea/gradle.xml new file mode 100644 index 0000000..0c51b85 --- /dev/null +++ b/.idea/gradle.xml @@ -0,0 +1,21 @@ + + + + + + + \ No newline at end of file diff --git a/.idea/inspectionProfiles/Project_Default.xml b/.idea/inspectionProfiles/Project_Default.xml new file mode 100644 index 0000000..0bf205c --- /dev/null +++ b/.idea/inspectionProfiles/Project_Default.xml @@ -0,0 +1,6 @@ + + + + \ No newline at end of file diff --git a/.idea/misc.xml b/.idea/misc.xml new file mode 100644 index 0000000..d7916a5 --- /dev/null +++ b/.idea/misc.xml @@ -0,0 +1,9 @@ + + + + + + + + \ No newline at end of file diff --git a/.idea/vcs.xml b/.idea/vcs.xml new file mode 100644 index 0000000..94a25f7 --- /dev/null +++ b/.idea/vcs.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/app/.gitignore b/app/.gitignore new file mode 100644 index 0000000..42afabf --- /dev/null +++ b/app/.gitignore @@ -0,0 +1 @@ +/build \ No newline at end of file diff --git a/app/build.gradle b/app/build.gradle new file mode 100644 index 0000000..e9b977d --- /dev/null +++ b/app/build.gradle @@ -0,0 +1,51 @@ +plugins { + id 'com.android.application' +} + +android { + namespace 'com.example.aucma_mes' + compileSdk 33 + + defaultConfig { + applicationId "com.example.aucma_mes" + minSdk 24 + targetSdk 33 + versionCode 1 + versionName "1.0" + + testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" + } + + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro' + } + } + buildFeatures { + viewBinding true + dataBinding true + } + compileOptions { + targetCompatibility JavaVersion.VERSION_11 + sourceCompatibility JavaVersion.VERSION_11 + } +} + +dependencies { + implementation(platform("org.jetbrains.kotlin:kotlin-bom:1.8.0")) + implementation 'androidx.appcompat:appcompat:1.6.1' + implementation 'com.google.android.material:material:1.8.0' + implementation 'androidx.constraintlayout:constraintlayout:2.1.4' + implementation 'androidx.annotation:annotation:1.6.0' + implementation 'androidx.lifecycle:lifecycle-livedata-ktx:2.6.1' + implementation 'androidx.lifecycle:lifecycle-viewmodel-ktx:2.6.1' + implementation 'androidx.gridlayout:gridlayout:1.0.0' + testImplementation 'junit:junit:4.13.2' + androidTestImplementation 'androidx.test.ext:junit:1.1.5' + androidTestImplementation 'androidx.test.espresso:espresso-core:3.5.1' + implementation 'com.lzy.net:okgo:3.0.4' + // https://mvnrepository.com/artifact/com.google.code.gson/gson + implementation 'com.google.code.gson:gson:2.10.1' + +} \ No newline at end of file diff --git a/app/proguard-rules.pro b/app/proguard-rules.pro new file mode 100644 index 0000000..481bb43 --- /dev/null +++ b/app/proguard-rules.pro @@ -0,0 +1,21 @@ +# Add project specific ProGuard rules here. +# You can control the set of applied configuration files using the +# proguardFiles setting in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# If your project uses WebView with JS, uncomment the following +# and specify the fully qualified class name to the JavaScript interface +# class: +#-keepclassmembers class fqcn.of.javascript.interface.for.webview { +# public *; +#} + +# Uncomment this to preserve the line number information for +# debugging stack traces. +#-keepattributes SourceFile,LineNumberTable + +# If you keep the line number information, uncomment this to +# hide the original source file name. +#-renamesourcefileattribute SourceFile \ No newline at end of file diff --git a/app/src/androidTest/java/com/example/aucma_mes/ExampleInstrumentedTest.java b/app/src/androidTest/java/com/example/aucma_mes/ExampleInstrumentedTest.java new file mode 100644 index 0000000..622ddaf --- /dev/null +++ b/app/src/androidTest/java/com/example/aucma_mes/ExampleInstrumentedTest.java @@ -0,0 +1,26 @@ +package com.example.aucma_mes; + +import android.content.Context; + +import androidx.test.platform.app.InstrumentationRegistry; +import androidx.test.ext.junit.runners.AndroidJUnit4; + +import org.junit.Test; +import org.junit.runner.RunWith; + +import static org.junit.Assert.*; + +/** + * Instrumented test, which will execute on an Android device. + * + * @see Testing documentation + */ +@RunWith(AndroidJUnit4.class) +public class ExampleInstrumentedTest { + @Test + public void useAppContext() { + // Context of the app under test. + Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext(); + assertEquals("com.example.aucma_mes", appContext.getPackageName()); + } +} \ No newline at end of file diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000..c5226a3 --- /dev/null +++ b/app/src/main/AndroidManifest.xml @@ -0,0 +1,49 @@ + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/java/com/example/aucma_mes/BindingActivity.java b/app/src/main/java/com/example/aucma_mes/BindingActivity.java new file mode 100644 index 0000000..0308f56 --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/BindingActivity.java @@ -0,0 +1,90 @@ +package com.example.aucma_mes; + +import androidx.databinding.DataBindingUtil; +import androidx.databinding.ObservableField; + +import android.os.Bundle; +import android.util.Log; +import android.view.View; +import android.widget.Toast; + +import com.example.aucma_mes.base.BaseActivity; +import com.example.aucma_mes.databinding.ActivityBindingBinding; +import com.example.aucma_mes.entity.Result; +import com.example.aucma_mes.utils.SharedPreferencesUtils; +import com.lzy.okgo.OkGo; +import com.lzy.okgo.callback.StringCallback; +import com.lzy.okgo.model.Response; + +public class BindingActivity extends BaseActivity { + + public ObservableField boxCode; + public ObservableField innerCode; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + ActivityBindingBinding binding = DataBindingUtil.setContentView(this, R.layout.activity_binding); + boxCode = new ObservableField<>(); + innerCode = new ObservableField<>(); + binding.setTest(this); + binding.button2.setOnClickListener(t -> { + boxCode.set(null); + innerCode.set(null); + }); + + + } + + @Override + protected void sanInfo(String code) { + Log.e("TAG", "sanInfo:" + code); + if (boxCode.get() == null) { + boxCode.set(code); + } else { + innerCode.set(code); + } + + + } + + + public void click1(View view) { + if (boxCode.get() == null || innerCode.get() == null) return; + + dialog.show(); + OkGo.post(url + "/api/boxBanding") + .tag(this) + .headers("Authorization",SharedPreferencesUtils.getstring("token","")) + .params("boxCode", boxCode.get()) + .params("innerCode", innerCode.get()) + .params("loginName", SharedPreferencesUtils.getstring("loginName", "")) + .execute(new StringCallback() { + @Override + public void onSuccess(Response response) { + dialog.dismiss(); + + Result result = gson.fromJson(response.body(), Result.class); + if (result.getCode() == 200) { + Toast.makeText(BindingActivity.this, "绑定成功", Toast.LENGTH_SHORT).show(); + boxCode.set(""); + innerCode.set(""); + } else { + Toast.makeText(BindingActivity.this, result.getMsg(), Toast.LENGTH_SHORT).show(); + } + } + + @Override + public void onError(Response response) { + super.onError(response); + Toast.makeText(BindingActivity.this, "网路连接错误", Toast.LENGTH_SHORT).show(); + } + }); + } + + public void click2(View view) { + + boxCode.set(null); + innerCode.set(null); + } +} \ No newline at end of file diff --git a/app/src/main/java/com/example/aucma_mes/CheckActivity.java b/app/src/main/java/com/example/aucma_mes/CheckActivity.java new file mode 100644 index 0000000..dfa359e --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/CheckActivity.java @@ -0,0 +1,143 @@ +package com.example.aucma_mes; + +import androidx.appcompat.app.AppCompatActivity; +import androidx.databinding.DataBindingUtil; + +import android.os.Bundle; +import android.util.Log; +import android.view.View; +import android.widget.AdapterView; +import android.widget.ArrayAdapter; +import android.widget.ListPopupWindow; +import android.widget.Spinner; +import android.widget.Toast; + +import com.example.aucma_mes.adapter.CheckAdapter; +import com.example.aucma_mes.base.BaseActivity; +import com.example.aucma_mes.databinding.ActivityCheckBinding; +import com.example.aucma_mes.entity.DefectBeen; +import com.example.aucma_mes.entity.DictBeen; +import com.example.aucma_mes.entity.Result; +import com.example.aucma_mes.utils.MyRecultCall; +import com.example.aucma_mes.utils.SharedPreferencesUtils; +import com.example.aucma_mes.vm.CheckViewModel; +import com.google.gson.reflect.TypeToken; +import com.lzy.okgo.OkGo; +import com.lzy.okgo.callback.StringCallback; +import com.lzy.okgo.model.Response; +import com.lzy.okgo.request.base.Request; + +import java.util.ArrayList; +import java.util.List; + +import okhttp3.RequestBody; + +public class CheckActivity extends BaseActivity implements CheckAdapter.CheckItemClickCall, AdapterView.OnItemClickListener { + private ActivityCheckBinding binding; + private CheckViewModel checkViewModel; + + private ListPopupWindow listPopupWindow; + private CheckAdapter checkAdapter; + private List list; + private List submitList; + private List defectBeens; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + binding = DataBindingUtil.setContentView(this, R.layout.activity_check); + checkViewModel = new CheckViewModel(); + binding.setVm(checkViewModel); + + checkAdapter = new CheckAdapter(this, this); + submitList = new ArrayList<>(); + checkAdapter.setList(submitList); + binding.recyclerView.setAdapter(checkAdapter); + listPopupWindow = new ListPopupWindow(this); + listPopupWindow.setAnchorView(binding.selectDefect); + listPopupWindow.setOnItemClickListener(this); + String stationCode = getIntent().getStringExtra("stationCode"); + /* OkGo.get(url + "/base/qualityInspectionItem/getQualityDefects/" + stationCode).tag(this).headers("Authorization", SharedPreferencesUtils.getstring("token", "")).execute(new MyRecultCall(dialog, this) { + @Override + public void onSuccess(Response response) { + super.onSuccess(response); + Result body = response.body(); + Log.e("TAG", "onSuccess:" + body.toString()); + if (body.getCode() == 200) { + Toast.makeText(CheckActivity.this, "请求成功", Toast.LENGTH_SHORT).show(); + list = gson.fromJson(body.getData().toString(), new TypeToken>() { + }.getType()); + defectBeens = new ArrayList<>(list.size()); + + list.stream().forEach(t -> defectBeens.add(t.qualityDefectName)); + listPopupWindow.setAdapter(new ArrayAdapter(CheckActivity.this, androidx.appcompat.R.layout.support_simple_spinner_dropdown_item, defectBeens)); + } else { + Toast.makeText(CheckActivity.this, body.getMsg(), Toast.LENGTH_SHORT).show(); + } + } + + }); + */ OkGo.get(url + "/system/dict/data/type/treatment_measures").tag(this) + .headers("Authorization", SharedPreferencesUtils.getstring("token", "")) + .execute(new MyRecultCall(dialog, this) { + @Override + public void onSuccess(Response response) { + super.onSuccess(response); + Result body = response.body(); + List dictBeenList = gson.fromJson(gson.toJson(body.getData()), + new TypeToken>() {}.getType()); + + checkViewModel.setDictBeenList(dictBeenList); + } + + }); + } + + @Override + protected void sanInfo(String code) { + checkViewModel.setCode(code); + } + + public void checkSelect(View view) { + listPopupWindow.show(); + } + + public void checkSubmint(View view) { + String s = binding.checkSpinner1.getSelectedItem().toString(); + if (s.equals("返修") && submitList.isEmpty()) { + return; + } + checkViewModel.setMeasure(s); + String s1 = binding.checkSpinner2.getSelectedItem().toString(); + checkViewModel.setOffline(s1); + checkViewModel.setList(submitList); + checkViewModel.setUserName(SharedPreferencesUtils.getstring("userName", "pda01")); + OkGo.post(url + "/api/checkSubmit").tag(this).headers("Authorization", SharedPreferencesUtils.getstring("token", "")).upRequestBody(RequestBody.create(JSON, gson.toJson(checkViewModel))).execute(new MyRecultCall(dialog, this) { + @Override + public void onSuccess(Response response) { + super.onSuccess(response); + + } + }); + } + + @Override + public void onClick(int positon) { + Log.e("TAG", "列表点击:" + positon); + submitList.remove(positon); + checkAdapter.notifyDataSetChanged(); + } + + @Override + public void onItemClick(AdapterView parent, View view, int position, long id) { + checkViewModel.setDefect(defectBeens.get(position)); + DefectBeen defectBeen = list.get(position); + if (submitList.contains(defectBeen)) { + Toast.makeText(this, "已经添加了", Toast.LENGTH_SHORT).show(); + return; + } + submitList.add(defectBeen); + checkAdapter.notifyDataSetChanged(); + listPopupWindow.dismiss(); + } +} \ No newline at end of file diff --git a/app/src/main/java/com/example/aucma_mes/HomePageActivity.java b/app/src/main/java/com/example/aucma_mes/HomePageActivity.java new file mode 100644 index 0000000..d72859d --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/HomePageActivity.java @@ -0,0 +1,87 @@ +package com.example.aucma_mes; + +import androidx.activity.result.contract.ActivityResultContracts; +import androidx.appcompat.app.AppCompatActivity; +import androidx.databinding.DataBindingUtil; + +import android.content.Intent; +import android.os.Bundle; +import android.util.Log; +import android.view.View; +import android.widget.Toast; + +import com.example.aucma_mes.databinding.ActivityHomePageBinding; +import com.example.aucma_mes.dialog.InfoDialog; +import com.example.aucma_mes.entity.LoginInfoBeen; +import com.example.aucma_mes.vm.User; +import com.google.gson.Gson; +import com.google.gson.JsonObject; + +import java.util.ArrayList; + +public class HomePageActivity extends AppCompatActivity { + ActivityHomePageBinding binding; + private Intent intent; + private ArrayList roles; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + binding = DataBindingUtil.setContentView(this, R.layout.activity_home_page); + getSupportActionBar().hide(); + Intent intent1 = getIntent(); + roles = intent1.getStringArrayListExtra("role"); + String json=intent1.getStringExtra("info"); + LoginInfoBeen infoBeen=new Gson().fromJson(json, LoginInfoBeen.class); + Log.e("TAG", "onCreate:" + infoBeen); + InfoDialog infoDialog=new InfoDialog(this); + String stationCode = null; + try { + User user = infoBeen.getUser(); + + stationCode = user.getStationCode(); + infoDialog.setInfoData(infoBeen, user); + }catch (Exception e){ + + } + + + String finalStationCode = stationCode; + binding.homeButton1.setOnClickListener(v -> { +// if (!roles.contains("quality_inspection")) { +// Toast.makeText(this, "暂无权限", Toast.LENGTH_SHORT).show(); +// return; +// } + intent = new Intent(this, CheckActivity.class); + intent.putExtra("stationCode", "1006"); + startActivity(intent); + }); + binding.homeButton2.setOnClickListener(v -> { + if (!roles.contains("shell_bile_binding")) { + Toast.makeText(this, "暂无权限", Toast.LENGTH_SHORT).show(); + return; + } + intent = new Intent(this, BindingActivity.class); + intent.putExtra("title", "壳胆绑定"); + startActivity(intent); + }); + binding.homeButton3.setOnClickListener(v -> { + if (!roles.contains("quality_repair")) { + Toast.makeText(this, "暂无权限", Toast.LENGTH_SHORT).show(); + return; + } + }); + binding.homeButton4.setOnClickListener(v -> { + if (!roles.contains("barcode_binding")) { + Toast.makeText(this, "暂无权限", Toast.LENGTH_SHORT).show(); + return; + } + }); + binding.homeButton5.setOnClickListener(v -> { + infoDialog.show(); + }); + + } + + +} \ No newline at end of file diff --git a/app/src/main/java/com/example/aucma_mes/MainActivity.java b/app/src/main/java/com/example/aucma_mes/MainActivity.java new file mode 100644 index 0000000..833384c --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/MainActivity.java @@ -0,0 +1,132 @@ +package com.example.aucma_mes; + +import androidx.appcompat.app.AppCompatActivity; +import androidx.databinding.DataBindingComponent; +import androidx.databinding.DataBindingUtil; +import androidx.databinding.ViewDataBinding; + +import android.content.Context; +import android.content.Intent; +import android.net.wifi.WifiInfo; +import android.net.wifi.WifiManager; +import android.os.Bundle; +import android.util.Log; +import android.view.View; +import android.widget.Toast; + +import com.example.aucma_mes.base.BaseActivity; +import com.example.aucma_mes.databinding.ActivityMainBinding; +import com.example.aucma_mes.entity.LoginBack; +import com.example.aucma_mes.utils.SharedPreferencesUtils; +import com.example.aucma_mes.vm.User; +import com.google.gson.Gson; +import com.lzy.okgo.OkGo; +import com.lzy.okgo.callback.StringCallback; +import com.lzy.okgo.model.Response; + +import java.net.NetworkInterface; +import java.util.Collections; +import java.util.List; + +import okhttp3.MediaType; +import okhttp3.RequestBody; + +public class MainActivity extends BaseActivity { + + private User user; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + ActivityMainBinding binding = DataBindingUtil.setContentView(this, R.layout.activity_main); + user=new User(); + user.setUsername("pda01"); + user.setPassword("aucma@123"); + getSupportActionBar().hide(); // 隐藏原生标题栏 + binding.setUser(user); + Toast.makeText(this, getMacAddress()+"可以使用", Toast.LENGTH_SHORT).show(); + } + + @Override + protected void sanInfo(String code) { + + } + public String getMacAddress() { + try { + List interfaces = Collections.list(NetworkInterface.getNetworkInterfaces()); + for (NetworkInterface intf : interfaces) { + if (intf.getName().equalsIgnoreCase("wlan0")) { + byte[] mac = intf.getHardwareAddress(); + if (mac == null) { + return ""; + } + StringBuilder buf = new StringBuilder(); + for (byte aMac : mac) { + buf.append(String.format("%02X:", aMac)); + } + if (buf.length() > 0) { + buf.deleteCharAt(buf.length() - 1); + } + return buf.toString(); + } + } + } catch (Exception e) { + e.printStackTrace(); + } + return "02:00:00:00:00:00"; // 如果无法获取到有效的MAC地址,返回一个默认值 + } + public void login(View view) { + dialog.show(); + MediaType JSON = MediaType.parse("application/json; charset=utf-8"); + RequestBody body = RequestBody.create(JSON,gson.toJson(user) ); + OkGo.post(BaseActivity.url + "/login") + .tag(this) + .upRequestBody(body) + .execute(new StringCallback() { + @Override + public void onSuccess(Response response) { + LoginBack loginBack=gson.fromJson(response.body(),LoginBack.class); + + if (loginBack.getCode()==200){ + getUserInfo(loginBack.getToken()); + }else { + dialog.dismiss(); + Toast.makeText(MainActivity.this, loginBack.getMsg(), Toast.LENGTH_SHORT).show(); + } + } + + @Override + public void onError(Response response) { + super.onError(response); + dialog.dismiss(); + Toast.makeText(MainActivity.this, "网络错误", Toast.LENGTH_SHORT).show(); + } + }); + + + } + private void getUserInfo(String token){ + OkGo.get(BaseActivity.url + "/getInfo") + .tag(this) + .headers("Authorization",token) + .execute(new StringCallback() { + @Override + public void onSuccess(Response response) { + dialog.dismiss(); + String body = response.body(); + LoginBack loginBack=gson.fromJson(body,LoginBack.class); + if (loginBack.getCode()==200){ + Intent intent = new Intent(MainActivity.this, HomePageActivity.class); + intent.putExtra("role",loginBack.getRoles()); + intent.putExtra("info",body); + SharedPreferencesUtils.putstring("loginName",user.username); + SharedPreferencesUtils.putstring("token",token); + startActivity(intent); + finish(); + }else { + Toast.makeText(MainActivity.this, loginBack.getMsg(), Toast.LENGTH_SHORT).show(); + } + } + }); + } +} \ No newline at end of file diff --git a/app/src/main/java/com/example/aucma_mes/RepairActivity.java b/app/src/main/java/com/example/aucma_mes/RepairActivity.java new file mode 100644 index 0000000..8758230 --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/RepairActivity.java @@ -0,0 +1,19 @@ +package com.example.aucma_mes; + +import androidx.appcompat.app.AppCompatActivity; +import androidx.databinding.DataBindingUtil; + +import android.os.Bundle; + +import com.example.aucma_mes.databinding.ActivityMainBinding; +import com.example.aucma_mes.databinding.ActivityRepairBinding; + +public class RepairActivity extends AppCompatActivity { + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + ActivityRepairBinding binding = DataBindingUtil.setContentView(this, R.layout.activity_repair); + + } +} \ No newline at end of file diff --git a/app/src/main/java/com/example/aucma_mes/adapter/CheckAdapter.java b/app/src/main/java/com/example/aucma_mes/adapter/CheckAdapter.java new file mode 100644 index 0000000..4027583 --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/adapter/CheckAdapter.java @@ -0,0 +1,88 @@ +package com.example.aucma_mes.adapter; + +import android.content.Context; +import android.net.wifi.WifiInfo; +import android.net.wifi.WifiManager; +import android.view.LayoutInflater; +import android.view.View; +import android.view.ViewGroup; +import android.widget.Adapter; + +import androidx.annotation.NonNull; +import androidx.databinding.DataBindingUtil; +import androidx.databinding.ViewDataBinding; +import androidx.recyclerview.widget.RecyclerView; + +import com.example.aucma_mes.BR; +import com.example.aucma_mes.R; +import com.example.aucma_mes.databinding.ItemLayoutBinding; +import com.example.aucma_mes.entity.DefectBeen; + +import java.util.List; +import java.util.zip.Inflater; + +/** + * @author wanghao + * @date 2023/11/17 17:15 + */ +public class CheckAdapter extends RecyclerView.Adapter { + private Context context; + private List list; + private LayoutInflater from; + private CheckItemClickCall checkItemClickCall; + + public CheckAdapter(Context context, CheckItemClickCall checkItemClickCall) { + this.context = context; + this.checkItemClickCall = checkItemClickCall; + from = LayoutInflater.from(context); + } + + public void setList(List list) { + this.list = list; + } + + @NonNull + @Override + public CheckAdapterVH onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { + ItemLayoutBinding inflate1 = DataBindingUtil.inflate(from, R.layout.item_layout, parent, false); + return new CheckAdapterVH(inflate1); + } + + @Override + public void onBindViewHolder(@NonNull CheckAdapterVH holder, int position) { + DefectBeen defectBeen = list.get(position); + defectBeen.setIndex(position + 1); + ItemLayoutBinding databing = holder.getInflate1(); + databing.setVariable(BR.item, defectBeen); + databing.itemButtom.setOnClickListener(t -> { + checkItemClickCall.onClick(position); + }); + + databing.executePendingBindings(); + } + + @Override + public int getItemCount() { + return list == null ? 0 : list.size(); + } + + class CheckAdapterVH extends RecyclerView.ViewHolder { + private ItemLayoutBinding inflate1; + + public ItemLayoutBinding getInflate1() { + return inflate1; + } + + public CheckAdapterVH(ItemLayoutBinding inflate1) { + super(inflate1.getRoot()); + this.inflate1 = inflate1; + } + + + } + + public interface CheckItemClickCall { + void onClick(int positon); + } + +} diff --git a/app/src/main/java/com/example/aucma_mes/base/BaseActivity.java b/app/src/main/java/com/example/aucma_mes/base/BaseActivity.java new file mode 100644 index 0000000..e63b770 --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/base/BaseActivity.java @@ -0,0 +1,59 @@ +package com.example.aucma_mes.base; + +import androidx.appcompat.app.AppCompatActivity; + +import android.annotation.SuppressLint; +import android.app.ProgressDialog; +import android.content.BroadcastReceiver; +import android.content.Context; +import android.content.Intent; +import android.content.IntentFilter; +import android.os.Bundle; +import android.util.Log; +import android.view.Window; + +import com.example.aucma_mes.R; +import com.google.gson.Gson; + +import okhttp3.MediaType; + +public abstract class BaseActivity extends AppCompatActivity { + private MyBroad receiver; + public static String url="http://172.20.10.2:8080"; + public ProgressDialog dialog; + public Gson gson; + public MediaType JSON = MediaType.parse("application/json; charset=utf-8"); + @SuppressLint("UnspecifiedRegisterReceiverFlag") + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + IntentFilter intentFilter = new IntentFilter("com.honeywell.scan.broadcast"); + receiver = new MyBroad(); + registerReceiver(receiver,intentFilter); + gson=new Gson(); + initDialog(); + } + + private void initDialog() { + dialog = new ProgressDialog(this); + dialog.requestWindowFeature(Window.FEATURE_NO_TITLE); + dialog.setCanceledOnTouchOutside(false); + dialog.setProgressStyle(ProgressDialog.STYLE_SPINNER); + dialog.setMessage("请求网络..."); + } + + protected abstract void sanInfo(String code); + @Override + protected void onDestroy() { + super.onDestroy(); + // 注销广播接收器 + unregisterReceiver(receiver); + } + private class MyBroad extends BroadcastReceiver{ + + @Override + public void onReceive(Context context, Intent intent) { + sanInfo(intent.getStringExtra("data")) ; + } + } +} \ No newline at end of file diff --git a/app/src/main/java/com/example/aucma_mes/base/MyApplication.java b/app/src/main/java/com/example/aucma_mes/base/MyApplication.java new file mode 100644 index 0000000..7316c63 --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/base/MyApplication.java @@ -0,0 +1,71 @@ +package com.example.aucma_mes.base; + +import android.app.Application; +import android.util.Log; +import android.widget.Toast; + +import com.example.aucma_mes.utils.SharedPreferencesUtils; +import com.lzy.okgo.OkGo; +import com.lzy.okgo.cache.CacheEntity; +import com.lzy.okgo.cache.CacheMode; +import com.lzy.okgo.cookie.CookieJarImpl; +import com.lzy.okgo.cookie.store.MemoryCookieStore; +import com.lzy.okgo.https.HttpsUtils; +import com.lzy.okgo.interceptor.HttpLoggingInterceptor; + +import java.util.concurrent.TimeUnit; +import java.util.logging.Level; + +import okhttp3.OkHttpClient; + + + +/** + * @author: wangh + * @description: + * @date: 2019/06/11-13:01 + */ +public class MyApplication extends Application { + + MyApplication application; + + @Override + public void onCreate() { + super.onCreate(); + application = this; + SharedPreferencesUtils.init(getApplicationContext(), "myapp"); + okGoBase(); + + } + + + //OKGO 初始化 + private void okGoBase() { + OkHttpClient.Builder builder = new OkHttpClient.Builder(); + HttpLoggingInterceptor loggingInterceptor = new HttpLoggingInterceptor("OkGo"); + //log打印级别,决定了log显示的详细程度 + loggingInterceptor.setPrintLevel(HttpLoggingInterceptor.Level.BODY); + //log颜色级别,决定了log在控制台显示的颜色 + loggingInterceptor.setColorLevel(Level.SEVERE); + //方法一:信任所有证书,不安全有风险 + HttpsUtils.SSLParams sslParams1 = HttpsUtils.getSslSocketFactory(); + builder.sslSocketFactory(sslParams1.sSLSocketFactory, sslParams1.trustManager); + + builder.addInterceptor(loggingInterceptor); +//全局的读取超时时间 + builder.readTimeout(OkGo.DEFAULT_MILLISECONDS, TimeUnit.MILLISECONDS); +//全局的写入超时时间 + builder.writeTimeout(OkGo.DEFAULT_MILLISECONDS, TimeUnit.MILLISECONDS); +//全局的连接超时时间 + builder.connectTimeout(OkGo.DEFAULT_MILLISECONDS, TimeUnit.MILLISECONDS); + //使用内存保持cookie,app退出后,cookie消失 + builder.cookieJar(new CookieJarImpl(new MemoryCookieStore())); + OkGo.getInstance().init(this).setOkHttpClient(builder.build()) //建议设置OkHttpClient,不设置将使用默认的 + .setCacheMode(CacheMode.NO_CACHE) //全局统一缓存模式,默认不使用缓存,可以不传 + .setCacheTime(CacheEntity.CACHE_NEVER_EXPIRE) //全局统一缓存时间,默认永不过期,可以不传 + .setRetryCount(3); + + + } + +} diff --git a/app/src/main/java/com/example/aucma_mes/dialog/InfoDialog.java b/app/src/main/java/com/example/aucma_mes/dialog/InfoDialog.java new file mode 100644 index 0000000..a3d1e30 --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/dialog/InfoDialog.java @@ -0,0 +1,38 @@ +package com.example.aucma_mes.dialog; + +import android.app.Dialog; +import android.content.Context; +import android.view.LayoutInflater; + +import androidx.annotation.NonNull; +import androidx.databinding.DataBindingUtil; +import androidx.fragment.app.DialogFragment; + +import com.example.aucma_mes.R; +import com.example.aucma_mes.databinding.DialogInfoBinding; +import com.example.aucma_mes.entity.LoginInfoBeen; +import com.example.aucma_mes.vm.User; + +/** + * @author wanghao + * @date 2023/11/16 14:42 + */ +public class InfoDialog extends Dialog { + + private DialogInfoBinding binding; + public InfoDialog(@NonNull Context context) { + super(context,R.style.dialog); + binding = DataBindingUtil.inflate(LayoutInflater.from(context), + R.layout. dialog_info, null, false); + setContentView(binding.getRoot()); + assert binding.dialogButton != null; + binding.dialogButton.setOnClickListener(t-> dismiss()); + } + + public void setInfoData(LoginInfoBeen infoBeen,User user) { + binding.setUser(user); + binding.setBeen(infoBeen); + } + + +} diff --git a/app/src/main/java/com/example/aucma_mes/entity/DefectBeen.java b/app/src/main/java/com/example/aucma_mes/entity/DefectBeen.java new file mode 100644 index 0000000..2423a4e --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/entity/DefectBeen.java @@ -0,0 +1,43 @@ +package com.example.aucma_mes.entity; + +import androidx.databinding.BaseObservable; + +import java.util.Objects; + +/** + * @author wanghao + * @date 2023/11/17 17:00 + */ +public class DefectBeen extends BaseObservable { + public int index; + public String qualityDefectCode; + public String qualityDefectName; + + private String stationCode;//检测项编号 TEST_ITEM_CODE + public void setIndex(int index) { + this.index = index; + } + + public String getStationCode() { + return stationCode; + } + + public void setStationCode(String stationCode) { + this.stationCode = stationCode; + } + + @Override + public boolean equals(Object o) { + if (this == o) return true; + if (o == null || getClass() != o.getClass()) return false; + + DefectBeen that = (DefectBeen) o; + + return Objects.equals(qualityDefectName, that.qualityDefectName); + } + + @Override + public int hashCode() { + return qualityDefectName != null ? qualityDefectName.hashCode() : 0; + } +} diff --git a/app/src/main/java/com/example/aucma_mes/entity/DictBeen.java b/app/src/main/java/com/example/aucma_mes/entity/DictBeen.java new file mode 100644 index 0000000..d8f4d81 --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/entity/DictBeen.java @@ -0,0 +1,26 @@ +package com.example.aucma_mes.entity; + +/** + * @author wanghao + * @date 2023/11/22 16:16 + */ +public class DictBeen { + public String dictLabel; + public String dictValue; + + public String getDictLabel() { + return dictLabel; + } + + public void setDictLabel(String dictLabel) { + this.dictLabel = dictLabel; + } + + public String getDictValue() { + return dictValue; + } + + public void setDictValue(String dictValue) { + this.dictValue = dictValue; + } +} diff --git a/app/src/main/java/com/example/aucma_mes/entity/LoginBack.java b/app/src/main/java/com/example/aucma_mes/entity/LoginBack.java new file mode 100644 index 0000000..467d4cc --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/entity/LoginBack.java @@ -0,0 +1,47 @@ +package com.example.aucma_mes.entity; + +import java.util.ArrayList; +import java.util.List; + +/** + * @author wanghao + * @date 2023/11/15 10:17 + */ +public class LoginBack { + private String msg; + private int code; + private String token; + private ArrayList roles; + + public ArrayList getRoles() { + return roles; + } + + public void setRoles(ArrayList roles) { + this.roles = roles; + } + + public String getMsg() { + return msg; + } + + public void setMsg(String msg) { + this.msg = msg; + } + + public int getCode() { + return code; + } + + public void setCode(int code) { + this.code = code; + } + + public String getToken() { + return token; + } + + public void setToken(String token) { + this.token = token; + } +} diff --git a/app/src/main/java/com/example/aucma_mes/entity/LoginInfoBeen.java b/app/src/main/java/com/example/aucma_mes/entity/LoginInfoBeen.java new file mode 100644 index 0000000..29985a0 --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/entity/LoginInfoBeen.java @@ -0,0 +1,67 @@ +package com.example.aucma_mes.entity; + +import com.example.aucma_mes.vm.User; + +/** + * @author wanghao + * @date 2023/11/16 14:29 + */ +public class LoginInfoBeen { + + public String companyCode; + public String factoryCode; + public String companyName; + public String factoryName; + public User user; + + public String getCompanyCode() { + return companyCode; + } + + public void setCompanyCode(String companyCode) { + this.companyCode = companyCode; + } + + public String getFactoryCode() { + return factoryCode; + } + + public void setFactoryCode(String factoryCode) { + this.factoryCode = factoryCode; + } + + public String getCompanyName() { + return companyName; + } + + public void setCompanyName(String companyName) { + this.companyName = companyName; + } + + public String getFactoryName() { + return factoryName; + } + + public void setFactoryName(String factoryName) { + this.factoryName = factoryName; + } + + public User getUser() { + return user; + } + + public void setUser(User user) { + this.user = user; + } + + @Override + public String toString() { + return "LoginInfoBeen{" + + "companyCode='" + companyCode + '\'' + + ", factoryCode='" + factoryCode + '\'' + + ", companyName='" + companyName + '\'' + + ", factoryName='" + factoryName + '\'' + + ", user=" + user.toString() + + '}'; + } +} diff --git a/app/src/main/java/com/example/aucma_mes/entity/Result.java b/app/src/main/java/com/example/aucma_mes/entity/Result.java new file mode 100644 index 0000000..92faa85 --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/entity/Result.java @@ -0,0 +1,43 @@ +package com.example.aucma_mes.entity; + +/** + * @author wanghao + * @date 2023/11/17 14:42 + */ +public class Result { + private int code; + private String msg; + private Object data; + + public int getCode() { + return code; + } + + public void setCode(int code) { + this.code = code; + } + + public String getMsg() { + return msg; + } + + public void setMsg(String msg) { + this.msg = msg; + } + + public Object getData() { + return data; + } + + public void setData(Object data) { + this.data = data; + } + + @Override + public String toString() { + return "Result{" + + "code=" + code + + ", msg='" + msg + '\'' + + '}'; + } +} diff --git a/app/src/main/java/com/example/aucma_mes/utils/MyRecultCall.java b/app/src/main/java/com/example/aucma_mes/utils/MyRecultCall.java new file mode 100644 index 0000000..96eba36 --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/utils/MyRecultCall.java @@ -0,0 +1,52 @@ +package com.example.aucma_mes.utils; + +import android.app.ProgressDialog; +import android.content.Context; + +import com.example.aucma_mes.entity.Result; +import com.google.gson.Gson; +import com.lzy.okgo.callback.AbsCallback; +import com.lzy.okgo.model.Response; +import com.lzy.okgo.request.base.Request; + +import okhttp3.ResponseBody; + +/** + * @author wanghao + * @date 2023/11/20 14:27 + */ +public class MyRecultCall extends AbsCallback { + private ProgressDialog dialog; + private Context context; + + public MyRecultCall(ProgressDialog dialog, Context context) { + this.dialog = dialog; + this.context = context; + } + + @Override + public Result convertResponse(okhttp3.Response response) throws Throwable { + ResponseBody body = response.body(); + if (body == null) return null; + + Result resust =new Gson().fromJson(body.string(), Result.class); + return resust; + } + + @Override + public void onSuccess(Response response) { + dialog.dismiss(); + } + + @Override + public void onError(Response response) { + super.onError(response); + dialog.dismiss(); + } + + @Override + public void onStart(Request request) { + super.onStart(request); + dialog.show(); + } +} diff --git a/app/src/main/java/com/example/aucma_mes/utils/SharedPreferencesUtils.java b/app/src/main/java/com/example/aucma_mes/utils/SharedPreferencesUtils.java new file mode 100644 index 0000000..7da9453 --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/utils/SharedPreferencesUtils.java @@ -0,0 +1,86 @@ +package com.example.aucma_mes.utils; + +import android.content.Context; +import android.content.SharedPreferences; + +/** + * Created by wang 18/7/5 + */ + +public class SharedPreferencesUtils { + private static SharedPreferences sharedPreferences; + private static SharedPreferences.Editor edit; + + public static void init(Context context, String name) { + sharedPreferences = context.getSharedPreferences(name, context.MODE_PRIVATE); + edit = sharedPreferences.edit(); + edit.commit(); + } + + public static void putstring(String key, String value) { + if (edit != null) { + edit.putString(key, value); + edit.commit(); + } + } + public static void putInt(String key, int value) { + if (edit != null) { + edit.putInt(key, value); + edit.commit(); + } + } + + public static int getInt(String key, int value) { + if (sharedPreferences != null) { + return sharedPreferences.getInt(key,value); + } + return 0; + } + + + public static void putboolean(String key, boolean value) { + if (edit != null) { + edit.putBoolean(key, value); + edit.commit(); + } + } + + /** + * 取得方法 + */ + + public static String getstring(String key, String deaflut) { + if (sharedPreferences != null) { + return sharedPreferences.getString(key, deaflut); + } + return ""; + } + + public static boolean getboolean(String key, boolean aaa) { + if (sharedPreferences != null) { + boolean aBoolean = sharedPreferences.getBoolean(key, aaa); + return aBoolean; + } + return false; + } + + /** + * remo + */ + public static void removeKey(String key) { + if (edit != null) { + edit.remove(key); + edit.commit(); + } + } + public static void Clean() { + //清空数据 + try { + edit.clear(); + edit.commit(); + }catch (Exception e){ + e.printStackTrace(); + } + + } +} diff --git a/app/src/main/java/com/example/aucma_mes/vm/CheckViewModel.java b/app/src/main/java/com/example/aucma_mes/vm/CheckViewModel.java new file mode 100644 index 0000000..c5ab0ee --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/vm/CheckViewModel.java @@ -0,0 +1,111 @@ +package com.example.aucma_mes.vm; + +import android.view.View; +import android.widget.AdapterView; + +import androidx.databinding.BaseObservable; +import androidx.lifecycle.MutableLiveData; + +import com.example.aucma_mes.entity.DefectBeen; +import com.example.aucma_mes.entity.DictBeen; + +import java.util.ArrayList; +import java.util.List; + +/** + * @author wanghao + * @date 2023/11/17 16:26 + */ +public class CheckViewModel extends BaseObservable { + public String code;//产品条码 + public String defect; + public List stringList; + private List list;//缺陷列表 + + private String measure;//处理措施TREATMENT_MEASURE + + private String offline; + private String processCode; + private String userName; + + public List dictBeenList; + + + public List getDictBeenList() { + return dictBeenList; + } + + + + public void setDictBeenList(List dictBeenList) { + this.dictBeenList = dictBeenList; + stringList=new ArrayList<>(dictBeenList.size()); + dictBeenList.forEach(t->stringList.add(t.getDictLabel())); + notifyChange(); + } + + public String getProcessCode() { + return processCode; + } + + public void setProcessCode(String processCode) { + this.processCode = processCode; + } + + public String getUserName() { + return userName; + } + + public void setUserName(String userName) { + this.userName = userName; + } + + + public String getMeasure() { + return measure; + } + + public void setMeasure(String measure) { + this.measure =dictBeenList.get(stringList.indexOf(measure)).getDictValue() ; + } + + public String getOffline() { + return offline; + } + + public void setOffline(String offline) { + if (offline.equals("是")) { + this.offline = "Y"; + } else { + this.offline = "N"; + } + + } + + public String getCode() { + return code; + } + + public String getDefect() { + return defect; + } + + public List getList() { + return list; + } + + public void setList(List list) { + this.list = list; + } + + public void setCode(String code) { + this.code = code; + notifyChange(); + } + + public void setDefect(String defect) { + this.defect = defect; + notifyChange(); + } + +} diff --git a/app/src/main/java/com/example/aucma_mes/vm/User.java b/app/src/main/java/com/example/aucma_mes/vm/User.java new file mode 100644 index 0000000..a03e2cf --- /dev/null +++ b/app/src/main/java/com/example/aucma_mes/vm/User.java @@ -0,0 +1,70 @@ +package com.example.aucma_mes.vm; + +import androidx.databinding.BaseObservable; +import androidx.databinding.Bindable; + +/** + * @author wanghao + * @date 2023/11/15 9:45 + */ +public class User extends BaseObservable { + @Bindable + public String username; + @Bindable + public String password; + + public String nickName; + public String stationCode; + public String stationName; + + public String getUsername() { + return username; + } + + public void setUsername(String username) { + this.username = username; + } + + public String getPassword() { + return password; + } + + public void setPassword(String password) { + this.password = password; + } + + public String getNickName() { + return nickName; + } + + public void setNickName(String nickName) { + this.nickName = nickName; + } + + public String getStationCode() { + return stationCode; + } + + public void setStationCode(String stationCode) { + this.stationCode = stationCode; + } + + public String getStationName() { + return stationName; + } + + public void setStationName(String stationName) { + this.stationName = stationName; + } + + @Override + public String toString() { + return "User{" + + "username='" + username + '\'' + + ", password='" + password + '\'' + + ", nickName='" + nickName + '\'' + + ", stationCode='" + stationCode + '\'' + + ", stationName='" + stationName + '\'' + + '}'; + } +} diff --git a/app/src/main/res/anim/dialog_in.xml b/app/src/main/res/anim/dialog_in.xml new file mode 100644 index 0000000..893368c --- /dev/null +++ b/app/src/main/res/anim/dialog_in.xml @@ -0,0 +1,7 @@ + + + + \ No newline at end of file diff --git a/app/src/main/res/anim/dialog_out.xml b/app/src/main/res/anim/dialog_out.xml new file mode 100644 index 0000000..17de545 --- /dev/null +++ b/app/src/main/res/anim/dialog_out.xml @@ -0,0 +1,11 @@ + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/button_true.xml b/app/src/main/res/drawable/button_true.xml new file mode 100644 index 0000000..f685f3a --- /dev/null +++ b/app/src/main/res/drawable/button_true.xml @@ -0,0 +1,7 @@ + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/button_w.xml b/app/src/main/res/drawable/button_w.xml new file mode 100644 index 0000000..4769877 --- /dev/null +++ b/app/src/main/res/drawable/button_w.xml @@ -0,0 +1,7 @@ + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/dialog_bg.xml b/app/src/main/res/drawable/dialog_bg.xml new file mode 100644 index 0000000..682ba6c --- /dev/null +++ b/app/src/main/res/drawable/dialog_bg.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/home_bg.xml b/app/src/main/res/drawable/home_bg.xml new file mode 100644 index 0000000..0c06eec --- /dev/null +++ b/app/src/main/res/drawable/home_bg.xml @@ -0,0 +1,16 @@ + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/ic_launcher_background.xml b/app/src/main/res/drawable/ic_launcher_background.xml new file mode 100644 index 0000000..07d5da9 --- /dev/null +++ b/app/src/main/res/drawable/ic_launcher_background.xml @@ -0,0 +1,170 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/app/src/main/res/drawable/ic_launcher_foreground.xml b/app/src/main/res/drawable/ic_launcher_foreground.xml new file mode 100644 index 0000000..2b068d1 --- /dev/null +++ b/app/src/main/res/drawable/ic_launcher_foreground.xml @@ -0,0 +1,30 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/san_text_bg.xml b/app/src/main/res/drawable/san_text_bg.xml new file mode 100644 index 0000000..25671e0 --- /dev/null +++ b/app/src/main/res/drawable/san_text_bg.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/text_bg.xml b/app/src/main/res/drawable/text_bg.xml new file mode 100644 index 0000000..4632687 --- /dev/null +++ b/app/src/main/res/drawable/text_bg.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/title_bg.xml b/app/src/main/res/drawable/title_bg.xml new file mode 100644 index 0000000..4c55680 --- /dev/null +++ b/app/src/main/res/drawable/title_bg.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout-land/dialog_info.xml b/app/src/main/res/layout-land/dialog_info.xml new file mode 100644 index 0000000..bb96e18 --- /dev/null +++ b/app/src/main/res/layout-land/dialog_info.xml @@ -0,0 +1,15 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/activity_binding.xml b/app/src/main/res/layout/activity_binding.xml new file mode 100644 index 0000000..627c3f8 --- /dev/null +++ b/app/src/main/res/layout/activity_binding.xml @@ -0,0 +1,99 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +