/* * 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; /** * GTaskSyncService是GTask同步的服务类,负责管理GTask同步的启动、取消和进度通知 *

* 该服务提供了以下主要功能: * 1. 启动GTask同步操作 * 2. 取消正在进行的同步操作 * 3. 通过广播通知同步状态和进度 *

*/ 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; /** * GTask同步服务广播的Intent名称 */ 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) { mSyncTask = new GTaskASyncTask(this, new GTaskASyncTask.OnCompleteListener() { public void onComplete() { mSyncTask = null; sendBroadcast(""); stopSelf(); } }); sendBroadcast(""); mSyncTask.execute(); } } /** * 取消正在进行的同步操作 */ private void cancelSync() { if (mSyncTask != null) { mSyncTask.cancelSync(); } } @Override public void onCreate() { mSyncTask = null; } @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(); } } @Override 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); } /** * 启动GTask同步服务 * @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); } /** * 取消GTask同步服务 * @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; } }