|  |  |  | @ -0,0 +1,145 @@ | 
			
		
	
		
			
				
					|  |  |  |  | /* | 
			
		
	
		
			
				
					|  |  |  |  |  * 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; | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | // 导入必要的Android类
 | 
			
		
	
		
			
				
					|  |  |  |  | import android.app.Activity; | 
			
		
	
		
			
				
					|  |  |  |  | import android.app.Service; | 
			
		
	
		
			
				
					|  |  |  |  | import android.content.Context; | 
			
		
	
		
			
				
					|  |  |  |  | import android.content.Intent; | 
			
		
	
		
			
				
					|  |  |  |  | import android.os.Bundle; | 
			
		
	
		
			
				
					|  |  |  |  | import android.os.IBinder; | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | // 定义一个继承自Service的类,用于同步任务
 | 
			
		
	
		
			
				
					|  |  |  |  | public class GTaskSyncService extends Service { | 
			
		
	
		
			
				
					|  |  |  |  |     // 定义同步动作名称的常量
 | 
			
		
	
		
			
				
					|  |  |  |  |     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) { // 如果当前没有正在执行的同步任务
 | 
			
		
	
		
			
				
					|  |  |  |  |             mSyncTask = new GTaskASyncTask(this, new GTaskASyncTask.OnCompleteListener() { | 
			
		
	
		
			
				
					|  |  |  |  |                 public void onComplete() { | 
			
		
	
		
			
				
					|  |  |  |  |                     mSyncTask = null; // 任务完成后,将任务对象置为null
 | 
			
		
	
		
			
				
					|  |  |  |  |                     sendBroadcast(""); // 发送广播,通知同步完成
 | 
			
		
	
		
			
				
					|  |  |  |  |                     stopSelf(); // 停止服务
 | 
			
		
	
		
			
				
					|  |  |  |  |                 } | 
			
		
	
		
			
				
					|  |  |  |  |             }); | 
			
		
	
		
			
				
					|  |  |  |  |             sendBroadcast(""); // 发送广播,通知开始同步(这里可能需要发送具体信息)
 | 
			
		
	
		
			
				
					|  |  |  |  |             mSyncTask.execute(); // 执行异步任务
 | 
			
		
	
		
			
				
					|  |  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 取消同步的私有方法
 | 
			
		
	
		
			
				
					|  |  |  |  |     private void cancelSync() { | 
			
		
	
		
			
				
					|  |  |  |  |         if (mSyncTask != null) { // 如果当前有正在执行的同步任务
 | 
			
		
	
		
			
				
					|  |  |  |  |             mSyncTask.cancelSync(); // 取消任务
 | 
			
		
	
		
			
				
					|  |  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 当服务被创建时调用
 | 
			
		
	
		
			
				
					|  |  |  |  |     @Override | 
			
		
	
		
			
				
					|  |  |  |  |     public void onCreate() { | 
			
		
	
		
			
				
					|  |  |  |  |         mSyncTask = null; // 初始化同步任务对象为null
 | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 当服务被命令启动时调用
 | 
			
		
	
		
			
				
					|  |  |  |  |     @Override | 
			
		
	
		
			
				
					|  |  |  |  |     public int onStartCommand(Intent intent, int flags, int startId) { | 
			
		
	
		
			
				
					|  |  |  |  |         Bundle bundle = intent.getExtras(); // 获取Intent中的附加数据
 | 
			
		
	
		
			
				
					|  |  |  |  |         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; // 如果服务被杀死,系统会重新创建服务并调用onStartCommand方法
 | 
			
		
	
		
			
				
					|  |  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |  |         return super.onStartCommand(intent, flags, startId); // 如果没有指定动作,则调用父类方法
 | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 当设备内存不足时调用
 | 
			
		
	
		
			
				
					|  |  |  |  |     @Override | 
			
		
	
		
			
				
					|  |  |  |  |     public void onLowMemory() { | 
			
		
	
		
			
				
					|  |  |  |  |         if (mSyncTask != null) { // 如果当前有正在执行的同步任务
 | 
			
		
	
		
			
				
					|  |  |  |  |             mSyncTask.cancelSync(); // 取消任务以释放内存
 | 
			
		
	
		
			
				
					|  |  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 返回null,因为此服务不绑定客户端
 | 
			
		
	
		
			
				
					|  |  |  |  |     public IBinder onBind(Intent intent) { | 
			
		
	
		
			
				
					|  |  |  |  |         return null; | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 发送广播的方法,用于通知同步进度等信息
 | 
			
		
	
		
			
				
					|  |  |  |  |     public void sendBroadcast(String msg) { | 
			
		
	
		
			
				
					|  |  |  |  |         mSyncProgress = msg; // 更新同步进度信息
 | 
			
		
	
		
			
				
					|  |  |  |  |         Intent intent = new Intent(GTASK_SERVICE_BROADCAST_NAME); // 创建广播Intent
 | 
			
		
	
		
			
				
					|  |  |  |  |         intent.putExtra(GTASK_SERVICE_BROADCAST_IS_SYNCING, mSyncTask != null); // 是否正在同步
 | 
			
		
	
		
			
				
					|  |  |  |  |         intent.putExtra(GTASK_SERVICE_BROADCAST_PROGRESS_MSG, msg); // 同步进度信息
 | 
			
		
	
		
			
				
					|  |  |  |  |         sendBroadcast(intent); // 发送广播
 | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 提供一个静态方法,用于从Activity启动同步服务
 | 
			
		
	
		
			
				
					|  |  |  |  |     public static void startSync(Activity activity) { | 
			
		
	
		
			
				
					|  |  |  |  |         GTaskManager.getInstance().setActivityContext(activity); // 设置GTaskManager的Activity上下文
 | 
			
		
	
		
			
				
					|  |  |  |  |         Intent intent = new Intent(activity, GTaskSyncService.class); // 创建Intent
 | 
			
		
	
		
			
				
					|  |  |  |  |         intent.putExtra(GTaskSyncService.ACTION_STRING_NAME, GTaskSyncService.ACTION_START_SYNC); // 添加动作类型
 | 
			
		
	
		
			
				
					|  |  |  |  |         activity.startService(intent); // 启动服务
 | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 提供一个静态方法,用于从Context取消同步服务
 | 
			
		
	
		
			
				
					|  |  |  |  |     public static void cancelSync(Context context) { | 
			
		
	
		
			
				
					|  |  |  |  |         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() { | 
			
		
	
		
			
				
					|  |  |  |  |         return mSyncTask != null; // 返回mSyncTask是否为null
 | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     // 提供一个静态方法,用于获取同步进度信息
 | 
			
		
	
		
			
				
					|  |  |  |  |     public static String getProgressString() { | 
			
		
	
		
			
				
					|  |  |  |  |         return mSyncProgress; // 返回mSyncProgress的值
 | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | } |