自定义版本更新弹窗
目录介绍
- 1.本库优点亮点
- 2.使用介绍
- 3.注意要点
- 4.效果展现
- 5.其余介绍
好消息
- 博客笔记大汇总【16年3月到至今】,包括Java基础及深刻知识点,Android技术博客,Python学习笔记等等,还包括平时开发中遇到的bug汇总,固然也在工做之余收集了大量的面试题,长期更新维护而且修正,持续完善……开源的文件是markdown格式的!同时也开源了生活博客,从12年起,积累共计47篇[近20万字],转载请注明出处,谢谢!
- 连接地址:https://github.com/yangchong211/YCBlogs
- 若是以为好,能够star一下,谢谢!固然也欢迎提出建议,万事起于忽微,量变引发质变!
1.本库优点亮点
- 支持后台下载,支持断点下载。支持监听下载过程,下载成功,失败,异常,下载中,暂停等多种状态
- 用户能够设置是否支持强制更新,还支持用户设置版本更新内容,当内容过长,能够实现滚动模式
- 支持进度条显示,对话框进度条,而且下载中支持通知栏进度条展现,解决8.0通知栏不显示问题
- 因为下载apk到本地须要权限,固在lib中已经处理这个逻辑,只有当有读写权限时才会下载文件,没有权限则跳转设置页面打开权限
- 调用十分简单,相比AppUpdate,CheckVersionLib等库的特色是不用设置http的get或者post请求,只须要传入下载连接就能够
- 相比GitHub上几个主流的版本更新库,我这个lib代码量少不少,我以为最少最精简的代码完成须要的功能就最好
- 适配 Android 7.0 FileProvider,处理了7.0以上安装apk异常问题,在lib中已经配置了fileProvider,直接使用就能够
- 使用dialogFragment替换了dialog,处理了重建后逻辑,dialogFragment深刻分析博客
- 下载完成后自动安装,对于错误的下载连接地址,会下载异常,也能够查看异常的日志
- 当下载完成后,再次弹窗,则会先判断本地是否已经下载,若是下载则直接提示安装
- 支持设置自定义下载文件路径,若是不设置,则直接使用lib中的路径【sd/apk/downApk目录下】
- 当apk下载失败,异常,错误等状态,支持重启下载任务。功能十分强大,已经用于正式app多时,你采用拿来主义使用便可,欢迎提出问题。
2.使用介绍
2.1 关于库导入
- 在build.gradle中直接导入:compile 'cn.yc:YCUpdateLib:1.0.2'
2.2 使用说明
- 代码以下所示,就是这么简单
//设置自定义下载文件路径
UpdateUtils.APP_UPDATE_DOWN_APK_PATH = "apk" + File.separator + "downApk";
String desc = getResources().getString(R.string.update_content_info);
/*
* @param isForceUpdate 是否强制更新
* @param desc 更新文案
* @param url 下载连接
* @param apkFileName apk下载文件路径名称
* @param packName 包名
*/
UpdateFragment.showFragment(MainActivity.this,
false,firstUrl,apkName,desc,BuildConfig.APPLICATION_ID);
2.3 lib库中解决了代码中安装 APK文件异常问题【注意lib已经解决该问题】
- 直接调用工具类UpdateUtils.installNormal方法
- 关于在代码中安装 APK 文件,在 Android N 之后,为了安卓系统为了安全考虑,不能直接访问软件,须要使用 fileProvider 机制来访问、打开 APK 文件。里面if 语句,就是区分软件运行平台,来对 intent 设置不一样的属性。
/**
* 关于在代码中安装 APK 文件,在 Android N 之后,为了安卓系统为了安全考虑,不能直接访问软件
* 须要使用 fileProvider 机制来访问、打开 APK 文件。
* 普通安装
* @param context 上下文
* @param apkPath path,文件路径
* @param pathName 你的包名
*/
public static void installNormal(Context context, String apkPath , String pathName) {
if(apkPath==null || pathName==null){
return;
}
Intent intent = new Intent(Intent.ACTION_VIEW);
File apkFile = new File(apkPath);
// 因为没有在Activity环境下启动Activity,设置下面的标签
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
//版本在7.0以上是不能直接经过uri访问的
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
//参数1 上下文, 参数2 Provider主机地址 和配置文件中保持一致 参数3 共享的文件
Uri apkUri = FileProvider.getUriForFile(context, pathName+".fileProvider", apkFile);
//添加这一句表示对目标应用临时受权该Uri所表明的文件
intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);
intent.setDataAndType(apkUri, "application/vnd.android.package-archive");
} else {
Uri uri = Uri.fromFile(apkFile);
intent.setDataAndType(uri, "application/vnd.android.package-archive");
}
context.startActivity(intent);
}
<provider
android:name=".VersionFileProvider"
android:authorities="${applicationId}.provider"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/file_paths" />
</provider>
- 在res/xml下增长文件:file_paths.xml
<?xml version="1.0" encoding="utf-8"?>
<paths>
<external-path
name="external_files"
path="." />
<root-path
name="root_path"
path="." />
</paths>
3.注意要点
- 注意须要申请读写权限,若是你要使用,能够自定定义通知栏下载UI布局,能够本身设置弹窗UI。这里就不适用正式项目中的UI和图标,图标是使用别人的,请勿商用。
4.效果展现






5.其余介绍
关于其余内容介绍

版本更新说明
- v1.0.0 更新于2017年8月13日
- v1.0.1 更新于2017年12月9日
- v1.0.2 更新于2017年11月21日
关于博客汇总连接
关于LICENSE
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://×××w.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.