[英]Android NFC intent handling, showing a toast
Hello fellow programmers! 各位程序员大家好!
I am really new to Android, 2 weeks old. 我真的是2周大的Android新手。
I am trying to do some programming with NFC. 我正在尝试使用NFC进行一些编程。 I have Nexus 5 and I am trying to read and display UID of the MIFARE Classic 1k.
我有Nexus 5,并且正在尝试读取和显示MIFARE Classic 1k的UID。 I know all the protocol compatibilities issues with the Broadcom chip, so we can skip that and go straight to fact that you can read UID with no problem.
我知道Broadcom芯片的所有协议兼容性问题,因此我们可以跳过这一点,直接了解您可以毫无问题地读取UID。
I want to catch the intent and show a toast with read UID. 我想抓住意图,并举杯阅读UID。 So far I made it work by putting performIntent into onCreate method.
到目前为止,我通过将performIntent放入onCreate方法来使其工作。 By making the intent to restart my activity I am able to handle that intent and show its UID via toast and that all works.
通过意图重新启动我的活动,我能够处理该意图并通过烤面包显示其UID,并且一切正常。 Here is my humble code: MainActivity.java
这是我谦虚的代码:MainActivity.java
package sanjin.com.nfc;
import android.content.Intent;
import android.nfc.NfcAdapter;
import android.app.Activity;
import android.nfc.Tag;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.Toast;
public class MainActivity extends Activity {
NfcAdapter mNfcAdapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mNfcAdapter = NfcAdapter.getDefaultAdapter(this);
Boolean nfcEnabled = mNfcAdapter.isEnabled();
if (nfcEnabled){
Toast.makeText(MainActivity.this,
R.string.turned_on,
Toast.LENGTH_SHORT).show();
} else {
Toast.makeText(MainActivity.this,
R.string.turned_off,
Toast.LENGTH_SHORT).show();
}
performIntent(getIntent());
}
private String serialId = "";
@Override
public void onResume() {
super.onResume();
performIntent(getIntent());
}
private void performIntent(Intent intent) {
String action = intent.getAction();
Tag tag = intent.getParcelableExtra(NfcAdapter.EXTRA_TAG);
if (action.equals(NfcAdapter.ACTION_TAG_DISCOVERED)) {
try {
byte[] tagId = tag.getId();
serialId = toHexString(tagId);
Log.d("[ReadCardTools]", "Serial Number: " + serialId);
Toast.makeText(this, serialId,Toast.LENGTH_SHORT).show();
} catch (NullPointerException ex) {
ex.printStackTrace();
serialId = "ERROR";
}
}
}
public static String toHexString(byte[] bytes) {
char[] hexArray = {'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
char[] hexChars = new char[bytes.length * 2];
int v;
for ( int j = 0; j < bytes.length; j++ ) {
v = bytes[j] & 0xFF;
hexChars[j*2] = hexArray[v/16];
hexChars[j*2 + 1] = hexArray[v%16];
}
return new String(hexChars);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
}
And manifest file: 和清单文件:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="sanjin.com.nfc">
<uses-permission android:name="android.permission.NFC" />
<uses-feature
android:name="android.hardware.nfc"
android:required="true" />
<application
android:label="@string/app_name"
android:launchMode="singleTask">
<activity
android:name=".MainActivity"
android:label="@string/app_name">
<intent-filter>
<action android:name="android.nfc.action.TAG_DISCOVERED" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
Now, I want this intent to just show the toast without starting the activity again. 现在,我希望此意图仅显示吐司,而无需再次开始该活动。 I realize its working because when the activity restarts, intent gets handled and show me my UID.
我意识到它可以正常工作,因为当活动重新启动时,意图得到了处理,并向我显示了我的UID。
I just want the incoming intent to show the toast containing its UID. 我只希望传入的意图显示包含其UID的吐司。
Sorry if this was asked before, I tried finding it but no luck. 抱歉,如果以前有人问过我,我尝试找到它,但是没有运气。
Thanks! 谢谢!
public class MainActivity extends AppCompatActivity {
private static final String LOG_TAG = MainActivity.class.getSimpleName();
NfcAdapter nfcAdapter;
TextView uidView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
uidView = (TextView)findViewById(R.id.mTextView);
nfcAdapter = NfcAdapter.getDefaultAdapter(MainActivity.this);
Boolean nfcEnabled = nfcAdapter.isEnabled();
if (nfcEnabled){
Toast.makeText(MainActivity.this,
R.string.turned_on,
Toast.LENGTH_SHORT).show();
} else {
Toast.makeText(MainActivity.this,
R.string.turned_off,
Toast.LENGTH_SHORT).show();
}
Intent intent = getIntent();
resolveIntent(intent);
}
protected void resolveIntent(Intent intent) {
Tag nfcTag = intent.getParcelableExtra(NfcAdapter.EXTRA_TAG);
if (nfcTag == null) {
Log.w(LOG_TAG, "Unable to obtain NFC tag from intent!");
} else {
String tagId = bytesToHex(nfcTag.getId());
uidView.setText(tagId);
//Toast.makeText(getApplicationContext(), tagId, Toast.LENGTH_LONG).show();
}
}
public static String bytesToHex(byte[] bytes) {
StringBuilder ret = new StringBuilder();
if (bytes != null) {
for (Byte b : bytes) {
ret.append(String.format("%02X", b.intValue() & 0xFF));
}
}
StringBuilder result = new StringBuilder();
for (int i = 0; i <= ret.length() - 2; i = i + 2) {
result.append(new StringBuilder(ret.substring(i, i + 2)).reverse());
}
String card = result.reverse().toString();
if(card.length() == 8){
card = "0" + Long.parseLong(card, 16) + "\n\n";
}
if(card.length() == 9){
card = Long.parseLong(card, 16) + "\n\n";
}
return card;
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.