Я пытаюсь показать Диалог на прогресс в спиннинге, но он дает мне ошибку, когда я помещаю код в класс Async Tasking. >
public class Utilssss extends AsyncTask {
private Context mContext;
private ProgressDialog pdia;
// constructor
public Utilssss(Context activityContext) {
mContext = activityContext;
}
protected void onPreExecute() {
super.onPreExecute();
pdia = new ProgressDialog(mContext);
pdia.setMessage("Loading...");
pdia.show();
}
protected String doInBackground(String... url) {
return GetLinkss(url[0]);
}
protected void onPostExecute(String result) {
// Toast.makeText(mContext, result, Toast.LENGTH_LONG).show();
super.onPostExecute(result);
pdia.dismiss();
}
private String GetLinkss(String url) {
// your stuff
String StringBuffer = "";
String stringText = "";
try {
URL link = new URL(url);
BufferedReader bufferReader = new BufferedReader(new InputStreamReader(link.openStream()));
while ((StringBuffer = bufferReader.readLine()) != null) {
stringText += StringBuffer;
}
bufferReader.close();
} catch (MalformedURLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return stringText;
}
}
< /code>
Код, как я доступ к этому классу < /p>
public void urdu(View view) throws InterruptedException, ExecutionException {
String fileexist = null;
fileexist = new Utilssss(getBaseContext()).execute("http://192.168.1.2/eWorldLiterature/urdu/index.txt").get();
Toast.makeText(getBaseContext(), fileexist, Toast.LENGTH_SHORT).show();
// if (fileexist != 229) {
Intent i = new Intent(getBaseContext(), MainPage.class);
i.putExtra(LANGUAGE, "urdu");
startActivity(i);
< /code>
Вот результаты logcat. < /p>
12-05 00:38:06.266: E/AndroidRuntime(28766): FATAL EXCEPTION: main
12-05 00:38:06.266: E/AndroidRuntime(28766): java.lang.IllegalStateException: Could not execute method of the activity
12-05 00:38:06.266: E/AndroidRuntime(28766): at android.view.View$1.onClick(View.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at android.view.View.performClick(View.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at android.view.View$PerformClick.run(View.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at android.os.Handler.handleCallback(Handler.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at android.os.Handler.dispatchMessage(Handler.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at android.os.Looper.loop(Looper.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at android.app.ActivityThread.main(ActivityThread.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at java.lang.reflect.Method.invokeNative(Native Method)
12-05 00:38:06.266: E/AndroidRuntime(28766): at java.lang.reflect.Method.invoke(Method.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at dalvik.system.NativeStart.main(Native Method)
12-05 00:38:06.266: E/AndroidRuntime(28766): Caused by: java.lang.reflect.InvocationTargetException
12-05 00:38:06.266: E/AndroidRuntime(28766): at java.lang.reflect.Method.invokeNative(Native Method)
12-05 00:38:06.266: E/AndroidRuntime(28766): at java.lang.reflect.Method.invoke(Method.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): ... 12 more
12-05 00:38:06.266: E/AndroidRuntime(28766): Caused by: android.view.WindowManager$BadTokenException: Unable to add window -- token null is not for an application
12-05 00:38:06.266: E/AndroidRuntime(28766): at android.view.ViewRootImpl.setView(ViewRootImpl.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at android.view.WindowManagerImpl$CompatModeWrapper.addView(WindowManagerImpl.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at android.app.Dialog.show(Dialog.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at md.literature.imranseries.Utilssss.onPreExecute(Utilssss.java:35)
12-05 00:38:06.266: E/AndroidRuntime(28766): at android.os.AsyncTask.executeOnExecutor(AsyncTask.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at android.os.AsyncTask.execute(AsyncTask.java)
12-05 00:38:06.266: E/AndroidRuntime(28766): at md.literature.imranseries.Selection.urdu(Selection.java:65)
12-05 00:38:06.266: E/AndroidRuntime(28766): ... 14 more
< /code>
Просто еще одна вещь, которую я хочу спросить. Извините, что снова беспокоит вас, ребята ..
Вот в чем дело, одна из моей деятельности опирается на результаты Asynctas что доказывает. < /p>
final Context context = this;
new Utils(context, new Utils.UtilsCallback() {
@Override
public void onResult(String lstr) {
// lstr = string;
Toast.makeText(getBaseContext(), "Now Raeading" + Novelselected, Toast.LENGTH_LONG).show();
}
}).execute(ulti_link + "/" + Novelselected.replace(" ", "%20") + ".txt");
Toast.makeText(getBaseContext(), "Now Raeading", Toast.LENGTH_LONG).show();
< /code>
В приведенном выше коде, следующее тост появляется перед появлением тоста в Asynctas Полем
Большое спасибо
Подробнее здесь: https://stackoverflow.com/questions/203 ... task-class
Мобильная версия