Пользовательский планшет Android с NFC иногда не работаетAndroid

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Пользовательский планшет Android с NFC иногда не работает

Сообщение Anonymous »

Я разрабатываю приложение для планшета Android с устройством чтения NFC. У меня приложение работает круглосуточно, планшет специально предназначен для работы в режиме киоска.
Моя проблема в том, что иногда планшет перестает реагировать на теги, случайно, иногда через несколько дней, иногда через несколько месяцев работы, читая журналы планшета, я вижу, что теги обнаружены системой, но Android не маршрутизирует показания в моем приложении. Чтобы решить проблему, достаточно перевести приложение в фоновый режим и снова открыть его. Нет необходимости закрывать приложение или перезагружать планшет, но эти решения тоже работают.
Я использую AID для маршрутизации своих показаний в мое приложение, и категория, которую я объявил на Android, — «другое». Я использую класс, реализующий NfcAdapter.ReaderCallback
Я в отчаянии, не знаю, что делать. Я перепробовал все варианты, но через некоторое время проблема повторяется.
Это мой NfcManager, я запускаю его из активности колтина. Не знаю почему, но если я запущу nfcreader с помощью Java, он будет работать лучше, чем запуск с Kotlin.
public class NfcManager implements NfcAdapter.ReaderCallback {

NfcAdapter mNfcAdapter;

Activity activity;

void startReading(Activity activity) {
try {
MyChannel.channel.invokeMethod("log", "START READING");
this.activity = activity;
mNfcAdapter = NfcAdapter.getDefaultAdapter(activity);
if (mNfcAdapter != null) {
if (mNfcAdapter.isEnabled()) {
MyChannel.channel.invokeMethod("log", "ADAPTER ENABLED");
startNFCReaderMode(activity, this);
} else {
MyChannel.channel.invokeMethod("log", "ADAPDTER NOT ENABLED");
new Handler().postDelayed(() -> startReading(activity), 10000);
}
}
} catch (Exception err) {
Log.e("ERRORE LETTORE NFC", err.toString());
MyChannel.channel.invokeMethod("log", err.toString());
}
}

void startNFCReaderMode(Activity activity, NfcAdapter.ReaderCallback callback) {
try {
MyChannel.channel.invokeMethod("log", "START NFC READERMODE");
Bundle options = new Bundle();
// Work around for some broken Nfc firmware implementations that poll the card too fast
options.putInt(NfcAdapter.EXTRA_READER_PRESENCE_CHECK_DELAY, 250);

Log.i("SERVIZIO AVVIATO", "Servizio Avviato");
mNfcAdapter.enableReaderMode(activity,
this,
NfcAdapter.FLAG_READER_NFC_A | NfcAdapter.FLAG_READER_SKIP_NDEF_CHECK,
options);
MyChannel.channel.invokeMethod("log", "NFC STARTED, ADAPETR:" + mNfcAdapter.isEnabled());

Timer timer = new Timer();
NFCMonitopringClass monitor = new NFCMonitopringClass();
TimerTask task = new TimerTask() {
@Override
public void run() {
NFCMonitopringClass.NfcHealthStatus status = monitor.performHealthCheck(activity);
activity.runOnUiThread(new Runnable() {
@Override
public void run() {
MyChannel.channel.invokeMethod("log", "NFC CHECKER: isEnabled? -> " + mNfcAdapter.isEnabled() + " isReaderOptionEnabled? -> " + status.toString());
}
});
}
};
timer.schedule(task, 0, 5 * 60 * 1000);
} catch (Exception e) {
MyChannel.channel.invokeMethod("log", "ERRORE enablereadermode:" + e);
}

}

void stopReading() {
if (mNfcAdapter != null && mNfcAdapter.isEnabled()) {
Log.i("SERVIZIO FERMATO", "Servizio fermato");
mNfcAdapter.disableReaderMode(activity);
}
}

@Override
public void onTagDiscovered(Tag tag) {
//DO THINGS WITH THE RESULT
}

}


Подробнее здесь: https://stackoverflow.com/questions/798 ... ot-working
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»