/* * 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.Notification; import android.app.NotificationManager; import android.app.PendingIntent; import android.content.Context; import android.content.Intent; import android.os.AsyncTask; import net.micode.notes.R; import net.micode.notes.ui.NotesListActivity; import net.micode.notes.ui.NotesPreferenceActivity; /** * Google Tasks 同步的异步任务类 * 负责在后台执行与 Google Tasks 的同步操作,并通过通知栏显示进度和结果 */ public class GTaskASyncTask extends AsyncTask { private static int GTASK_SYNC_NOTIFICATION_ID = 5234235; // 同步通知的唯一标识符 /** * 同步完成监听器接口 * 用于在同步任务完成后回调通知调用者 */ public interface OnCompleteListener { void onComplete(); // 同步完成时调用的方法 } private Context mContext; // 应用上下文 private NotificationManager mNotifiManager; // 通知管理器 private GTaskManager mTaskManager; // Google Tasks 管理类实例 private OnCompleteListener mOnCompleteListener; // 同步完成监听器 /** * 构造函数 * @param context 应用上下文 * @param listener 同步完成监听器 */ public GTaskASyncTask(Context context, OnCompleteListener listener) { mContext = context; mOnCompleteListener = listener; // 获取系统通知服务 mNotifiManager = (NotificationManager) mContext .getSystemService(Context.NOTIFICATION_SERVICE); mTaskManager = GTaskManager.getInstance(); // 获取单例的任务管理器 } /** * 取消同步操作 */ public void cancelSync() { mTaskManager.cancelSync(); // 调用任务管理器的取消同步方法 } /** * 发布同步进度 * @param message 进度消息 */ public void publishProgess(String message) { publishProgress(new String[] { message }); // 调用 AsyncTask 的进度发布方法 } /** * 显示通知栏消息 * @param tickerId 通知提示文本的资源 ID * @param content 通知内容 */ private void showNotification(int tickerId, String content) { // 创建通知对象,设置图标、提示文本和时间戳 Notification notification = new Notification(R.drawable.notification, mContext .getString(tickerId), System.currentTimeMillis()); notification.defaults = Notification.DEFAULT_LIGHTS; // 设置默认灯光效果 notification.flags = Notification.FLAG_AUTO_CANCEL; // 设置点击后自动取消 PendingIntent pendingIntent; // 根据通知类型设置点击后的跳转意图 if (tickerId != R.string.ticker_success) { // 非成功通知:跳转到设置页面 pendingIntent = PendingIntent.getActivity(mContext, 0, new Intent(mContext, NotesPreferenceActivity.class), 0); } else { // 成功通知:跳转到便签列表页面 pendingIntent = PendingIntent.getActivity(mContext, 0, new Intent(mContext, NotesListActivity.class), 0); } // 设置通知的详细信息并显示 notification.setLatestEventInfo(mContext, mContext.getString(R.string.app_name), content, pendingIntent); mNotifiManager.notify(GTASK_SYNC_NOTIFICATION_ID, notification); } /** * 后台执行的同步操作 * @param unused 不使用的参数 * @return 同步结果状态码 */ @Override protected Integer doInBackground(Void... unused) { // 发布登录进度 publishProgess(mContext.getString(R.string.sync_progress_login, NotesPreferenceActivity .getSyncAccountName(mContext))); // 调用任务管理器的同步方法并返回结果 return mTaskManager.sync(mContext, this); } /** * 处理进度更新 * @param progress 进度消息数组 */ @Override protected void onProgressUpdate(String... progress) { // 显示同步中的通知 showNotification(R.string.ticker_syncing, progress[0]); // 如果上下文是 GTaskSyncService,发送广播通知进度 if (mContext instanceof GTaskSyncService) { ((GTaskSyncService) mContext).sendBroadcast(progress[0]); } } /** * 同步完成后的处理 * @param result 同步结果状态码 */ @Override protected void onPostExecute(Integer result) { // 根据同步结果显示不同的通知 if (result == GTaskManager.STATE_SUCCESS) { // 同步成功 showNotification(R.string.ticker_success, mContext.getString( R.string.success_sync_account, mTaskManager.getSyncAccount())); // 记录最后同步时间 NotesPreferenceActivity.setLastSyncTime(mContext, System.currentTimeMillis()); } else if (result == GTaskManager.STATE_NETWORK_ERROR) { // 网络错误 showNotification(R.string.ticker_fail, mContext.getString(R.string.error_sync_network)); } else if (result == GTaskManager.STATE_INTERNAL_ERROR) { // 内部错误 showNotification(R.string.ticker_fail, mContext.getString(R.string.error_sync_internal)); } else if (result == GTaskManager.STATE_SYNC_CANCELLED) { // 同步取消 showNotification(R.string.ticker_cancel, mContext .getString(R.string.error_sync_cancelled)); } // 如果设置了完成监听器,则在线程池中执行回调 if (mOnCompleteListener != null) { new Thread(new Runnable() { public void run() { mOnCompleteListener.onComplete(); } }).start(); } } }