2013-07-31 4 views
1

Я хочу получить диалоговое окно с предупреждением внутри async Задача onClick of ListItem. Ниже приведены ссылки, которые я перешел к деятельности «getbaseContext()», «ClassName.this», «this»; но ничего не получилось, и он потерпел крушение. Есть идеи ?AlertDialog onclick ListItem в AsyncTask

Async.java

общественный класс Асинхронный расширяет активность {

/** Called when the activity is first created. */ 

ListView _rssFeedListView; 
List<JSONObject> jobs; 
List<RssFeedStructure> rssStr; 
private BlogAdapter _adapter; 
TextView textview; 
Context context; 
AlertDialog.Builder builder 
@Override 
public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.listview); 

    //context = getApplicationContext(); 

    _rssFeedListView = (ListView) findViewById(R.id.rssfeed_listview); 
    builder = new AlertDialog.Builder(getApplicationContext()); 
    textview = (TextView) findViewById(R.id.loading); 
    RssFeedTask rssTask = new RssFeedTask(); 
    rssTask.execute(); 

    _rssFeedListView.setOnItemClickListener(new OnItemClickListener() { 

     @Override 
     public void onItemClick(AdapterView<?> parent, View view, int position, long id) { 

      //AlertDialog.Builder builder = new AlertDialog.Builder(getApplicationContext()); 
      // builder.setCancelable(true); 
      builder.setTitle("Invitation sent unsuccesful.Please try again !"); 
      // builder.setInverseBackgroundForced(true); 

      builder.setNegativeButton(
        "Ok",null 

        ); 


      builder.show(); 


     } 
    }); 



} 


private class RssFeedTask extends AsyncTask<String, Void, String> { 
    // private String Content; 
    // private ProgressDialog Dialog; 
    String response = ""; 
    AlertDialog.Builder alert; 


    @Override 
    protected void onPreExecute() { 
    } 

    @Override 
    protected String doInBackground(String... urls) { 
     try { 

      String feed = "http://url"; 
      XmlHandler rh = new XmlHandler(); 
      rssStr = rh.getLatestArticles(feed); 
     } catch (Exception e) { 
     } 
     return response; 

    } 

    @Override 
    protected void onPostExecute(String result) { 
     if (rssStr != null) { 

      _adapter = new BlogAdapter(Async.this, rssStr); 
      _rssFeedListView.setAdapter(_adapter); 
      textview.setVisibility(View.INVISIBLE); 


     } 


    } 

} 

} 

Ошибка: 07-31 16:45:56.615: E/AndroidRuntime(28575): FATAL EXCEPTION: main 07-31 16:45:56.615: E/AndroidRuntime(28575): android.view.WindowManager$BadTokenException: Unable to add window -- token null is not for an application 07-31 16:45:56.615: E/AndroidRuntime(28575): at android.view.ViewRootImpl.setView(ViewRootImpl.java:712) 07-31 16:45:56.615: E/AndroidRuntime(28575): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:346) 07-31 16:45:56.615: E/AndroidRuntime(28575): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:224) 07-31 16:45:56.615: E/AndroidRuntime(28575): at android.view.WindowManagerImpl$CompatModeWrapper.addView(WindowManagerImpl.java:149) 07-31 16:45:56.615: E/AndroidRuntime(28575): at android.app.Dialog.show(Dialog.java:277) 07-31 16:45:56.615: E/AndroidRuntime(28575): at android.app.AlertDialog$Builder.show(AlertDialog.java:932) 07-31 16:45:56.615: E/AndroidRuntime(28575): at com.itcuties.multicategoryrssreader.BlogFeeds$1.onItemClick(BlogFeeds.java:86) 07-31 16:45:56.615: E/AndroidRuntime(28575): at android.widget.AdapterView.performItemClick(AdapterView.java:298) 07-31 16:45:56.615: E/AndroidRuntime(28575): at android.widget.AbsListView.performItemClick(AbsListView.java:1283) 07-31 16:45:56.615: E/AndroidRuntime(28575): at android.widget.AbsListView$PerformClick.run(AbsListView.java:3074) 07-31 16:45:56.615: E/AndroidRuntime(28575): at android.widget.AbsListView$1.run(AbsListView.java:4147) 07-31 16:45:56.615: E/AndroidRuntime(28575): at android.os.Handler.handleCallback(Handler.java:615) 07-31 16:45:56.615: E/AndroidRuntime(28575): at android.os.Handler.dispatchMessage(Handler.java:92) 07-31 16:45:56.615: E/AndroidRuntime(28575): at android.os.Looper.loop(Looper.java:137) 07-31 16:45:56.615: E/AndroidRuntime(28575): at android.app.ActivityThread.main(ActivityThread.java:4898) 07-31 16:45:56.615: E/AndroidRuntime(28575): at java.lang.reflect.Method.invokeNative(Native Method) 07-31 16:45:56.615: E/AndroidRuntime(28575): at java.lang.reflect.Method.invoke(Method.java:511) 07-31 16:45:56.615: E/AndroidRuntime(28575): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1008) 07-31 16:45:56.615: E/AndroidRuntime(28575): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:775) 07-31 16:45:56.615: E/AndroidRuntime(28575): at dalvik.system.NativeStart.main(Native Method)

ошибки, полученные в Manish & предложение Раджи в:

07-31 17:53:35.210: E/AndroidRuntime(8442): FATAL EXCEPTION: main 07-31 17:53:35.210: E/AndroidRuntime(8442): android.view.WindowManager$BadTokenException: Unable to add window -- token [email protected] is not valid; is your activity running? 07-31 17:53:35.210: E/AndroidRuntime(8442): at android.view.ViewRootImpl.setView(ViewRootImpl.java:708) 07-31 17:53:35.210: E/AndroidRuntime(8442): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:346) 07-31 17:53:35.210: E/AndroidRuntime(8442): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:224) 07-31 17:53:35.210: E/AndroidRuntime(8442): at android.view.WindowManagerImpl$CompatModeWrapper.addView(WindowManagerImpl.java:149) 07-31 17:53:35.210: E/AndroidRuntime(8442): at android.view.Window$LocalWindowManager.addView(Window.java:554) 07-31 17:53:35.210: E/AndroidRuntime(8442): at android.app.Dialog.show(Dialog.java:277) 07-31 17:53:35.210: E/AndroidRuntime(8442): at android.app.AlertDialog$Builder.show(AlertDialog.java:932) 07-31 17:53:35.210: E/AndroidRuntime(8442): at com.itcuties.multicategoryrssreader.BlogFeeds$1.onItemClick(BlogFeeds.java:78) 07-31 17:53:35.210: E/AndroidRuntime(8442): at android.widget.AdapterView.performItemClick(AdapterView.java:298) 07-31 17:53:35.210: E/AndroidRuntime(8442): at android.widget.AbsListView.performItemClick(AbsListView.java:1283) 07-31 17:53:35.210: E/AndroidRuntime(8442): at android.widget.AbsListView$PerformClick.run(AbsListView.java:3074) 07-31 17:53:35.210: E/AndroidRuntime(8442): at android.widget.AbsListView$1.run(AbsListView.java:4147) 07-31 17:53:35.210: E/AndroidRuntime(8442): at android.os.Handler.handleCallback(Handler.java:615) 07-31 17:53:35.210: E/AndroidRuntime(8442): at android.os.Handler.dispatchMessage(Handler.java:92) 07-31 17:53:35.210: E/AndroidRuntime(8442): at android.os.Looper.loop(Looper.java:137) 07-31 17:53:35.210: E/AndroidRuntime(8442): at android.app.ActivityThread.main(ActivityThread.java:4898) 07-31 17:53:35.210: E/AndroidRuntime(8442): at java.lang.reflect.Method.invokeNative(Native Method) 07-31 17:53:35.210: E/AndroidRuntime(8442): at java.lang.reflect.Method.invoke(Method.java:511) 07-31 17:53:35.210: E/AndroidRuntime(8442): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1008) 07-31 17:53:35.210: E/AndroidRuntime(8442): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:775) 07-31 17:53:35.210: E/AndroidRuntime(8442): at dalvik.system.NativeStart.main(Native Method)

+0

я не вижу никакой "AlertDialog alertDialog = alertDialogBuilder.create();" – bofredo

+0

bofredo: Да, я пропустил это, но даже если я использую его все еще не работающий ... Редактированный конечный код в вопросе – user45678

ответ

0

Это будет работать:

Создать Popupwindow Как это

LayoutInflater layoutInflater = (LayoutInflater)getBaseContext().getSystemService(LAYOUT_INFLATER_SERVICE); 
     View layout = layoutInflater.inflate(R.layout.new_popup_layout, null); 
     final PopupWindow popupWindow = new PopupWindow(
       layout, 
        LayoutParams.WRAP_CONTENT, 
         LayoutParams.WRAP_CONTENT); 

WebView web = (WebView)layout.findViewbyId(R.id.webView1); 

popupWindow.showAtLocation (view, Gravity.CENTER, 0, 0);

и не создавать new_popup_layout файл макета с WebView, как это:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:tools="http://schemas.android.com/tools" 
android:layout_width="match_parent" 
android:layout_height="wrap_content" 
android:orientation="vertical" > 

<WebView 
    android:id="@+id/webView1" 
    android:layout_width="match_parent" 
    android:layout_height="461dp" /> 

0

Вместо того, чтобы использовать эту

getBaseContext() 

Использование

getAppplicationContext() 

А также инициализировать контекст, прежде чем выполнить Async Task как

this.context = getAppplicationContext(); 

А затем выполнить

RssFeedTask rssTask = new RssFeedTask(); 
    rssTask.execute(); 
+0

Хариш: Я тоже это пробовал ... но не работал – user45678

1

Init ialize, прежде чем вы вызовете класс async.

+0

Это не дает ответа на вопрос , Чтобы критиковать или запросить разъяснения у автора, оставьте комментарий ниже своего сообщения - вы всегда можете прокомментировать свои собственные сообщения, и как только у вас будет достаточно [репутации] (http://stackoverflow.com/help/whats-reputation), вы будете быть в состоянии [прокомментировать любое сообщение] (http://stackoverflow.com/help/privileges/comment). – CRUSADER

+0

samdroid: это не правильный ответ ... не просто ответьте за очки. Показать некоторые предложения – user45678

0

Я использовал следующий фрагмент кода внутри AsyncTaskonPostExecute() и его работает отлично,

AlertDialog.Builder builder = new AlertDialog.Builder(
          FacebookFriends.this); 
        builder.setCancelable(true); 
        builder.setTitle("Invitation sent unsuccesful.Please try again !"); 
        builder.setInverseBackgroundForced(true); 

        builder.setNegativeButton(
          "Ok", 
          new DialogInterface.OnClickListener() { 
           @Override 
           public void onClick(
             DialogInterface dialog, 
             int which) { 
            dialog.dismiss(); 
           } 
          }); 

        AlertDialog alert = builder.create(); 
        alert.show(); 
+0

user2012: не сработал для меня – user45678

0

общественный класс Асинхронный расширяет активность {

/** Called when the activity is first created. */ 

ListView _rssFeedListView; 
List<JSONObject> jobs; 
List<RssFeedStructure> rssStr; 
private BlogAdapter _adapter; 
TextView textview; 
Context context; 


@Override 
public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.listview); 
    _rssFeedListView = (ListView) findViewById(R.id.rssfeed_listview); 

    textview = (TextView) findViewById(R.id.loading); 
    RssFeedTask rssTask = new RssFeedTask(); 
    rssTask.execute(); 

    this.context = getBaseContext(); 

_rssFeedListView.setOnItemClickListener (новый OnItemClickListener() {

   @Override 
       public void onItemClick(AdapterView<?> parent, View view, int position, long id) { 

        alert = new AlertDialog.Builder(getBaseContext()); 

        alert.setTitle("Title here"); 

        WebView wv = new WebView(getBaseContext()); 

        wv.loadUrl("http://www.google.com"); 

        wv.setWebViewClient(new WebViewClient() { 
         @Override 
         public boolean shouldOverrideUrlLoading(
           WebView view, String url) { 
          view.loadUrl(url); 

          return true; 
         } 
        }); 

        alert.setView(wv); 
        alert.setNegativeButton("Close", 
          new DialogInterface.OnClickListener() { 
           @Override 
           public void onClick(DialogInterface dialog, int id) { 
           } 
          }); 
        alert.show(); 



       } 
      }); 
} 


private class RssFeedTask extends AsyncTask<String, Void, String> { 
    // private String Content; 
    // private ProgressDialog Dialog; 
    String response = ""; 
    AlertDialog.Builder alert; 


    @Override 
    protected void onPreExecute() { 
    } 

    @Override 
    protected String doInBackground(String... urls) { 
     try { 
      // String feed = 
      // "https://www.facebook.com/feeds/page.php?format=atom10&id=330938752535"; 
      String feed = "http://srisriravishankar.org/feed/"; 
      XmlHandler rh = new XmlHandler(); 
      rssStr = rh.getLatestArticles(feed); 
     } catch (Exception e) { 
     } 
     return response; 

    } 

    @Override 
    protected void onPostExecute(String result) { 
     if (rssStr != null) { 

      _adapter = new BlogAdapter(Async.this, rssStr); 
      _rssFeedListView.setAdapter(_adapter); 
      textview.setVisibility(View.INVISIBLE); 



     } 


    } 

} 

} 

положить y наш onItemClickListner в методе onCreate().

+0

Наркомания Маниш: Я сделал то, что предложил, и он разбился. Ошибка проводки в вопросе – user45678

+0

замените getBaseContext() на «this» или getAppplicationContext() в каждом месте, где вы используете это. –

+0

Пробовал тоже :) Но все равно не сработал ... Отредактировал мой вопрос снова по вашему предложению. Пожалуйста, посмотрите – user45678

0

Попробуйте запустить AsyncTask не с onCreate способом вашей деятельности, а с onResume. Или даже после onResume, используя, например, обработчик. Что-то вроде этого:

Handler handler = new Handler(); 
Runnable r = new Runnable(){ 
     public void run() { 
      /*your asyncTask execution code here*/ 
     } 
}; 

@Override 
public void onResume() { 
    super.onResume; 
    handler.post(r); 
} 

С этим вы будете уверены, что активность действительно активна и завершила процесс инициализации.

+0

Пробовал это, но получил ошибку. Пожалуйста, просмотрите мой отредактированный вопрос для ошибки – user45678

+0

Попробуйте изменить контекст здесь: 'builder = new AlertDialog.Builder (getApplicationContext());', установить активность как контекст. – Raiv

0

Создайте конструктор задачи async и передайте контекст в своей задаче async.

см следуя, например

private class asyncTask extends AsyncTask<Void, Void, Cursor> 
    { 
     Context mContext; 

     asyncTask(Context context) 
     { 
      mContext = context 


     } 
     protected void onPreExecute() 
     { 

     } 
     protected void onPostExecute(Cursor cursor) 
     { 
     AlertDialog.Builder builder = new AlertDialog.Builder(mContext); 
     builder.setCancelable(true); 
     builder.setTitle("Invitation sent unsuccesful.Please try again !"); 
     builder.setInverseBackgroundForced(true); 

     builder.setNegativeButton(
       "Ok", 
       new DialogInterface.OnClickListener() { 
        @Override 
        public void onClick(
          DialogInterface dialog, 
          int which) { 
         dialog.dismiss(); 
        } 
       }); 

     AlertDialog alert = builder.create(); 
     alert.show(); 
     } 

     @Override 
     protected Cursor doInBackground(Void... params) 
     { 

     } 
    } 

После этого вы можете вызвать эту AsyncTask как

new asyncTask(Your_Context).execute(); 
+0

Его работая отлично для меня – Andrain

+0

Давид, его диалог диалогов оповещений и не прогресс. Это не сработает. Существует только один способ создания диалогового окна предупреждения в документации, а именно: AlertDialog.Builder builder = new AlertDialog.Builder (getActivity()); – user45678

+0

Просто ознакомьтесь с моим обновленным ответом – Andrain

Смежные вопросы