|
|
|
@ -0,0 +1,177 @@
|
|
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2010 - 2011, The MiCode Open Source Community (www.micode.net)
|
|
|
|
|
*
|
|
|
|
|
* 遵循 Apache 许可证 2.0 版(“许可证”);
|
|
|
|
|
* 除非遵守许可证,否则不得使用此文件。
|
|
|
|
|
* 你可以在以下网址获取许可证副本:
|
|
|
|
|
*
|
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
*
|
|
|
|
|
* 除非适用法律要求或书面同意,
|
|
|
|
|
* 根据许可证分发的软件按“原样”分发,
|
|
|
|
|
* 不附带任何明示或暗示的保证或条件。
|
|
|
|
|
* 请参阅许可证,了解具体的权限和限制。
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
package net.micode.notes.gtask.remote;
|
|
|
|
|
|
|
|
|
|
import android.app.Activity;
|
|
|
|
|
import android.app.Service;
|
|
|
|
|
import android.content.Context;
|
|
|
|
|
import android.content.Intent;
|
|
|
|
|
import android.os.Bundle;
|
|
|
|
|
import android.os.IBinder;
|
|
|
|
|
|
|
|
|
|
// GTaskSyncService 是一个 Android 服务类,用于管理 Google 任务(GTask)的同步操作
|
|
|
|
|
// 提供了启动同步、取消同步的功能,并通过广播通知同步状态和进度
|
|
|
|
|
public class GTaskSyncService extends Service {
|
|
|
|
|
// 用于在 Intent 中传递同步操作类型的字符串名称
|
|
|
|
|
public final static String ACTION_STRING_NAME = "sync_action_type";
|
|
|
|
|
// 启动同步操作的类型标识
|
|
|
|
|
public final static int ACTION_START_SYNC = 0;
|
|
|
|
|
// 取消同步操作的类型标识
|
|
|
|
|
public final static int ACTION_CANCEL_SYNC = 1;
|
|
|
|
|
// 无效操作的类型标识
|
|
|
|
|
public final static int ACTION_INVALID = 2;
|
|
|
|
|
// 用于发送广播的名称
|
|
|
|
|
public final static String GTASK_SERVICE_BROADCAST_NAME = "net.micode.notes.gtask.remote.gtask_sync_service";
|
|
|
|
|
// 广播中用于表示是否正在同步的字段名称
|
|
|
|
|
public final static String GTASK_SERVICE_BROADCAST_IS_SYNCING = "isSyncing";
|
|
|
|
|
// 广播中用于表示同步进度消息的字段名称
|
|
|
|
|
public final static String GTASK_SERVICE_BROADCAST_PROGRESS_MSG = "progressMsg";
|
|
|
|
|
|
|
|
|
|
// 当前正在执行的同步任务
|
|
|
|
|
private static GTaskASyncTask mSyncTask = null;
|
|
|
|
|
// 当前同步的进度消息
|
|
|
|
|
private static String mSyncProgress = "";
|
|
|
|
|
|
|
|
|
|
// 启动同步任务的方法
|
|
|
|
|
private void startSync() {
|
|
|
|
|
// 如果同步任务尚未创建
|
|
|
|
|
if (mSyncTask == null) {
|
|
|
|
|
// 创建一个新的 GTaskASyncTask 实例,并传入当前服务上下文和一个任务完成监听器
|
|
|
|
|
mSyncTask = new GTaskASyncTask(this, new GTaskASyncTask.OnCompleteListener() {
|
|
|
|
|
// 当同步任务完成时,执行该方法
|
|
|
|
|
public void onComplete() {
|
|
|
|
|
// 将同步任务实例置为 null
|
|
|
|
|
mSyncTask = null;
|
|
|
|
|
// 发送广播通知同步完成,消息为空字符串
|
|
|
|
|
sendBroadcast("");
|
|
|
|
|
// 停止当前服务
|
|
|
|
|
stopSelf();
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
// 发送广播通知同步开始,消息为空字符串
|
|
|
|
|
sendBroadcast("");
|
|
|
|
|
// 执行同步任务
|
|
|
|
|
mSyncTask.execute();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 取消同步任务的方法
|
|
|
|
|
private void cancelSync() {
|
|
|
|
|
// 如果同步任务正在进行
|
|
|
|
|
if (mSyncTask!= null) {
|
|
|
|
|
// 调用同步任务的取消同步方法
|
|
|
|
|
mSyncTask.cancelSync();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 当服务创建时调用的方法
|
|
|
|
|
@Override
|
|
|
|
|
public void onCreate() {
|
|
|
|
|
// 将同步任务实例置为 null
|
|
|
|
|
mSyncTask = null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 当服务接收到启动命令时调用的方法
|
|
|
|
|
@Override
|
|
|
|
|
public int onStartCommand(Intent intent, int flags, int startId) {
|
|
|
|
|
// 获取 Intent 中携带的额外数据
|
|
|
|
|
Bundle bundle = intent.getExtras();
|
|
|
|
|
// 如果额外数据存在且包含同步操作类型字段
|
|
|
|
|
if (bundle!= null && bundle.containsKey(ACTION_STRING_NAME)) {
|
|
|
|
|
// 根据同步操作类型执行相应的操作
|
|
|
|
|
switch (bundle.getInt(ACTION_STRING_NAME, ACTION_INVALID)) {
|
|
|
|
|
case ACTION_START_SYNC:
|
|
|
|
|
// 启动同步任务
|
|
|
|
|
startSync();
|
|
|
|
|
break;
|
|
|
|
|
case ACTION_CANCEL_SYNC:
|
|
|
|
|
// 取消同步任务
|
|
|
|
|
cancelSync();
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
// 返回 START_STICKY 表示如果服务被系统杀死,在有足够内存时会自动重启
|
|
|
|
|
return START_STICKY;
|
|
|
|
|
}
|
|
|
|
|
// 如果未包含同步操作类型字段,调用父类的 onStartCommand 方法
|
|
|
|
|
return super.onStartCommand(intent, flags, startId);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 当系统内存不足时调用的方法
|
|
|
|
|
@Override
|
|
|
|
|
public void onLowMemory() {
|
|
|
|
|
// 如果同步任务正在进行
|
|
|
|
|
if (mSyncTask!= null) {
|
|
|
|
|
// 取消同步任务
|
|
|
|
|
mSyncTask.cancelSync();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 当客户端绑定到服务时调用的方法,由于该服务不支持绑定,返回 null
|
|
|
|
|
@Override
|
|
|
|
|
public IBinder onBind(Intent intent) {
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 发送广播的方法,用于通知同步状态和进度
|
|
|
|
|
public void sendBroadcast(String msg) {
|
|
|
|
|
// 更新同步进度消息
|
|
|
|
|
mSyncProgress = msg;
|
|
|
|
|
// 创建一个新的 Intent,设置广播名称
|
|
|
|
|
Intent intent = new Intent(GTASK_SERVICE_BROADCAST_NAME);
|
|
|
|
|
// 在 Intent 中添加是否正在同步的信息
|
|
|
|
|
intent.putExtra(GTASK_SERVICE_BROADCAST_IS_SYNCING, mSyncTask!= null);
|
|
|
|
|
// 在 Intent 中添加同步进度消息
|
|
|
|
|
intent.putExtra(GTASK_SERVICE_BROADCAST_PROGRESS_MSG, msg);
|
|
|
|
|
// 发送广播
|
|
|
|
|
sendBroadcast(intent);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 外部调用启动同步的静态方法
|
|
|
|
|
public static void startSync(Activity activity) {
|
|
|
|
|
// 设置 GTaskManager 的 Activity 上下文
|
|
|
|
|
GTaskManager.getInstance().setActivityContext(activity);
|
|
|
|
|
// 创建一个 Intent,指定要启动的服务为 GTaskSyncService
|
|
|
|
|
Intent intent = new Intent(activity, GTaskSyncService.class);
|
|
|
|
|
// 在 Intent 中添加启动同步的操作类型
|
|
|
|
|
intent.putExtra(GTaskSyncService.ACTION_STRING_NAME, GTaskSyncService.ACTION_START_SYNC);
|
|
|
|
|
// 启动服务
|
|
|
|
|
activity.startService(intent);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 外部调用取消同步的静态方法
|
|
|
|
|
public static void cancelSync(Context context) {
|
|
|
|
|
// 创建一个 Intent,指定要启动的服务为 GTaskSyncService
|
|
|
|
|
Intent intent = new Intent(context, GTaskSyncService.class);
|
|
|
|
|
// 在 Intent 中添加取消同步的操作类型
|
|
|
|
|
intent.putExtra(GTaskSyncService.ACTION_STRING_NAME, GTaskSyncService.ACTION_CANCEL_SYNC);
|
|
|
|
|
// 启动服务
|
|
|
|
|
context.startService(intent);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 判断是否正在进行同步的静态方法
|
|
|
|
|
public static boolean isSyncing() {
|
|
|
|
|
// 通过判断同步任务实例是否为 null 来确定是否正在同步
|
|
|
|
|
return mSyncTask!= null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 获取当前同步进度消息的静态方法
|
|
|
|
|
public static String getProgressString() {
|
|
|
|
|
// 返回当前的同步进度消息
|
|
|
|
|
return mSyncProgress;
|
|
|
|
|
}
|
|
|
|
|
}
|