Android 适配 - FileProvider

栏目: IOS · Android · 发布时间: 7年前

内容简介:响应 Google 号召,App 适配 Android 8.0 之上。只包括我们 App 中遇到的情况进行记录。参考了本适配的核心就是

响应 Google 号召,App 适配 Android 8.0 之上。只包括我们 App 中遇到的情况进行记录。

参考了 FileProvider 文档和网络上可以搜索的一些资料。

适配核心

本适配的核心就是 FileProvider 的使用。

AndroidManifest 适配

在 application 节点里面增加一个 provider 节点。

<manifest>
    ...
    <application>
        ...
        <provider
            android:name="androidx.core.content.FileProvider"
            android:authorities="${applicationId}.fileProvider"
            android:exported="false"
            android:grantUriPermissions="true">
                <meta-data
                    android:name="android.support.FILE_PROVIDER_PATHS"
                    android:resource="@xml/file_paths" />
        </provider>
    </appliction>
</manifest>
复制代码

上面的写法基本是固定的,很多项都是可以修改,但不建议做,下面只是记录一下。

可修改项 1

android:name="androidx.core.content.FileProvider"
复制代码

上面为指定提供服务的 Provider 类。如上是 Android androidx 包提供的类,可以自定义。可以使用ContentProvider提供服务的目标即可。

可修改项 2

android:authorities="${applicationId}.fileProvider"
复制代码

唯一字符串即可,上面为一般常用的写法。

可修改项 3

android:name="android.support.FILE_PROVIDER_PATHS"
复制代码

是可以修改,但是如果没有自己实现 Provider ,这个值只能是这个。这个字符串是在类 FileProvider 里面定义的。

可修改项 4

android:resource="@xml/file_paths"
复制代码

定义了类 FileProvider 使用的配置文件,文件名字不违法命名规范情况下随意。

增加一个特定的 ContentProvider FileProvider ,包名 androidx.core.content

FileProvider 适配文件

文件地址 res/xml/file_paths.xml

空文件内容如下

<?xml version="1.0" encoding="utf-8"?>
<paths>
</paths>
复制代码

里面的具体配置为,Android Studio 提示为这五个地方。

<files-path name="name" path="path" />
<cache-path name="name" path="path" />
<external-path name="name" path="path" />
<external-files-path name="name" path="path" />
<external-cache-path name="name" path="path" />
复制代码

网站介绍上还有一个

<!-- this directory is only available on API 21+ devices. -->
<external-media-path name="name" path="path" />
复制代码

代码里面可以看到还有一个

<!-- 这个定义的根目录是 / -->
<root-path name="name" path="path" />
复制代码

上面各个 -path 的区别是定义的根目录不同。

-path 根目录
files-path Context.getFilesDir()
cache-path Context.getCacheDir()
external-path Environment.getExternalStorageDirectory()
external-files-path Context.getExternalFilesDir(null)
external-cache-path Context.getExternalCacheDir()
external-media-path Context.getExternalMediaDirs()
root-path /

Path 节点里面的 name 属性

唯一不重复

Path 节点里面的 path 属性

文件夹名字,自动包括此文件夹下面的子目录

例子:

<external-path name="pic" path="Pictures" />
复制代码

这样定义后, /sdcard/Pictures 里面的所有文件,都可以从自己的App里面发出到其他App中使用。

具体应用

我们 App 涉及到这个地方不多。都是简单的应用。

图片分享

场景,App 内部生成一张图片,并使用系统分享。

核心代码

Uri uri = null;
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
    uri = FileProvider.getUriForFile(this, getPackageName() + ".fileProvider", file);
} else {
    uri = Uri.fromFile(file);
}
复制代码

视频播放

有个功能视频播放使用的系统播放器,同时有视频异步下载。如果下载完成,播放本地视频。会使用这个功能。

核心代码

Uri uri = null;
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
    uri = FileProvider.getUriForFile(this, getPackageName() + ".fileProvider", file);
} else {
    uri = Uri.fromFile(file);
}
// 上面的和图片分享一致。但需要额外增加一行权限代码
intent.setFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);
复制代码

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

超级连接者:破解新互联时代的成功密码

超级连接者:破解新互联时代的成功密码

伊桑•祖克曼(ETHAN ZUCKERMAN) / 林玮、张晨 / 浙江人民出版社 / 2018-8-1 / CNY 72.90

● 我们生活在一个互联互通的世界,我们需要辩证地看待某些事件,发现隐藏在背后的真相。着眼当下,看清彼此之间的联系,而非凭空幻想未来世界联系之紧密。数字世界主义要求我们承担起责任,让隐藏的联系变成现实。 ● 我们对世界的看法是局限的、不完整的、带有偏见的。如果我们想要改变从这个广阔的世界所获取的信息,我们需要做出结构性的改变。 ● 建立联系是一种新的力量。无论是在国家层面、企业层面还是个......一起来看看 《超级连接者:破解新互联时代的成功密码》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具