From 483cce8fd5cabc1a84b02044c965b3396e4e9fee Mon Sep 17 00:00:00 2001 From: wujie Date: Fri, 1 Sep 2023 09:51:56 +0800 Subject: [PATCH] =?UTF-8?q?urovo=20DT50=20Lite=20pda=E7=9A=84=E6=94=AF?= =?UTF-8?q?=E6=8C=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/build.gradle | 3 +- .../main/java/chaoran/business/BrandEnum.java | 1 + .../business/activity/MainActivity.java | 2 + .../business/adapter/UrovoAdapter.java | 53 +++++++++++++++++++ 4 files changed, 58 insertions(+), 1 deletion(-) create mode 100644 app/src/main/java/chaoran/business/adapter/UrovoAdapter.java diff --git a/app/build.gradle b/app/build.gradle index 6326af7..c441796 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -11,13 +11,14 @@ android { minSdk 28 targetSdk 28 versionCode 1 - versionName "1.4" + versionName "1.5" // 1.0 IDATA广播模式处理 // 1.1 霍尼韦尔的监听修改(扫描网站二维码跳出程序,监听失效,调整)、斑马PDA广播模式设置 // 1.2 霍尼韦尔EDA56、jdk11,gradle7.3、海信PDA广播支持 // 1.3 东集 pda的支持 // 1.4 联新 pda的支持 已经 adapter 关闭的判断 + // 1.5 urovo DT50 Lite pda的支持 testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" } diff --git a/app/src/main/java/chaoran/business/BrandEnum.java b/app/src/main/java/chaoran/business/BrandEnum.java index 5d1ce6f..a5ae1fb 100644 --- a/app/src/main/java/chaoran/business/BrandEnum.java +++ b/app/src/main/java/chaoran/business/BrandEnum.java @@ -11,6 +11,7 @@ package chaoran.business; public enum BrandEnum { //枚举名即为valueOf() HISENSE("海信", "hisense"), + UROVO("DT50 Lite", "urovo"), LACHESIS("联新", "lachesis"), UROBO("优博讯", "urobo"), ROCKCHIP("瑞芯微电子", "rockchip"), diff --git a/app/src/main/java/chaoran/business/activity/MainActivity.java b/app/src/main/java/chaoran/business/activity/MainActivity.java index b3e4539..66cd0cb 100644 --- a/app/src/main/java/chaoran/business/activity/MainActivity.java +++ b/app/src/main/java/chaoran/business/activity/MainActivity.java @@ -104,6 +104,8 @@ public class MainActivity extends AppCompatActivity implements ResultListener{ adapter = new HisenseAdapter(this, this); case LACHESIS: adapter = new LachesisAdapter(this, this); + case UROVO: + adapter = new UrovoAdapter(this, this); } if (null != adapter) { adapter.start(); diff --git a/app/src/main/java/chaoran/business/adapter/UrovoAdapter.java b/app/src/main/java/chaoran/business/adapter/UrovoAdapter.java new file mode 100644 index 0000000..07a1a84 --- /dev/null +++ b/app/src/main/java/chaoran/business/adapter/UrovoAdapter.java @@ -0,0 +1,53 @@ +package chaoran.business.adapter; + +import android.content.BroadcastReceiver; +import android.content.Context; +import android.content.Intent; +import android.content.IntentFilter; + +import chaoran.business.activity.ResultListener; +import chaoran.business.strategy.Strategy; + +public class UrovoAdapter implements Adapter { + private Context context; + private ResultListener resultListener; + private Strategy strategy; + + + public UrovoAdapter(Context context, ResultListener resultListener) { + this.context = context; + this.resultListener = resultListener; + strategy = new Receiver(); + } + + @Override + public void start() { + strategy.executeStrategy(resultListener); + } + + @Override + public void stop() { + strategy.exclusiveStrategy(); + } + + public class Receiver extends BroadcastReceiver implements Strategy { + + @Override + public void onReceive(Context context, Intent intent) { + resultListener.result(intent.getStringExtra("barcode_string")); + } + + @Override + public void executeStrategy(ResultListener resultListener) { + IntentFilter filter = new IntentFilter(); + filter.addAction("android.intent.ACTION_DECODE_DATA"); + filter.setPriority(2); + context.registerReceiver(this, filter); + } + + @Override + public void exclusiveStrategy() { + context.unregisterReceiver(this); + } + } +}