这近期也是有好多天没写博客了,除了到处张罗着搬家之外。依然还是许很多多的琐事阻碍着学习,加上使用NFC开发,也是须要具有NFC功能的測试机。也到买了一个,所以,也说了两天的概念
Android NFC开发(一)——初探NFC,了解当前前沿技术
Android NFC开发(二)——Android世界里的NFC所具备的条件以及用法
今天,咋们就来用一个小栗子做药引,一起进入Android NFC开发的世界,首先,你必须要知道的是这两个类
- NdefMessage
- NdefRecord
NdefMessage
主要是描写叙述NDEF格式的信息
NdefRecord
这个是秒速NDEF信息的一个信息段
这两个都是Android NCF技术的核心类,不管是读写NFC标签还是通过Android Beam技术传递数据都须要这两个类
开发步骤
1.获取Tag对象
Tag tag = intent.getParcelableExtra(NfcAdapter.EXTRA_TAG);
2.推断NFC标签的数格式
Ndef ndef = Ndef.get(tag);
3.写入数据
ndef.wrriteNdefMessage(ndefMessage);
准备工作都做好了,我们就直接来敲代码了,我们新建一个程序——NFCDemo
我们的需求是这种:我们的软件把手机上全部安装好的应用排列,然后我们点击一个就開始拿着这个软件,等我们的NFC标签靠近,就把软件写进去。然后。我们每次仅仅要把NFC标签开进有NFC的手机上就会直接执行我们写入的程序了。这个原理有点儿相似门卡。你的先买一个NFC标签
然后我们就開始写了。大致的情况是这种,我们主页有一个button,点击之后跳转到一个界面,是我们手机安装程序的包名列表,我们选中一个回到主Activity。然后等待NFC标签刷入,成功之后。我们就直接用NFC靠近手机就能启动这个程序了,跟门卡登记,然后开门的道理是一样的
主页是这种
我们点击之后跳转到ListActivity
ListActivity
package com.lgl.nfcdemo; import android.content.Intent; import android.content.pm.PackageInfo; import android.content.pm.PackageManager; import android.os.Bundle; import android.view.View; import android.widget.AdapterView; import android.widget.ArrayAdapter; import java.util.ArrayList; import java.util.List; /** * 读取手机软件列表 * * @author LGL */ public class ListActivity extends android.app.ListActivity implements AdapterView.OnItemClickListener { //返回码 private static final int CODE = 1; //封装全部软件 private List<String> mPackage = new ArrayList<String>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); //这里继承了ListActivity显示列表。不须要载入layout //获取手机上全部的包 PackageManager manager = getPackageManager(); //把他们装起来 List<PackageInfo> packageInfos = manager.getInstalledPackages(PackageManager.GET_ACTIVITIES); //遍历 for (PackageInfo pi : packageInfos) { //加入软件名和包名 mPackage.add(pi.applicationInfo.loadLabel(manager) + "\n" + pi.packageName); } //官方的适配器 ArrayAdapter<String> arrayAdapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, android.R.id.text1, mPackage); setListAdapter(arrayAdapter); //设置单击事件 getListView().setOnItemClickListener(this); } @Override public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) { Intent intent = new Intent(); intent.putExtra("package", mPackage.get(i)); setResult(CODE,intent); finish(); } }
这段代码应该清晰易懂吧。继承lListActivity,获取手机的应用排列。点击之后携带包名finish()。
MainActivity
package com.lgl.nfcdemo; import android.app.PendingIntent; import android.content.Intent; import android.nfc.FormatException; import android.nfc.NdefMessage; import android.nfc.NdefRecord; import android.nfc.NfcAdapter; import android.nfc.Tag; import android.nfc.tech.Ndef; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.view.View; import android.widget.Button; import android.widget.Toast; import com.google.android.gms.common.api.GoogleApiClient; import java.io.IOException; /** * NFC读写 * Created by lgl on 16/3/1. */ public class MainActivity extends AppCompatActivity { private Button btn_list; //选中的包名 private String mPackNmae; private NfcAdapter mNfcAdapter; private PendingIntent mPendingIntent; private GoogleApiClient client; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); btn_list = (Button) findViewById(R.id.btn_list); //初始化NfcAdapter mNfcAdapter = NfcAdapter.getDefaultAdapter(this); //初始化PendingIntent mPendingIntent = PendingIntent.getActivity(this, 0, new Intent(this, getClass()), 0); //点击跳转 btn_list = (Button) findViewById(R.id.btn_list); btn_list.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { Intent intent = new Intent(MainActivity.this,ListActivity.class); startActivityForResult(intent,1); } }); } //当设置android:launchMode="singleTop"时调用 @Override protected void onNewIntent(Intent intent) { super.onNewIntent(intent); //没有选择的话就不执行操作了 if (mPackNmae == null) { return; } //1.获取Tag对象 Tag tag = intent.getParcelableExtra(NfcAdapter.EXTRA_TAG); //写入程序 writeNFC(tag); } //NFC写入 private void writeNFC(Tag tag) { //null不执行操作,强调敲代码的逻辑性 if (tag == null) { return; } NdefMessage ndefMessage = new NdefMessage(new NdefRecord[]{NdefRecord.createApplicationRecord(mPackNmae)}); //获得写入大小 int size = ndefMessage.toByteArray().length; //2.推断是否是NDEF标签 try { Ndef ndef = Ndef.get(tag); if(ndef != null) { //说明是NDEF标签,開始连接 ndef.connect(); //推断是否可写 if(!ndef.isWritable()){ Toast.makeText(this, "当前设备不支持写入",Toast.LENGTH_LONG).show(); return; } //推断大小 if(ndef.getMaxSize() < size){ Toast.makeText(this, "容量太小了",Toast.LENGTH_LONG).show(); return; } //写入 try { ndef.writeNdefMessage(ndefMessage); Toast.makeText(this, "写入成功",Toast.LENGTH_LONG).show(); } catch (FormatException e) { e.printStackTrace(); } } } catch (IOException e) { e.printStackTrace(); } } //使当前窗体置顶,权限高于三重过滤 @Override protected void onResume() { super.onResume(); if (mNfcAdapter != null) { //设置当前activity为栈顶 mNfcAdapter.enableForegroundDispatch(this, mPendingIntent, null, null); } } @Override protected void onPause() { super.onPause(); //恢复栈 if (mNfcAdapter != null) { mNfcAdapter.disableForegroundDispatch(this); } } }
这里东西多了点。只是细致看会发现。也就是一些推断,真正的关键代码就那几句,
layout_main.xml
<?
xml version="1.0" encoding="utf-8"?
> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:fitsSystemWindows="true" android:orientation="vertical"> <Button android:layout_marginTop="15dp" android:id="@+id/btn_list" android:layout_width="200dp" android:layout_height="45dp" android:text="绑定应用程序" android:layout_gravity="center_horizontal" /> <TextView android:gravity="center_horizontal" android:textSize="14sp" android:text="你能够将NFC标签靠近手机背部" android:layout_width="match_parent" android:layout_height="wrap_content" /> <ImageView android:layout_weight="1" android:background="@mipmap/nfc" android:layout_width="match_parent" android:layout_height="0dp" /> </LinearLayout>
我们来简单的执行一下
然后我们靠近NFC就算写入成功了。以后我们仅仅要拿着NFC靠近手机就自己主动打开我们写入的那个程序了。原理和门卡有点相似,下节接着讲NFC和网络交互的那些事