commit fbcb4d5c4c465e14462668af9b299d28adb7f9fe Author: wangh <123456> Date: Thu May 16 16:21:59 2024 +0800 增加 写入界面 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..ce25527 --- /dev/null +++ b/.idea/.name @@ -0,0 +1 @@ +JinYu-RFID \ 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..abe205d --- /dev/null +++ b/.idea/gradle.xml @@ -0,0 +1,22 @@ + + + + + + + \ No newline at end of file diff --git a/.idea/misc.xml b/.idea/misc.xml new file mode 100644 index 0000000..f85ddd4 --- /dev/null +++ b/.idea/misc.xml @@ -0,0 +1,8 @@ + + + + + + + \ 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..c101ac0 --- /dev/null +++ b/app/build.gradle @@ -0,0 +1,51 @@ +plugins { + id 'com.android.application' +} + +android { + namespace 'com.example.jinyu_rfid' + compileSdk 33 + + defaultConfig { + applicationId "com.example.jinyu_rfid" + 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 { + sourceCompatibility JavaVersion.VERSION_11 + targetCompatibility 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 files('libs\\ModuleAPI_J.jar') + implementation files('libs\\uhfr_v1.8.jar') + 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.google.code.gson:gson:2.10.1' + // https://mvnrepository.com/artifact/com.lzy.net/okgo + implementation 'com.lzy.net:okgo:3.0.4' + implementation 'org.litepal.guolindev:core:3.2.3' + + +} \ No newline at end of file diff --git a/app/libs/ModuleAPI_J.jar b/app/libs/ModuleAPI_J.jar new file mode 100644 index 0000000..b231d74 Binary files /dev/null and b/app/libs/ModuleAPI_J.jar differ diff --git a/app/libs/uhfr_v1.8.jar b/app/libs/uhfr_v1.8.jar new file mode 100644 index 0000000..44c1a70 Binary files /dev/null and b/app/libs/uhfr_v1.8.jar differ 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/jinyu_rfid/ExampleInstrumentedTest.java b/app/src/androidTest/java/com/example/jinyu_rfid/ExampleInstrumentedTest.java new file mode 100644 index 0000000..b10a543 --- /dev/null +++ b/app/src/androidTest/java/com/example/jinyu_rfid/ExampleInstrumentedTest.java @@ -0,0 +1,26 @@ +package com.example.jinyu_rfid; + +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.jinyu_rfid", 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..1274ecf --- /dev/null +++ b/app/src/main/AndroidManifest.xml @@ -0,0 +1,39 @@ + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/assets/litepal.xml b/app/src/main/assets/litepal.xml new file mode 100644 index 0000000..066cab4 --- /dev/null +++ b/app/src/main/assets/litepal.xml @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/java/com/example/jinyu_rfid/ConfigurationTableActivity.java b/app/src/main/java/com/example/jinyu_rfid/ConfigurationTableActivity.java new file mode 100644 index 0000000..b3f4834 --- /dev/null +++ b/app/src/main/java/com/example/jinyu_rfid/ConfigurationTableActivity.java @@ -0,0 +1,19 @@ +package com.example.jinyu_rfid; + +import androidx.appcompat.app.AppCompatActivity; +import androidx.databinding.DataBindingUtil; + +import android.os.Bundle; + +import com.example.jinyu_rfid.base.BaseActivity; +import com.example.jinyu_rfid.databinding.ActivityConfigurationTableBinding; + +public class ConfigurationTableActivity extends BaseActivity { + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + ActivityConfigurationTableBinding binding=DataBindingUtil. setContentView(this,R.layout.activity_configuration_table); + binding.setTitle(getString(R.string.activity_name_configuration)); + } +} \ No newline at end of file diff --git a/app/src/main/java/com/example/jinyu_rfid/MainActivity.java b/app/src/main/java/com/example/jinyu_rfid/MainActivity.java new file mode 100644 index 0000000..0e29350 --- /dev/null +++ b/app/src/main/java/com/example/jinyu_rfid/MainActivity.java @@ -0,0 +1,101 @@ +package com.example.jinyu_rfid; + +import android.content.Intent; +import android.content.res.Configuration; +import android.content.res.Resources; +import android.os.Bundle; +import android.util.DisplayMetrics; +import android.util.Log; +import android.view.View; + +import androidx.databinding.DataBindingUtil; + + +import com.example.jinyu_rfid.base.BaseActivity; +import com.example.jinyu_rfid.base.MyRecultCall; +import com.example.jinyu_rfid.base.MyResult; +import com.example.jinyu_rfid.databinding.ActivityMainBinding; +import com.example.jinyu_rfid.uitls.SharedPreferencesUtils; +import com.example.jinyu_rfid.been.LoginVm; +import com.lzy.okgo.OkGo; +import com.lzy.okgo.model.Response; + +import java.util.HashMap; +import java.util.Locale; +import java.util.Map; + +import okhttp3.RequestBody; + +public class MainActivity extends BaseActivity { + private LoginVm loginVm; + private ActivityMainBinding binding; + + private Resources resources; + private Configuration config; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + resources = getResources(); + config = resources.getConfiguration(); + config.locale = SharedPreferencesUtils.getstring("language","English").equals("中文") ? Locale.CHINA : Locale.ENGLISH; + resources.updateConfiguration(config, resources.getDisplayMetrics()); + binding = DataBindingUtil.setContentView(this, R.layout.activity_main); + + loginVm = new LoginVm(); + boolean isRemember = SharedPreferencesUtils.getboolean("isRemember", false); + if (isRemember) { + loginVm.setUsername(SharedPreferencesUtils.getstring("user", "")); + loginVm.setPassword(SharedPreferencesUtils.getstring("pass", "")); + loginVm.setRemember(isRemember); + } + binding.setUser(loginVm); + + + } + + + @Override + public void sanCodeCall(String code) { + + } + + public void login_click(View view) { + String pass = loginVm.getPassword(); + String name = loginVm.getUsername(); + var selectLanguage = binding.mainLanguage.getSelectedItem().toString(); + config.locale = selectLanguage.equals("中文") ? Locale.CHINA : Locale.ENGLISH; + SharedPreferencesUtils.putstring("language", selectLanguage); + resources.updateConfiguration(config, resources.getDisplayMetrics()); + // this.recreate(); + // Intent intent = new Intent(MainActivity.this, ConfigurationTableActivity.class); + Intent intent = new Intent(MainActivity.this, WriteUserActivity.class); + startActivity(intent); + finish(); + /* if (pass == null || name == null || pass.isEmpty() || name.isEmpty()) return; + OkGo.post(url+"/auth/pdaLogin") + .upRequestBody(RequestBody.create(JSON, gson.toJson(loginVm))) + .execute(new MyRecultCall(dialog, this) { + @Override + public void onSuccess(Response response) { + super.onSuccess(response); + var body = response.body(); + if (body.getCode() == 200) { + // String accessToken = JSONObject.parseObject(body.getData().toString()).get("access_token").toString(); + // Log.e("TAG", "onSuccess:" + accessToken); + // SharedPreferencesUtils.putstring("access_token",accessToken); + boolean remember = loginVm.isRemember(); + if (remember) { + SharedPreferencesUtils.putboolean("isRemember", remember); + SharedPreferencesUtils.putstring("user", name); + SharedPreferencesUtils.putstring("pass", pass); + } + Intent intent=new Intent(MainActivity.this, HomePageActivity.class); + intent.putExtra("json",response.body()); + startActivity(intent); + finish(); + } + } + });*/ + } +} diff --git a/app/src/main/java/com/example/jinyu_rfid/WriteUserActivity.java b/app/src/main/java/com/example/jinyu_rfid/WriteUserActivity.java new file mode 100644 index 0000000..5fcbcd5 --- /dev/null +++ b/app/src/main/java/com/example/jinyu_rfid/WriteUserActivity.java @@ -0,0 +1,66 @@ +package com.example.jinyu_rfid; + +import androidx.appcompat.app.AppCompatActivity; +import androidx.databinding.DataBindingUtil; + +import android.content.Intent; +import android.os.Bundle; +import android.view.View; + +import com.example.jinyu_rfid.base.BaseActivity; +import com.example.jinyu_rfid.callback.DataReturnCall; +import com.example.jinyu_rfid.databinding.ActivityWriteUserBinding; +import com.example.jinyu_rfid.rfid.C5106Device; +import com.example.jinyu_rfid.rfid.RFIDModel; +import com.lzy.okgo.OkGo; + +public class WriteUserActivity extends BaseActivity implements DataReturnCall { + private Intent intent1; + private Intent intent2; + private RFIDModel rfidModel; + private ActivityWriteUserBinding binding; + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + binding = DataBindingUtil.setContentView(this, R.layout.activity_write_user); + binding.setTitle(getString(R.string.activity_name_configuration)); + + rfidModel=new C5106Device(); + rfidModel.openModel(); + intent1=new Intent(this, ConfigurationTableActivity.class); + intent2=new Intent(this, ConfigurationTableActivity.class); + } + + + public void writeReadEPC(View view){ + + } + public void writeUser(View view){ + + } + + + + public void writeGoRead(View view){ + startActivity(intent1); + } + public void writeGoConfiguration(View view){ + startActivity(intent2); + } + + @Override + public void readEpcCodeInfo(String epc) { + binding.writeEpcCode.setText(epc); + } + + @Override + public void readUserInfo(String user) { + + } + + @Override + public void readerCodeInfo(String erCode) { + binding.writeTire.setText(erCode); + // OkGo.post(url+"/") + } +} \ No newline at end of file diff --git a/app/src/main/java/com/example/jinyu_rfid/base/BaseActivity.java b/app/src/main/java/com/example/jinyu_rfid/base/BaseActivity.java new file mode 100644 index 0000000..21acb2a --- /dev/null +++ b/app/src/main/java/com/example/jinyu_rfid/base/BaseActivity.java @@ -0,0 +1,105 @@ +package com.example.jinyu_rfid.base; + +import android.Manifest; +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.content.pm.PackageManager; +import android.graphics.Bitmap; +import android.graphics.BitmapFactory; +import android.net.Uri; +import android.os.Build; +import android.os.Bundle; +import android.provider.MediaStore; +import android.util.Log; +import android.view.View; +import android.view.Window; + +import androidx.appcompat.app.AppCompatActivity; +import androidx.core.app.ActivityCompat; +import androidx.core.content.ContextCompat; +import androidx.core.content.FileProvider; + +import com.google.gson.Gson; + +import java.io.ByteArrayOutputStream; +import java.io.File; +import java.io.FileNotFoundException; +import java.io.FileOutputStream; +import java.io.IOException; +import java.text.SimpleDateFormat; +import java.util.Date; + +import okhttp3.MediaType; + + +public class BaseActivity extends AppCompatActivity { + + public static final int CAMERA_PHOTO = 1; + public static String url = "http://175.27.215.92:7018/prod-api"; + // public static String url = "http://10.11.40.120:7018/dev-api"; + public ProgressDialog dialog; + public Gson gson; + public MediaType JSON = MediaType.parse("application/json; charset=utf-8"); + private MyReceiver myReceiver; + public Context context; + @SuppressLint("SimpleDateFormat") + public SimpleDateFormat format= new SimpleDateFormat( "yyyyMMdd_HHmmss"); + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + Log.e("TAG", this.getLocalClassName() ); + gson = new Gson(); + this.context=this; + initDialog(); + + + } + + public class MyReceiver extends BroadcastReceiver { + + @Override + public void onReceive(Context context, Intent intent) { + var scannerdata = intent.getStringExtra("scannerdata"); + sanCodeCall(scannerdata); + } + } + + private void initDialog() { + dialog = new ProgressDialog(this); + dialog.requestWindowFeature(Window.FEATURE_NO_TITLE); + dialog.setCanceledOnTouchOutside(false); + dialog.setProgressStyle(ProgressDialog.STYLE_SPINNER); + dialog.setMessage("loading..."); + } + + private void initSan() { + myReceiver = new MyReceiver(); + IntentFilter intentFilter = new IntentFilter(); + intentFilter.addAction("com.rfid.SCAN"); + registerReceiver(myReceiver, intentFilter); + + } + + + // @Override + // protected void onDestroy() { + // super.onDestroy(); + // unregisterReceiver(myReceiver); + // } + + public void titleToolClick(View view) { + finish(); + } + + public void sanCodeCall(String code) { + + } + + + + +} \ No newline at end of file diff --git a/app/src/main/java/com/example/jinyu_rfid/base/MyApplication.java b/app/src/main/java/com/example/jinyu_rfid/base/MyApplication.java new file mode 100644 index 0000000..7821cdd --- /dev/null +++ b/app/src/main/java/com/example/jinyu_rfid/base/MyApplication.java @@ -0,0 +1,62 @@ +package com.example.jinyu_rfid.base; + +import android.app.Application; + +import com.example.jinyu_rfid.uitls.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 org.litepal.LitePal; + +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"); + loggingInterceptor.setPrintLevel(HttpLoggingInterceptor.Level.BODY); // log打印级别,决定了log显示的详细程度 + loggingInterceptor.setColorLevel(Level.SEVERE); // log颜色级别,决定了log在控制台显示的颜色 + HttpsUtils.SSLParams sslParams1 = HttpsUtils.getSslSocketFactory(); // 方法一:信任所有证书,不安全有风险 + builder.sslSocketFactory(sslParams1.sSLSocketFactory, sslParams1.trustManager); + builder.addInterceptor(loggingInterceptor); + builder.readTimeout(3000, TimeUnit.MILLISECONDS); // 全局的读取超时时间 + builder.writeTimeout(3000, TimeUnit.MILLISECONDS); // 全局的写入超时时间 + builder.connectTimeout(3000, TimeUnit.MILLISECONDS); // 全局的连接超时时间 + builder.cookieJar(new CookieJarImpl(new MemoryCookieStore())); // 使用内存保持cookie,app退出后,cookie消失 + 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/jinyu_rfid/base/MyRecultCall.java b/app/src/main/java/com/example/jinyu_rfid/base/MyRecultCall.java new file mode 100644 index 0000000..5cf3766 --- /dev/null +++ b/app/src/main/java/com/example/jinyu_rfid/base/MyRecultCall.java @@ -0,0 +1,65 @@ +package com.example.jinyu_rfid.base; + +import android.app.ProgressDialog; +import android.content.Context; +import android.util.Log; +import android.widget.Toast; + +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 MyResult convertResponse(okhttp3.Response response) throws Throwable { + ResponseBody body = response.body(); + if (body == null) return null; + Gson gson = new Gson(); + MyResult resust = gson.fromJson(body.string(), MyResult.class); + resust.setData(gson.toJson(resust.getData())); + return resust; + } + + @Override + public void onSuccess(Response response) { + dialog.dismiss(); + // Log.e("网络请求情况", "onSuccess:"); + } + + @Override + public void onError(Response response) { + super.onError(response); + dialog.dismiss(); + Log.e("网络请求情况", "onError:" ); + Toast.makeText(context, "网络连接错误", Toast.LENGTH_SHORT).show(); + } + + @Override + public void onStart(Request request) { + super.onStart(request); + dialog.show(); + // Log.e("网络请求情况", "onStart:" ); + } + + @Override + public void onFinish() { + super.onFinish(); + dialog.dismiss(); + Log.e("网络请求情况", "onFinish:" ); + } +} diff --git a/app/src/main/java/com/example/jinyu_rfid/base/MyResult.java b/app/src/main/java/com/example/jinyu_rfid/base/MyResult.java new file mode 100644 index 0000000..a1f5098 --- /dev/null +++ b/app/src/main/java/com/example/jinyu_rfid/base/MyResult.java @@ -0,0 +1,53 @@ +package com.example.jinyu_rfid.base; + +/** + * @author wanghao + * @date 2023/12/21 15:31 + */ +public class MyResult { + private int code; + private String msg; + private Object data; + private Object rows; + private int total; + + public int getTotal() { + return total; + } + + public void setTotal(int total) { + this.total = total; + } + + public Object getRows() { + return rows; + } + + public void setRows(Object rows) { + this.rows = rows; + } + + 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; + } +} diff --git a/app/src/main/java/com/example/jinyu_rfid/been/ConfigurationTable.java b/app/src/main/java/com/example/jinyu_rfid/been/ConfigurationTable.java new file mode 100644 index 0000000..c1faf0a --- /dev/null +++ b/app/src/main/java/com/example/jinyu_rfid/been/ConfigurationTable.java @@ -0,0 +1,46 @@ +package com.example.jinyu_rfid.been; + +import org.litepal.crud.LitePalSupport; + +/** + * @author wanghao + * @date 2024/5/15 15:02 + */ +public class ConfigurationTable extends LitePalSupport { + private int id; + private int index; + private String projectName; + private boolean state; + + public int getId() { + return id; + } + + public void setId(int id) { + this.id = id; + } + + public int getIndex() { + return index; + } + + public void setIndex(int index) { + this.index = index; + } + + public String getProjectName() { + return projectName; + } + + public void setProjectName(String projectName) { + this.projectName = projectName; + } + + public boolean isState() { + return state; + } + + public void setState(boolean state) { + this.state = state; + } +} diff --git a/app/src/main/java/com/example/jinyu_rfid/been/LoginVm.java b/app/src/main/java/com/example/jinyu_rfid/been/LoginVm.java new file mode 100644 index 0000000..c771c1e --- /dev/null +++ b/app/src/main/java/com/example/jinyu_rfid/been/LoginVm.java @@ -0,0 +1,42 @@ +package com.example.jinyu_rfid.been; + +import androidx.databinding.BaseObservable; + +/** + * @author wanghao + * @date 2023/12/21 14:00 + */ +public class LoginVm extends BaseObservable { + private String username; + private String password; + private boolean remember; + + public String getUsername() { + return username; + } + + public void setUsername(String username) { + this.username = username; + notifyChange(); + } + + public String getPassword() { + return password; + } + + public void setPassword(String password) { + this.password = password; + notifyChange(); + } + + + + public boolean isRemember() { + return remember; + } + + public void setRemember(boolean remember) { + this.remember = remember; + notifyChange(); + } +} diff --git a/app/src/main/java/com/example/jinyu_rfid/callback/DataReturnCall.java b/app/src/main/java/com/example/jinyu_rfid/callback/DataReturnCall.java new file mode 100644 index 0000000..1c91161 --- /dev/null +++ b/app/src/main/java/com/example/jinyu_rfid/callback/DataReturnCall.java @@ -0,0 +1,16 @@ +package com.example.jinyu_rfid.callback; + +/** + * @author wanghao + * @date 2024/5/16 15:45 + */ +public interface DataReturnCall { + /** + *读取信息 + * @param code + * @param mbank 1:epc 3:user 2:barCode + */ + void readEpcCodeInfo(String epc ); + void readUserInfo(String user); + void readerCodeInfo(String erCode); +} diff --git a/app/src/main/java/com/example/jinyu_rfid/callback/ItemClickCall.java b/app/src/main/java/com/example/jinyu_rfid/callback/ItemClickCall.java new file mode 100644 index 0000000..fd8c3ad --- /dev/null +++ b/app/src/main/java/com/example/jinyu_rfid/callback/ItemClickCall.java @@ -0,0 +1,9 @@ +package com.example.jinyu_rfid.callback; + +/** + * @author wanghao + * @date 2024/5/16 16:27 + */ +public interface ItemClickCall { + void onClick(int position); +} diff --git a/app/src/main/java/com/example/jinyu_rfid/rfid/C5106Device.java b/app/src/main/java/com/example/jinyu_rfid/rfid/C5106Device.java new file mode 100644 index 0000000..b5e3593 --- /dev/null +++ b/app/src/main/java/com/example/jinyu_rfid/rfid/C5106Device.java @@ -0,0 +1,15 @@ +package com.example.jinyu_rfid.rfid; + +import android.util.Log; + +/** + * @author wanghao + * @date 2024/5/16 15:12 + */ +public class C5106Device implements RFIDModel{ + + @Override + public void openModel() { + Log.e("TAG", "openModel:" + 123); + } +} diff --git a/app/src/main/java/com/example/jinyu_rfid/rfid/RFIDModel.java b/app/src/main/java/com/example/jinyu_rfid/rfid/RFIDModel.java new file mode 100644 index 0000000..864d566 --- /dev/null +++ b/app/src/main/java/com/example/jinyu_rfid/rfid/RFIDModel.java @@ -0,0 +1,9 @@ +package com.example.jinyu_rfid.rfid; + +/** + * @author wanghao + * @date 2024/5/16 15:12 + */ +public interface RFIDModel { + void openModel(); +} diff --git a/app/src/main/java/com/example/jinyu_rfid/uitls/SharedPreferencesUtils.java b/app/src/main/java/com/example/jinyu_rfid/uitls/SharedPreferencesUtils.java new file mode 100644 index 0000000..9dd4ac8 --- /dev/null +++ b/app/src/main/java/com/example/jinyu_rfid/uitls/SharedPreferencesUtils.java @@ -0,0 +1,86 @@ +package com.example.jinyu_rfid.uitls; + +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 aaa; + } + + /** + * 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/jniLibs/arm64-v8a/libModuleAPIJni.so b/app/src/main/jniLibs/arm64-v8a/libModuleAPIJni.so new file mode 100644 index 0000000..4072ad2 Binary files /dev/null and b/app/src/main/jniLibs/arm64-v8a/libModuleAPIJni.so differ diff --git a/app/src/main/jniLibs/arm64-v8a/libSerialPort.so b/app/src/main/jniLibs/arm64-v8a/libSerialPort.so new file mode 100644 index 0000000..18949be Binary files /dev/null and b/app/src/main/jniLibs/arm64-v8a/libSerialPort.so differ diff --git a/app/src/main/jniLibs/arm64-v8a/libdevapi.so b/app/src/main/jniLibs/arm64-v8a/libdevapi.so new file mode 100644 index 0000000..4e65b7e Binary files /dev/null and b/app/src/main/jniLibs/arm64-v8a/libdevapi.so differ diff --git a/app/src/main/jniLibs/arm64-v8a/libirdaSerialPort.so b/app/src/main/jniLibs/arm64-v8a/libirdaSerialPort.so new file mode 100644 index 0000000..8c43d80 Binary files /dev/null and b/app/src/main/jniLibs/arm64-v8a/libirdaSerialPort.so differ diff --git a/app/src/main/jniLibs/armeabi-v7a/libModuleAPIJni.so b/app/src/main/jniLibs/armeabi-v7a/libModuleAPIJni.so new file mode 100644 index 0000000..7e07755 Binary files /dev/null and b/app/src/main/jniLibs/armeabi-v7a/libModuleAPIJni.so differ diff --git a/app/src/main/jniLibs/armeabi-v7a/libSerialPort.so b/app/src/main/jniLibs/armeabi-v7a/libSerialPort.so new file mode 100644 index 0000000..d7eb1f9 Binary files /dev/null and b/app/src/main/jniLibs/armeabi-v7a/libSerialPort.so differ diff --git a/app/src/main/jniLibs/armeabi-v7a/libdevapi.so b/app/src/main/jniLibs/armeabi-v7a/libdevapi.so new file mode 100644 index 0000000..4ce4fc6 Binary files /dev/null and b/app/src/main/jniLibs/armeabi-v7a/libdevapi.so differ diff --git a/app/src/main/jniLibs/armeabi-v7a/libirdaSerialPort.so b/app/src/main/jniLibs/armeabi-v7a/libirdaSerialPort.so new file mode 100644 index 0000000..d1c5202 Binary files /dev/null and b/app/src/main/jniLibs/armeabi-v7a/libirdaSerialPort.so differ diff --git a/app/src/main/jniLibs/armeabi/libModuleAPIJni.so b/app/src/main/jniLibs/armeabi/libModuleAPIJni.so new file mode 100644 index 0000000..e837b9d Binary files /dev/null and b/app/src/main/jniLibs/armeabi/libModuleAPIJni.so differ diff --git a/app/src/main/jniLibs/armeabi/libSerialPort.so b/app/src/main/jniLibs/armeabi/libSerialPort.so new file mode 100644 index 0000000..dc3c956 Binary files /dev/null and b/app/src/main/jniLibs/armeabi/libSerialPort.so differ diff --git a/app/src/main/jniLibs/armeabi/libdevapi.so b/app/src/main/jniLibs/armeabi/libdevapi.so new file mode 100644 index 0000000..4ce4fc6 Binary files /dev/null and b/app/src/main/jniLibs/armeabi/libdevapi.so differ diff --git a/app/src/main/jniLibs/armeabi/libirdaSerialPort.so b/app/src/main/jniLibs/armeabi/libirdaSerialPort.so new file mode 100644 index 0000000..b8a8974 Binary files /dev/null and b/app/src/main/jniLibs/armeabi/libirdaSerialPort.so differ 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.xml b/app/src/main/res/drawable/san_text.xml new file mode 100644 index 0000000..57ba05b --- /dev/null +++ b/app/src/main/res/drawable/san_text.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/activity_configuration_table.xml b/app/src/main/res/layout/activity_configuration_table.xml new file mode 100644 index 0000000..61500a7 --- /dev/null +++ b/app/src/main/res/layout/activity_configuration_table.xml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + +