注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好。

原文链接:http://developer.android.com/training/beam-files/send-files.html


这节课将向你展示如何通过Android Beam文件传输向另一台设备发送大文件。要发送文件,首先需要申明使用NFC和外部存储的权限,你需要测试一下你的设备是否支持NFC,从而能够向Android Beam文件传输提供文件的URI。

使用Android Beam文件传输功能有下列要求:

  1. Android Beam文件传输功能只能在Android 4.1(API Level 16)及以上使用。
  2. 你希望传送的文件必须放置于外部存储。学习更多关于外部存储的知识,可以阅读:Using the External Storage
  3. 每个你希望传送的文件必须是全局可读的。你可以通过File.setReadable(true,false)来为文件设置相应的读权限。
  4. 你必须提供你要传输文件的URI。Android Beam文件传输无法处理由FileProvider.getUriForFile生成的URI。

一). 在清单文件中申明功能

首先,编辑你的清单文件来申明你应用申明的权限和功能。

需求权限

为了允许你的应用使用Android Beam文件传输使用NFC从外部存储发送文件,你必须在你的应用清单申明下面的权限:

NFC

允许你的应用通过NFC发送数据。为了指定该权限,添加下面的标签作为一个<manifest>标签的子标签:

<uses-permission android:name="android.permission.NFC" />

READ_EXTERNAL_STORAGE

允许你的应用读取外部存储。为了指定这个权限,添加下面的标签作为一个<manifest>标签的子标签:

<uses-permission
android:name="android.permission.READ_EXTERNAL_STORAGE" />

Note:

对于Android 4.2.2(API Level 17),这个权限不是必需的。在后续的系统版本中,若应用需要读取外部存储,可能会需要申明该权限。为了保证将来程序稳定性,建议在该权限申明变成必需的之前,就在清单文件中申明好。

指定NFC功能

指定你的应用使用使用NFC,添加<uses-feature>标签作为一个<manifest>标签的子标签。设置“android:required”属性字段为“true”,这样可以使得你的应用只有在NFC可以使用时,才能运行。

下面的代码展示了如何指定<uses-feature>标签:

<uses-feature
android:name="android.hardware.nfc"
android:required="true" />

注意,如果你的应用将NFC作为可选的一个功能,但期望在NFC不可使用时程序还能继续执行,你就应该设置“android:required”属性字段为“false”,然后再代码中测试NFC。

指定Android Beam文件传输

由于Android Beam文件传输只能在Android 4.1(API Level 16)及以上的平台使用,如果你的应用将Android Beam文件传输作为一个不可缺少的核心模块,那么你必须指定<uses-sdk>标签为:android:minSdkVersion="16"。或者,你可以将android:minSdkVersion设置为其它值,然后再代码中测试平台版本,这在下一节中将展开。


二). 测试Android Beam文件传输是否支持

为了在你的应用清单文件中,定义NFC是可选的,你应该使用下面的标签:

<uses-feature android:name="android.hardware.nfc" android:required="false" />

如果你设置了android:required="false",你必须再代码中测试NFC和Android Beam文件传输是否支持。

为了再代码中测试Android Beam文件传输,我们先通过PackageManager.hasSystemFeature()和参数FEATURE_NFC,来测试设备是否支持NFC。下一步,通过SDK_INT的值测试系统版本是否支持Android Beam文件传输。如果Android Beam文件传输是支持的,那么获得一个NFC控制器的实例,它能允许你与NFC硬件进行通信,例如:

public class MainActivity extends Activity {
...
NfcAdapter mNfcAdapter;
// Flag to indicate that Android Beam is available
boolean mAndroidBeamAvailable = false;
...
@Override
protected void onCreate(Bundle savedInstanceState) {
...
// NFC isn't available on the device
if (!PackageManager.hasSystemFeature(PackageManager.FEATURE_NFC)) {
/*
* Disable NFC features here.
* For example, disable menu items or buttons that activate
* NFC-related features
*/
...
// Android Beam file transfer isn't supported
} else if (Build.VERSION.SDK_INT <
Build.VERSION_CODES.JELLY_BEAN_MR1) {
// If Android Beam isn't available, don't continue.
mAndroidBeamAvailable = false;
/*
* Disable Android Beam file transfer features here.
*/
...
// Android Beam file transfer is available, continue
} else {
mNfcAdapter = NfcAdapter.getDefaultAdapter(this);
...
}
}
...
}

二). 创建一个提供文件的回调函数

一旦你确认了设备支持Android Beam文件传输,添加一个回调函数,当Android Beam文件传输监测到用户希望与另一个支持NFC的设备发送文件时,系统会调用。在该回调函数中,返回一个Uri对象数组,Android Beam文件传输将URI对应的文件拷贝发送给要接收的设备。

要添加这个回调函数,实现NfcAdapter.CreateBeamUrisCallback接口,和它的方法:createBeamUris(),下面是一个例子:

public class MainActivity extends Activity {
...
// List of URIs to provide to Android Beam
private Uri[] mFileUris = new Uri[10];
...
/**
* Callback that Android Beam file transfer calls to get
* files to share
*/
private class FileUriCallback implements
NfcAdapter.CreateBeamUrisCallback {
public FileUriCallback() {
}
/**
* Create content URIs as needed to share with another device
*/
@Override
public Uri[] createBeamUris(NfcEvent event) {
return mFileUris;
}
}
...
}

一旦你实现了这个接口,通过调用setBeamPushUrisCallback()将回调函数提供给Android Beam文件传输。下面是一个例子:

public class MainActivity extends Activity {
...
// Instance that returns available files from this app
private FileUriCallback mFileUriCallback;
...
@Override
protected void onCreate(Bundle savedInstanceState) {
...
// Android Beam file transfer is available, continue
...
mNfcAdapter = NfcAdapter.getDefaultAdapter(this);
/*
* Instantiate a new FileUriCallback to handle requests for
* URIs
*/
mFileUriCallback = new FileUriCallback();
// Set the dynamic callback for URI requests.
mNfcAdapter.setBeamPushUrisCallback(mFileUriCallback,this);
...
}
...
}

Note:

你也可以将Uri对象数组通过你应用的NfcAdapter实例,直接提供给NFC框架。如果你能在NFC触碰事件发生之前,定义这些URI,那么你可以选择这个方法。要学习关于这个方法的知识,可以阅读:NfcAdapter.setBeamPushUris()


三). 定义要发送的文件

为了将一个或更多个文件发送给支持NFC的设备,为每一个文件获取一个文件URI(一个具有文件架构(scheme)的URI),然后将它们添加至一个Uri对象数组。要传输一个文件,你必须也有读文件的权限。例如,下面的例子展示的是你如何根据文件名获取它的文件URI,然后将URI添加至数组当中:

        /*
* Create a list of URIs, get a File,
* and set its permissions
*/
private Uri[] mFileUris = new Uri[10];
String transferFile = "transferimage.jpg";
File extDir = getExternalFilesDir(null);
File requestFile = new File(extDir, transferFile);
requestFile.setReadable(true, false);
// Get a URI for the File and add it to the list of URIs
fileUri = Uri.fromFile(requestFile);
if (fileUri != null) {
mFileUris[0] = fileUri;
} else {
Log.e("My Activity", "No File URI available for file.");
}

【Android Developers Training】 41. 向另一台设备发送文件的更多相关文章

  1. 【Android Developers Training】 40. 序言:通过NFC共享文件

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...

  2. 【Android Developers Training】 42. 从另一台设备接收文件

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...

  3. 【Android Developers Training】 2. 运行你的应用

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...

  4. 【Android Developers Training】 96. 运行一个同步适配器

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...

  5. 【Android Developers Training】 94. 创建一个空内容提供器(Content Provider)

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...

  6. 【Android Developers Training】 92. 序言:使用同步适配器传输数据

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...

  7. 【Android Developers Training】 91. 解决云储存冲突

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...

  8. 【Android Developers Training】 9. 覆盖于布局之上的Action Bar

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...

  9. 【Android Developers Training】 8. 定义Action Bar风格

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...

随机推荐

  1. ZED 相机 && ORB-SLAM2安装环境配置与ROS下的调试

    注:1. 对某些地方进行了更新(红色标注),以方便进行配置. 2. ZED ROS Wrapper官方github已经更新,根据描述新的Wrapper可能已经不适用与Ros Indigo了,如果大家想 ...

  2. 用 Vue 全家桶二次开发 V2EX 社区

    一.开发背景 为了全面的熟悉Vue+Vue-router+Vuex+axios技术栈,结合V2EX的开放API开发了这个简洁版的V2EX. 在线预览 (为了实现跨域,直接npm run dev部署的, ...

  3. php jquery+ajax写批量删除

      为了美观,我还是引入了bootstrap的模态框,我引入的是自己的数据库 library中的一张表 名为:maninfo表 是一张个人信息表  表的加载我就不写了,比较简单,  大概写一下需要的按 ...

  4. Android中SimpleAdapter的使用—自定义列表

    本人初学Android,今天研究到Adapter这块感觉挺有意思的,写了个自定义列表进行测试 首先我们新建一个layout列表布局文件,具体布局可以自己设定. 下面贴上我的自定义布局文件代码 < ...

  5. 日志组件二:log4j2

    一.背景 随着业务服务(Server App)逐渐增加,我们的业务系统中的日志输出面临的问题越来越多,高并发下对磁盘io这块消耗的越来越大,因此,急需要一个高性能且最好能够支持异步输出日志的日志框架, ...

  6. Vulkan Tutorial 07 Window surface

    操作系统:Windows8.1 显卡:Nivida GTX965M 开发工具:Visual Studio 2017 到目前为止,我们了解到Vulkan是一个与平台特性无关联的API集合.它不能直接与窗 ...

  7. 手把手教你用Eclipse+TestNG搭建接口自动化测试框架

    转载于:http://qa.blog.163.com/blog/static/190147002201510275306185/ 把群博里关于接口自动化的文章都看了一遍,都是关于测试过程中遇到的问题及 ...

  8. JVM-4.类加载机制

    目录 一.类加载的基础 二.类加载的过程 三.类加载器:分类 四.类加载器:双亲委托模型 五.类加载器:补充 六.初始化时机/主动引用和被动引用[关于实例初始化,参考<Java编程思想05-初始 ...

  9. 调试JDK源码时,不能查看变量的值

    前几天本来想以debug模式看一下JDK的源码,进入调试模式时才发现,根本看不到方法里面变量值的情况.为什么呢?JDK现在的版本中,编译过后,去除了里面的调试信息.解决办法是,编译那些类,使其带有调试 ...

  10. HTML/XML/XPATH基础

    Html超文本标记语言 网页上单击右键→查看源文件/查看源代码 Html基本结构 <html>               为文档根元素,所有元素都在内部进行 <head>   ...