2012-04-03 32 views
0

私はWebViewClientを使用して、エミュレータを使用してURLを参照しています。しばらくすると(正確には原因を教えられない)、ページはそれ以上読み込めず、以前と同じサイトが非常に高速だったため、表示には永遠にかかります。 私は通常、エラー-2(WebViewClient.ERROR_HOST_LOOKUP)のonReceivedErrorを参照します。 助けてください/参考になります。Android WebView/WebViewClientがloadUrlを使用してブラウジングした後にエミュレータを使用してクラッシュする

ありがとうございます!

W/ThrottleService(91):のiface rmnet0
D/dalvikvm(171)の統計情報を見つけることができません:GC_CONCURRENTは、8%の遊離6971K/7559K、457Kを解放11ms以下まで+ 7MS
F/NetworkStatsを(一時停止(91):ネットワーク統計を読み取る際の問題
F/NetworkStats(91):java.lang.IllegalStateException:idx 1の解析に問題があります。
F/NetworkStats(91):com.android.internal.net.NetworkStatsFactory.readNetworkStatsDetail(NetworkStatsFactory。 java/300)
F/NetworkStats(91):com.android.server.NetworkManagementService.getNetworkStatsUidDetail(NetworkManagementService.java:1) (91):com.android.server.net.NetworkStatsService.performPollLocked(NetworkStatsService.java:831)
F/NetworkStats(91):com.android.server.net.NetworkStatsServiceで、F/NetworkStats(91) (NetworkStatsService.java:128)
F/NetworkStats(91):com.android(ネットワークスタートサービス.java:799)
F/NetworkStats(91):com.android.server.net.NetworkStatsService.access $ 100 (NetworkStatsService.java:633)
F/NetworkStats(91):android.app.LoadedApk $ ReceiverDispatcher $ Args.run(LoadedApk.java:728)
F/NetworkStats(ネットワークストラックスサービス) 91):android.os.Handler.handleCallback(Handler.java:605)
F/NetworkStats(91):android.os.Handler.dispatchMessage(Handler.java:92)
F/NetworkStats(91)において:android.os.Looper.loopで(Looper.java:137)
F/NetworkStats(91):android.os.HandlerThread.run(HandlerThread.java:60)
F/NetworkStats(91):原因:java.io.FileNotFoundException:/ proc/net/xt_qtaguid/stats:open失敗した:ENOENT(そのようなファイルやディレクトリはありません)
F/NetworkStats(91):libcore.io.IoBridge.open(IoBridge.java:406)
F/NetworkStats(91):java.io.FileInputStream。 (FileInputStream.java:78)
F/NetworkStats(91):com.android.internal.net.NetworkStatsFactory.readNetworkStatsDetail(Ne libcore.io.ErrnoException:オープンに失敗しました:ENOENT(そのようなファイルまたはディレクトリはありません)
(F)/ネットワークスタート(91):
F/NetworkStats(91):... 10 more
F/NetworkStats(91):libcore.io.Posix.open(ネイティブメソッド)で
F/NetworkStats(91):libcore.io.BlockGuardOs.open(BlockGuardOs.java:110)
F/NetworkStats(AT 91):libcore.io.IoBridge.open(IoBridge.java:390)
F/NetworkStats(91):... D/dalvikvm(91)
12以上:GC_CONCURRENTは、8%の遊離9025K/9735K、508Kを解放6msの+ 24ms
W/ThrottleService(91)一時停止:以下のiface rmnet0

+0

あなたのコードはここにありますか –

+0

私は 'http:// abc.com'をロードしようとしました。 webviewがロードできないようです。誰かがそれをテストできますか?ありがとう – fredy

答えて

0

使用の統計情報を見つけることができませんが作業コード::

public class Android_Activity extends Activity { 
private Android_Activity _activity; 
    @Override 
     public void onCreate(Bundle savedInstanceState) { 
      super.onCreate(savedInstanceState);  
      getWindow().requestFeature(Window.FEATURE_PROGRESS); 
      _activity = this; 
      setContentView(R.layout.main); 

      mwebview=(WebView)view.findViewById(R.id.webview); 
      mwebview.getSettings().setJavaScriptEnabled(true); 
      mwebview.getSettings().setJavaScriptCanOpenWindowsAutomatically(true); 

      if(checkInternetConnection(_activity)==true){ 
       if(savedInstanceState==null) 
        mwebview.loadUrl("http://abc.com"); 
       else 
        mwebview.restoreState(savedInstanceState); 
      } 
      else{ 
       AlertDialog.Builder builder = new AlertDialog.Builder(_activity); 
       builder.setMessage("Please check your network connection.") 
         .setCancelable(false) 
         .setPositiveButton("OK", new DialogInterface.OnClickListener() { 
          public void onClick(DialogInterface dialog, int id) { 

          } 
         }); 

       AlertDialog alert = builder.create();  
       alert.show(); 
      } 
      mwebview.setWebChromeClient(new WebChromeClient() { 

       @Override 
       public void onProgressChanged(WebView view, int progress) { 
        if(mwebview.getVisibility()==View.VISIBLE) 
        { 
         _activity.setProgress(progress * 100); 
        } 
       } 
      }); 
      mwebview.setWebViewClient(new HelloWebViewClient()); 
     } 


     //HelloWebViewClient class for webview 
     private class HelloWebViewClient extends WebViewClient { 

      @Override 
      public void onPageStarted(WebView view, String url, Bitmap favicon) { 
       // TODO Auto-generated method stub 
       super.onPageStarted(view, url, favicon); 
      } 
      @Override 
      public void onReceivedError(WebView view, int errorCode, 
        String description, String failingUrl) { 
       // TODO Auto-generated method stub 
       super.onReceivedError(view, errorCode, description, failingUrl); 

      } 
      @Override 
      public void onPageFinished(WebView view, String url) { 
       // TODO Auto-generated method stub 
       super.onPageFinished(view, url); 
      } 
      @Override 
      public boolean shouldOverrideUrlLoading(WebView view, String url) { 
       // Otherwise, the link is not for a page on my site, so launch another Activity that handles URLs 
       view.loadUrl(url); 
       return true; 
      } 

     } //HelloWebViewClient-class 
     @Override 
     public boolean onKeyDown(int keyCode, KeyEvent event) { 
      // Check if the key event was the Back button and if there's history 
      if ((keyCode == KeyEvent.KEYCODE_BACK) && mwebview.canGoBack()){ 
       mwebview.goBack(); 
       return true; 
      } 
      // If it wasn't the Back key or there's no web page history, bubble up to the default 
      // system behavior (probably exit the activity) 
      return super.onKeyDown(keyCode, event); 
     } 
     //To check whether network connection is available on device or not 
      public static boolean checkInternetConnection(Activity _activity) { 
       ConnectivityManager conMgr = (ConnectivityManager) _activity.getSystemService(Context.CONNECTIVITY_SERVICE); 
       if (conMgr.getActiveNetworkInfo() != null 
         && conMgr.getActiveNetworkInfo().isAvailable() 
         && conMgr.getActiveNetworkInfo().isConnected()) 
        return true; 
       else 
        return false; 
      }//checkInternetConnection() 
} 

そしてまたあなたのmain.xmlレイアウトで使用すると、次に、以下の行を交換し、

を試したIDのWebView

とのWebViewを持っている必要があります

if(savedInstanceState==null) 
        mwebview.loadUrl("http://abc.com"); 
       else 
        mwebview.restoreState(savedInstanceState); 

with .. mwebview.loadUrl( "http://abc.com");

+0

最初の実行は完全に働いた。 (同じエミュレータ上で、私はクリックして再度開いてアプリケーションを再開しました)エラー エラーなしでloadUrlを2回実行できますか? – fredy

+0

私はあなたを得ませんでした。何度も同じURLを読み込むことができます –

+0

strange ...エミュレータまたはデバイスで実行していますか? – fredy

関連する問題