diff --git a/README.md b/README.md
index c363b4d..d99f3e8 100644
--- a/README.md
+++ b/README.md
@@ -3,7 +3,7 @@
![Image](app/src/main/ic_launcher-web.png)
[![Download](https://img.shields.io/badge/download-App-blue.svg)](https://raw.githubusercontent.com/jenly1314/AppUpdater/master/app/release/app-release.apk)
-[![JCenter](https://img.shields.io/badge/JCenter-1.0.9-46C018.svg)](https://bintray.com/beta/#/jenly/maven/app-updater)
+[![JCenter](https://img.shields.io/badge/JCenter-1.0.10-46C018.svg)](https://bintray.com/beta/#/jenly/maven/app-updater)
[![JitPack](https://jitpack.io/v/jenly1314/AppUpdater.svg)](https://jitpack.io/#jenly1314/AppUpdater)
[![CI](https://travis-ci.org/jenly1314/AppUpdater.svg?branch=master)](https://travis-ci.org/jenly1314/AppUpdater)
[![CircleCI](https://circleci.com/gh/jenly1314/AppUpdater.svg?style=svg)](https://circleci.com/gh/jenly1314/AppUpdater)
@@ -44,7 +44,7 @@ AppUpdater for Android 是一个专注于App更新,一键傻瓜式集成App版
com.king.app
app-updater
- 1.0.9
+ 1.0.10
pom
@@ -52,7 +52,7 @@ AppUpdater for Android 是一个专注于App更新,一键傻瓜式集成App版
com.king.app
app-dialog
- 1.0.9
+ 1.0.10
pom
```
@@ -61,25 +61,25 @@ AppUpdater for Android 是一个专注于App更新,一键傻瓜式集成App版
//----------AndroidX 版本
//app-updater
- implementation 'com.king.app:app-updater:1.0.9-androidx'
+ implementation 'com.king.app:app-updater:1.0.10-androidx'
//app-dialog
- implementation 'com.king.app:app-dialog:1.0.9-androidx'
+ implementation 'com.king.app:app-dialog:1.0.10-androidx'
//----------Android Support 版本
//app-updater
- implementation 'com.king.app:app-updater:1.0.9'
+ implementation 'com.king.app:app-updater:1.0.10'
//app-dialog
- implementation 'com.king.app:app-dialog:1.0.9'
+ implementation 'com.king.app:app-dialog:1.0.10'
```
### Lvy:
```lvy
//app-updater
-
+
//app-dialog
-
+
```
@@ -152,6 +152,7 @@ AppUpdater for Android 是一个专注于App更新,一键傻瓜式集成App版
#### v1.0.10:2021-3-4
* AppDialogConfig添加构造参数,简化自定义扩展用法
+* 优化细节
#### v1.0.9:2020-12-11
* 优化默认Dialog样式的显示细节
diff --git a/app-updater/src/main/java/com/king/app/updater/service/DownloadService.java b/app-updater/src/main/java/com/king/app/updater/service/DownloadService.java
index 3938bf9..74d8e0d 100644
--- a/app-updater/src/main/java/com/king/app/updater/service/DownloadService.java
+++ b/app-updater/src/main/java/com/king/app/updater/service/DownloadService.java
@@ -1,19 +1,12 @@
package com.king.app.updater.service;
-import android.app.Notification;
-import android.app.NotificationChannel;
-import android.app.NotificationManager;
-import android.app.PendingIntent;
import android.app.Service;
import android.content.Context;
import android.content.Intent;
import android.os.Binder;
import android.os.Build;
import android.os.IBinder;
-import android.support.annotation.DrawableRes;
import android.support.annotation.Nullable;
-import android.support.annotation.RequiresApi;
-import android.support.v4.app.NotificationCompat;
import android.support.v4.content.ContextCompat;
import android.text.TextUtils;
import android.util.Log;
@@ -25,6 +18,7 @@
import com.king.app.updater.http.HttpManager;
import com.king.app.updater.http.IHttpManager;
import com.king.app.updater.util.AppUtils;
+import com.king.app.updater.util.NotificationUtils;
import java.io.File;
@@ -250,7 +244,7 @@ private AppDownloadCallback(UpdateConfig config,UpdateCallback callback){
this.channelId = TextUtils.isEmpty(config.getChannelId()) ? Constants.DEFAULT_NOTIFICATION_CHANNEL_ID : config.getChannelId();
this.channelName = TextUtils.isEmpty(config.getChannelName()) ? Constants.DEFAULT_NOTIFICATION_CHANNEL_NAME : config.getChannelName();
}
- if(config.getNotificationIcon() <=0 ){
+ if(config.getNotificationIcon() <= 0){
this.notificationIcon = AppUtils.getAppIcon(getContext());
}else{
this.notificationIcon = config.getNotificationIcon();
@@ -275,7 +269,7 @@ public void onStart(String url) {
isDownloading = true;
mLastProgress = 0;
if(isShowNotification){
- showStartNotification(notifyId,channelId,channelName,notificationIcon,getString(R.string.app_updater_start_notification_title),getString(R.string.app_updater_start_notification_content),config.isVibrate(),config.isSound());
+ NotificationUtils.showStartNotification(getContext(),notifyId,channelId,channelName,notificationIcon,getString(R.string.app_updater_start_notification_title),getString(R.string.app_updater_start_notification_content),config.isVibrate(),config.isSound());
}
if(callback!=null){
@@ -302,7 +296,7 @@ public void onProgress(long progress, long total) {
content += percentage;
}
- showProgressNotification(notifyId, channelId, notificationIcon, getString(R.string.app_updater_progress_notification_title), content, currProgress, 100);
+ NotificationUtils.showProgressNotification(getContext(),notifyId, channelId, notificationIcon, getString(R.string.app_updater_progress_notification_title), content, currProgress, 100);
}
}
@@ -317,7 +311,7 @@ public void onProgress(long progress, long total) {
public void onFinish(File file) {
Log.d(Constants.TAG,"onFinish:" + file);
isDownloading = false;
- showFinishNotification(notifyId,channelId,notificationIcon,getString(R.string.app_updater_finish_notification_title),getString(R.string.app_updater_finish_notification_content),file,authority);
+ NotificationUtils.showFinishNotification(getContext(),notifyId,channelId,notificationIcon,getString(R.string.app_updater_finish_notification_title),getString(R.string.app_updater_finish_notification_content),file,authority);
if(isInstallApk){
AppUtils.installApk(getContext(),file,authority);
}
@@ -334,7 +328,7 @@ public void onError(Exception e) {
//支持下载失败时重新下载,当重新下载次数不超过限制时才被允许
boolean isReDownload = this.isReDownload && mCount < reDownloads;
String content = isReDownload ? getString(R.string.app_updater_error_notification_content_re_download) : getString(R.string.app_updater_error_notification_content);
- showErrorNotification(notifyId,channelId,notificationIcon,getString(R.string.app_updater_error_notification_title),content,isReDownload,config);
+ NotificationUtils.showErrorNotification(getContext(),notifyId,channelId,notificationIcon,getString(R.string.app_updater_error_notification_title),content,isReDownload,config);
if(callback!=null){
callback.onError(e);
@@ -349,7 +343,7 @@ public void onError(Exception e) {
public void onCancel() {
Log.d(Constants.TAG,"onCancel");
isDownloading = false;
- cancelNotification(notifyId);
+ NotificationUtils.cancelNotification(getContext(),notifyId);
if(callback!=null){
callback.onCancel();
}
@@ -367,191 +361,6 @@ public void onDestroy() {
super.onDestroy();
}
- //---------------------------------------- Notification
-
- /**
- * 显示开始下载是的通知
- * @param notifyId
- * @param channelId
- * @param channelName
- * @param icon
- * @param title
- * @param content
- */
- private void showStartNotification(int notifyId,String channelId, String channelName,@DrawableRes int icon,CharSequence title,CharSequence content,boolean isVibrate,boolean isSound){
- if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.O){
- createNotificationChannel(channelId,channelName,isVibrate,isSound);
- }
- NotificationCompat.Builder builder = buildNotification(channelId,icon,title,content);
- builder.setPriority(NotificationManager.IMPORTANCE_HIGH);
- if(isVibrate && isSound){
- builder.setDefaults(Notification.DEFAULT_VIBRATE | Notification.DEFAULT_SOUND);
- }else if(isVibrate){
- builder.setDefaults(Notification.DEFAULT_VIBRATE);
- }else if(isSound){
- builder.setDefaults(Notification.DEFAULT_SOUND);
- }
-
- Notification notification = builder.build();
- notification.flags = Notification.FLAG_NO_CLEAR | Notification.FLAG_ONLY_ALERT_ONCE;
- notifyNotification(notifyId,notification);
- }
-
- /**
- * 显示下载中的通知(更新进度)
- * @param notifyId
- * @param channelId
- * @param icon
- * @param title
- * @param content
- * @param progress
- * @param size
- */
- private void showProgressNotification(int notifyId,String channelId,@DrawableRes int icon,CharSequence title,CharSequence content,int progress,int size){
- NotificationCompat.Builder builder = buildNotification(channelId,icon,title,content,progress,size);
-
- Notification notification = builder.build();
- notification.flags = Notification.FLAG_NO_CLEAR | Notification.FLAG_ONLY_ALERT_ONCE;
- notifyNotification(notifyId,notification);
- }
-
- /**
- * 显示下载完成时的通知(点击安装)
- * @param notifyId
- * @param channelId
- * @param icon
- * @param title
- * @param content
- * @param file
- */
- private void showFinishNotification(int notifyId,String channelId,@DrawableRes int icon,CharSequence title,CharSequence content,File file,String authority){
- cancelNotification(notifyId);
- NotificationCompat.Builder builder = buildNotification(channelId,icon,title,content);
- builder.setAutoCancel(true);
- Intent intent = AppUtils.getInstallIntent(getContext(),file,authority);
- PendingIntent clickIntent = PendingIntent.getActivity(getContext(), notifyId,intent, PendingIntent.FLAG_UPDATE_CURRENT);
- builder.setContentIntent(clickIntent);
- Notification notification = builder.build();
- notification.flags = Notification.FLAG_AUTO_CANCEL;
- notifyNotification(notifyId,notification);
- }
-
- private void showErrorNotification(int notifyId,String channelId,@DrawableRes int icon,CharSequence title,CharSequence content,boolean isReDownload,UpdateConfig config){
- NotificationCompat.Builder builder = buildNotification(channelId,icon,title,content);
- builder.setAutoCancel(true);
- if(isReDownload){//重新下载
- Intent intent = new Intent(getContext(),DownloadService.class);
- intent.putExtra(Constants.KEY_RE_DOWNLOAD,true);
- intent.putExtra(Constants.KEY_UPDATE_CONFIG,config);
- PendingIntent clickIntent = PendingIntent.getService(getContext(), notifyId,intent, PendingIntent.FLAG_UPDATE_CURRENT);
- builder.setContentIntent(clickIntent);
- }else{
- PendingIntent clickIntent = PendingIntent.getService(getContext(), notifyId,new Intent(), PendingIntent.FLAG_UPDATE_CURRENT);
- builder.setContentIntent(clickIntent);
- }
-
- Notification notification = builder.build();
- notification.flags = Notification.FLAG_AUTO_CANCEL;
- notifyNotification(notifyId,notification);
- }
-
-
- /**
- * 显示通知信息(非第一次)
- * @param notifyId
- * @param channelId
- * @param icon
- * @param title
- * @param content
- */
- private void showNotification(int notifyId,String channelId,@DrawableRes int icon,CharSequence title,CharSequence content,boolean isAutoCancel){
- NotificationCompat.Builder builder = buildNotification(channelId,icon,title,content);
- builder.setAutoCancel(isAutoCancel);
- Notification notification = builder.build();
- notification.flags = Notification.FLAG_AUTO_CANCEL;
- notifyNotification(notifyId,notification);
- }
-
- /**
- * 取消通知
- * @param notifyId
- */
- private void cancelNotification(int notifyId){
- getNotificationManager().cancel(notifyId);
- }
-
-
- /**
- * 获取通知管理器
- * @return
- */
- private NotificationManager getNotificationManager(){
- return (NotificationManager)getSystemService(Context.NOTIFICATION_SERVICE);
- }
-
- /**
- * 创建一个通知渠道(兼容0以上版本)
- * @param channelId
- * @param channelName
- */
- @RequiresApi(api = Build.VERSION_CODES.O)
- private void createNotificationChannel(String channelId, String channelName,boolean isVibrate,boolean isSound){
- NotificationChannel channel = new NotificationChannel(channelId,channelName, NotificationManager.IMPORTANCE_HIGH);
- channel.enableVibration(isVibrate);
- if(!isSound){
- channel.setSound(null,null);
- }
- getNotificationManager().createNotificationChannel(channel);
-
- }
-
- /**
- * 构建一个通知构建器
- * @param channelId
- * @param icon
- * @param title
- * @param content
- * @return
- */
- private NotificationCompat.Builder buildNotification(String channelId, @DrawableRes int icon,CharSequence title,CharSequence content){
- return buildNotification(channelId,icon,title,content,Constants.NONE,Constants.NONE);
- }
-
- /**
- * 构建一个通知构建器
- * @param channelId
- * @param icon
- * @param title
- * @param content
- * @param progress
- * @param size
- * @return
- */
- private NotificationCompat.Builder buildNotification(String channelId,@DrawableRes int icon,CharSequence title,CharSequence content,int progress,int size){
- NotificationCompat.Builder builder = new NotificationCompat.Builder(getContext(),channelId);
- builder.setSmallIcon(icon);
-
- builder.setContentTitle(title);
- builder.setContentText(content);
- builder.setOngoing(true);
-
- if(progress!= Constants.NONE && size!=Constants.NONE){
- builder.setProgress(size,progress,false);
- }
-
- return builder;
- }
-
- /**
- * 更新通知栏
- * @param id
- * @param notification
- */
- private void notifyNotification(int id, Notification notification){
- getNotificationManager().notify(id,notification);
- }
-
-
//---------------------------------------- Binder
@Nullable