मैंने एक सप्ताह के लिए इस दुविधा का हल ढूंढने के लिए टाल दिया है कि मैनिफ़ेस्ट फ़ाइल का संपादन किए बिना। इस समाधान की धारणाएं हैं:
- आपको हमेशा एक प्रगति संवाद का उपयोग करने की आवश्यकता होती है
- एक समय में केवल एक ही कार्य किया जाता है
- जब फोन घुमाया जाता है और प्रगति संवाद स्वचालित रूप से खारिज हो जाता है, तो आपको कार्य जारी रखने की आवश्यकता होती है।
कार्यान्वयन
आपको इस पोस्ट के नीचे मिली दो फाइलों को अपने कार्यक्षेत्र में कॉपी करना होगा। बस यह सुनिश्चित करें कि:
आपके सभी का Activity
विस्तार होना चाहिएBaseActivity
में onCreate()
, super.onCreate()
आप किसी भी सदस्य को प्रारंभ बाद भी आपके द्वारा पहुँचा जा करने की आवश्यकता पर बुलाया जाना चाहिए ASyncTask
है। इसके अलावा, getContentViewId()
फ़ॉर्म लेआउट आईडी प्रदान करने के लिए ओवरराइड करें।
गतिविधि द्वारा प्रबंधित संवाद बनाने के लिए onCreateDialog()
हमेशा की तरह ओवरराइड करें ।
अपने AsyncTasks बनाने के लिए एक नमूना स्थिर आंतरिक वर्ग के लिए नीचे दिया गया कोड देखें। आप बाद में एक्सेस करने के लिए अपना परिणाम mResult में स्टोर कर सकते हैं।
final static class MyTask extends SuperAsyncTask<Void, Void, Void> {
public OpenDatabaseTask(BaseActivity activity) {
super(activity, MY_DIALOG_ID); // change your dialog ID here...
// and your dialog will be managed automatically!
}
@Override
protected Void doInBackground(Void... params) {
// your task code
return null;
}
@Override
public boolean onAfterExecute() {
// your after execute code
}
}
और अंत में, अपने नए कार्य को शुरू करने के लिए:
mCurrentTask = new MyTask(this);
((MyTask) mCurrentTask).execute();
बस! मुझे उम्मीद है कि यह मजबूत समाधान किसी की मदद करेगा।
BaseActivity.java (स्वयं आयात व्यवस्थित करें)
protected abstract int getContentViewId();
public abstract class BaseActivity extends Activity {
protected SuperAsyncTask<?, ?, ?> mCurrentTask;
public HashMap<Integer, Boolean> mDialogMap = new HashMap<Integer, Boolean>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(getContentViewId());
mCurrentTask = (SuperAsyncTask<?, ?, ?>) getLastNonConfigurationInstance();
if (mCurrentTask != null) {
mCurrentTask.attach(this);
if (mDialogMap.get((Integer) mCurrentTask.dialogId) != null
&& mDialogMap.get((Integer) mCurrentTask.dialogId)) {
mCurrentTask.postExecution();
}
}
}
@Override
protected void onPrepareDialog(int id, Dialog dialog) {
super.onPrepareDialog(id, dialog);
mDialogMap.put(id, true);
}
@Override
public Object onRetainNonConfigurationInstance() {
if (mCurrentTask != null) {
mCurrentTask.detach();
if (mDialogMap.get((Integer) mCurrentTask.dialogId) != null
&& mDialogMap.get((Integer) mCurrentTask.dialogId)) {
return mCurrentTask;
}
}
return super.onRetainNonConfigurationInstance();
}
public void cleanupTask() {
if (mCurrentTask != null) {
mCurrentTask = null;
System.gc();
}
}
}
SuperAsyncTask.java
public abstract class SuperAsyncTask<Params, Progress, Result> extends AsyncTask<Params, Progress, Result> {
protected BaseActivity mActivity = null;
protected Result mResult;
public int dialogId = -1;
protected abstract void onAfterExecute();
public SuperAsyncTask(BaseActivity activity, int dialogId) {
super();
this.dialogId = dialogId;
attach(activity);
}
@Override
protected void onPreExecute() {
super.onPreExecute();
mActivity.showDialog(dialogId); // go polymorphism!
}
protected void onPostExecute(Result result) {
super.onPostExecute(result);
mResult = result;
if (mActivity != null &&
mActivity.mDialogMap.get((Integer) dialogId) != null
&& mActivity.mDialogMap.get((Integer) dialogId)) {
postExecution();
}
};
public void attach(BaseActivity activity) {
this.mActivity = activity;
}
public void detach() {
this.mActivity = null;
}
public synchronized boolean postExecution() {
Boolean dialogExists = mActivity.mDialogMap.get((Integer) dialogId);
if (dialogExists != null || dialogExists) {
onAfterExecute();
cleanUp();
}
public boolean cleanUp() {
mActivity.removeDialog(dialogId);
mActivity.mDialogMap.remove((Integer) dialogId);
mActivity.cleanupTask();
detach();
return true;
}
}