/* * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) * * 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://www.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. */ 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; /** *

Google任务同步服务类。

*

设计意图:作为Android服务组件,管理Google任务的同步操作,提供同步的启动和取消功能。

*

核心职责:

* *

与其他类的关键关联:

* */ public class GTaskSyncService extends Service { /** * 操作类型的Intent extra键名 */ 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"; /** * 广播中表示是否正在同步的extra键名 */ public final static String GTASK_SERVICE_BROADCAST_IS_SYNCING = "isSyncing"; /** * 广播中表示同步进度消息的extra键名 */ public final static String GTASK_SERVICE_BROADCAST_PROGRESS_MSG = "progressMsg"; /** * 当前正在执行的同步任务实例 */ private static GTaskASyncTask mSyncTask = null; /** * 当前同步进度消息 */ private static String mSyncProgress = ""; /** * 启动Google任务同步操作。 * *

业务逻辑:

* */ private void startSync() { if (mSyncTask == null) { mSyncTask = new GTaskASyncTask(this, new GTaskASyncTask.OnCompleteListener() { public void onComplete() { mSyncTask = null; sendBroadcast(""); stopSelf(); } }); sendBroadcast(""); mSyncTask.execute(); } } /** * 取消正在执行的Google任务同步操作。 * *

业务逻辑:

* */ private void cancelSync() { if (mSyncTask != null) { mSyncTask.cancelSync(); } } /** * 创建服务时的回调方法。 * *

业务逻辑:

* */ @Override public void onCreate() { mSyncTask = null; } /** * 服务启动时的回调方法,处理启动服务的Intent。 * *

业务逻辑:

* * * @param intent 启动服务的Intent * @param flags 启动标志 * @param startId 启动ID * @return 服务的启动模式 */ @Override public int onStartCommand(Intent intent, int flags, int startId) { 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; } return START_STICKY; } return super.onStartCommand(intent, flags, startId); } /** * 系统内存不足时的回调方法。 * *

业务逻辑:

* */ @Override public void onLowMemory() { if (mSyncTask != null) { mSyncTask.cancelSync(); } } /** * 绑定服务时的回调方法。 * *

业务逻辑:

* * * @param intent 绑定服务的Intent * @return 绑定接口,此处返回null */ public IBinder onBind(Intent intent) { return null; } /** * 发送同步状态的广播。 * *

业务逻辑:

* * * @param msg 同步进度消息 */ public void sendBroadcast(String msg) { mSyncProgress = msg; Intent intent = new Intent(GTASK_SERVICE_BROADCAST_NAME); intent.putExtra(GTASK_SERVICE_BROADCAST_IS_SYNCING, mSyncTask != null); intent.putExtra(GTASK_SERVICE_BROADCAST_PROGRESS_MSG, msg); sendBroadcast(intent); } /** * 静态方法:启动Google任务同步服务。 * *

业务逻辑:

* * * @param activity 调用该方法的Activity实例 */ public static void startSync(Activity activity) { GTaskManager.getInstance().setActivityContext(activity); Intent intent = new Intent(activity, GTaskSyncService.class); intent.putExtra(GTaskSyncService.ACTION_STRING_NAME, GTaskSyncService.ACTION_START_SYNC); activity.startService(intent); } /** * 静态方法:取消Google任务同步服务。 * *

业务逻辑:

* * * @param context 调用该方法的上下文 */ public static void cancelSync(Context context) { Intent intent = new Intent(context, GTaskSyncService.class); intent.putExtra(GTaskSyncService.ACTION_STRING_NAME, GTaskSyncService.ACTION_CANCEL_SYNC); context.startService(intent); } /** * 静态方法:检查是否正在进行同步操作。 * *

业务逻辑:

* * * @return true表示正在同步,false表示没有同步操作进行 */ public static boolean isSyncing() { return mSyncTask != null; } /** * 静态方法:获取当前同步进度消息。 * *

业务逻辑:

* * * @return 当前同步进度消息 */ public static String getProgressString() { return mSyncProgress; } }