|  |  |  | @ -28,7 +28,7 @@ import net.micode.notes.R; | 
			
		
	
		
			
				
					|  |  |  |  | import net.micode.notes.ui.NotesListActivity; | 
			
		
	
		
			
				
					|  |  |  |  | import net.micode.notes.ui.NotesPreferenceActivity; | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | //异步操作类,实现GTask的异步操作过程
 | 
			
		
	
		
			
				
					|  |  |  |  | public class GTaskASyncTask extends AsyncTask<Void, String, Integer> { | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     private static int GTASK_SYNC_NOTIFICATION_ID = 5234235; | 
			
		
	
	
		
			
				
					|  |  |  | @ -62,7 +62,8 @@ public class GTaskASyncTask extends AsyncTask<Void, String, Integer> { | 
			
		
	
		
			
				
					|  |  |  |  |             message | 
			
		
	
		
			
				
					|  |  |  |  |         }); | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |      | 
			
		
	
		
			
				
					|  |  |  |  |     //向用户提示当前同步的状态
 | 
			
		
	
		
			
				
					|  |  |  |  |     private void showNotification(int tickerId, String content) { | 
			
		
	
		
			
				
					|  |  |  |  |         Notification notification = new Notification(R.drawable.notification, mContext | 
			
		
	
		
			
				
					|  |  |  |  |                 .getString(tickerId), System.currentTimeMillis()); | 
			
		
	
	
		
			
				
					|  |  |  | @ -71,22 +72,23 @@ public class GTaskASyncTask extends AsyncTask<Void, String, Integer> { | 
			
		
	
		
			
				
					|  |  |  |  |         PendingIntent pendingIntent; | 
			
		
	
		
			
				
					|  |  |  |  |         if (tickerId != R.string.ticker_success) { | 
			
		
	
		
			
				
					|  |  |  |  |             pendingIntent = PendingIntent.getActivity(mContext, 0, new Intent(mContext, | 
			
		
	
		
			
				
					|  |  |  |  |                     NotesPreferenceActivity.class), 0); | 
			
		
	
		
			
				
					|  |  |  |  |                     NotesPreferenceActivity.class), 0); //如果同步不成功,那么从系统取得一个用于启动一个NotesPreferenceActivity的PendingIntent对象
 | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |         } else { | 
			
		
	
		
			
				
					|  |  |  |  |             pendingIntent = PendingIntent.getActivity(mContext, 0, new Intent(mContext, | 
			
		
	
		
			
				
					|  |  |  |  |                     NotesListActivity.class), 0); | 
			
		
	
		
			
				
					|  |  |  |  |                     NotesListActivity.class), 0); //如果同步成功,那么从系统取得一个用于启动一个NotesListActivity的PendingIntent对象
 | 
			
		
	
		
			
				
					|  |  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |  |         notification.setLatestEventInfo(mContext, mContext.getString(R.string.app_name), content, | 
			
		
	
		
			
				
					|  |  |  |  |                 pendingIntent); | 
			
		
	
		
			
				
					|  |  |  |  |         mNotifiManager.notify(GTASK_SYNC_NOTIFICATION_ID, notification); | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     //完成任务的主要工作
 | 
			
		
	
		
			
				
					|  |  |  |  |     @Override | 
			
		
	
		
			
				
					|  |  |  |  |     protected Integer doInBackground(Void... unused) { | 
			
		
	
		
			
				
					|  |  |  |  |         publishProgess(mContext.getString(R.string.sync_progress_login, NotesPreferenceActivity | 
			
		
	
		
			
				
					|  |  |  |  |                 .getSyncAccountName(mContext))); | 
			
		
	
		
			
				
					|  |  |  |  |         return mTaskManager.sync(mContext, this); | 
			
		
	
		
			
				
					|  |  |  |  |                 .getSyncAccountName(mContext)));//利用getString,将把 NotesPreferenceActivity.getSyncAccountName(mContext))的字符串内容传进sync_progress_login中
 | 
			
		
	
		
			
				
					|  |  |  |  |         return mTaskManager.sync(mContext, this);  //进行后台同步具体操作
 | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     @Override | 
			
		
	
	
		
			
				
					|  |  |  | @ -98,7 +100,7 @@ public class GTaskASyncTask extends AsyncTask<Void, String, Integer> { | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     @Override | 
			
		
	
		
			
				
					|  |  |  |  |     protected void onPostExecute(Integer result) { | 
			
		
	
		
			
				
					|  |  |  |  |     protected void onPostExecute(Integer result) { //用于在执行完后台任务后更新UI,显示结果
 | 
			
		
	
		
			
				
					|  |  |  |  |         if (result == GTaskManager.STATE_SUCCESS) { | 
			
		
	
		
			
				
					|  |  |  |  |             showNotification(R.string.ticker_success, mContext.getString( | 
			
		
	
		
			
				
					|  |  |  |  |                     R.string.success_sync_account, mTaskManager.getSyncAccount())); | 
			
		
	
	
		
			
				
					|  |  |  | @ -110,11 +112,11 @@ public class GTaskASyncTask extends AsyncTask<Void, String, Integer> { | 
			
		
	
		
			
				
					|  |  |  |  |         } 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() { | 
			
		
	
		
			
				
					|  |  |  |  |                 public void run() {//完成后的操作,使用onComplete()将所有值都重新初始化,相当于完成一次操作
 | 
			
		
	
		
			
				
					|  |  |  |  |                     mOnCompleteListener.onComplete(); | 
			
		
	
		
			
				
					|  |  |  |  |                 } | 
			
		
	
		
			
				
					|  |  |  |  |             }).start(); | 
			
		
	
	
		
			
				
					|  |  |  | 
 |