15

Używam WebView do ładowania strony internetowej. Jest jednak bardzo powolny i nieszczelny, gdy są ładowane określone witryny. Załaduję WebView z następującym kodem.WebView nie ładuje strony internetowej

@Override 
    protected void onNewIntent(Intent intent) { 
     if (intent.getStringExtra("url") != null) { 
      webView.loadurl(intent.getStringExtra("url")); 

      } 
    } 

Ale Wołam webView.loadUrl(Config.URL); (Config.URL może zawierać samej zawartości, jak określono powyżej) w onCreate() metody po zainicjowaniu WebView z następujących czynności.

 this.webView = (WebView) findViewById(R.id.wv); 
     this.webView.getSettings().setJavaScriptEnabled(true); 
     this.webView.getSettings().setLoadsImagesAutomatically(true); 
     this.webView.getSettings().setDomStorageEnabled(true); 
     this.webView.setScrollBarStyle(View.SCROLLBARS_INSIDE_OVERLAY); 
     MyClient client = new MyClient(WebActivity.this, (ProgressBar)findViewById(R.id.progressBar)); 
     webView.setWebViewClient(client); 

Wkładanie od onCreate() działa dobrze (nie w porządku, to jest zbyt powolny). Ale ten sam adres URL, który ładuje się z onNewIntent(), to nie działa !!!. Po wykonaniu tego w onNewIntent() żadne adresy URL nie zostały załadowane za pomocą webView.loadurl(), a bieżąca strona staje się niewzruszona. to znaczy. paski przewijania poruszają się w trybie WebView, ale strona nie przewija się. Przetestowałem ten sam URL w onCreate() i działa.

Dla robi, że jestem przechodzącej url z

intent.putExtra("url", Config.URL+targetUrl); 
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_SINGLE_TOP); 

z toczącym intencyjny powiadomień. Chociaż działa w niektórych urządzeniach, np. Google Nexus. Ale nie działa na większości telefonów. mam

android:hardwareAccelerated="true" 

Myclient

public class MyClient extends WebViewClient{ 
    private Context context; 
    private Activity activity; 
    private Handler handler; 
    private Runnable runnable; 
    private ProgressBar viewBar; 
    private String ret,ret2; 
    public void setFirstLoad(boolean firstLoad) { 
     this.firstLoad = firstLoad; 
    } 

    private boolean firstLoad=false; 
    public MyClient(Activity activity, ProgressBar bar) { 
     this.context = activity.getApplicationContext(); 
     this.activity = activity; 
     viewBar=bar; 
     handler=new Handler(); 
    } 

    @Override 
    public boolean shouldOverrideUrlLoading(WebView view, String url) { 
     /*if (url.startsWith("tel:")) { 
      Intent intent = new Intent(Intent.ACTION_DIAL, 
        Uri.parse(url)); 
      intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK); 
      context.startActivity(intent); 
     }else if(url.startsWith("http:") || url.startsWith("https:")) { 
      *//*view.setVisibility(View.GONE); 
      viewBar.setVisibility(View.VISIBLE);*//* 
      view.loadUrl(url); 
     } 
     return true;*/ 
     if (Uri.parse(url).getHost().equals("www.somepage.com")) { 
      return false; 
     } 
     // Otherwise, the link is not for a page on my site, so launch another Activity that handles URLs 
     try { 
      Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(url)); 
      intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK); 
      context.startActivity(intent); 
      Answers.getInstance().logShare(new ShareEvent() 
      .putContentId(Build.USER) 
      .putMethod(shareName(url)) 
      .putContentName(contentDecode(url)) 
      .putContentType("news_share")); 
     }catch (android.content.ActivityNotFoundException e){ 
      Log.e("Activity not found",e.toString()); 
      Toast.makeText(context,"Application not found",Toast.LENGTH_LONG).show(); 
     } 

     return true; 

    } 

    @Override 
    public void onReceivedError(final WebView view, int errorCode, String description, final String failingUrl) { 
     //Clearing the WebView 
     try { 
      view.stopLoading(); 
     } catch (Exception e) { 
     } 
     try { 
      view.clearView(); 
     } catch (Exception e) { 
     } 
     if (view.canGoBack()) { 
      view.goBack(); 
     } 
     view.loadUrl("about:blank"); 

     //Showing and creating an alet dialog 
     AlertDialog.Builder alertDialog = new AlertDialog.Builder(activity); 
     alertDialog.setTitle("Error"); 
     alertDialog.setMessage("No internet connection was found!"); 
     alertDialog.setPositiveButton("Retry", new DialogInterface.OnClickListener() { 
      @Override 
      public void onClick(DialogInterface dialog, int which) { 
       view.loadUrl(failingUrl); 

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

     //Don't forget to call supper! 
     super.onReceivedError(view, errorCode, description, failingUrl); 
    } 

    @Override 
    public void onLoadResource(final WebView view, String url) { 
     super.onLoadResource(view, url); 
     //injectScriptFile(view, "js/script.js"); 
     injectCSS(view,"css/style.css"); 
     if (firstLoad){ 
      firstLoad=false; 
      view.setVisibility(View.INVISIBLE); 
      viewBar.setVisibility(View.VISIBLE); 
      runnable=new Runnable() { 
       @Override 
       public void run() { 
        viewBar.setVisibility(View.GONE); 
        view.setVisibility(View.VISIBLE); 
       } 
      }; 
      handler.postDelayed(runnable,2000); 
     } 

     // test if the script was loaded 
     // view.loadUrl("javascript:setTimeout(hideMe(), 200)"); 
    } 

    /*@Override 
    public void onPageFinished(final WebView view, String url) { 

     //System.gc(); 
    }*/ 


    @Override 
    public void onPageFinished(WebView view, String url) { 
     super.onPageFinished(view, url); 
     System.gc(); 
    } 

Pytanie: Jaki jest problem przy korzystaniu loadurl() metodę w onNewIntent()?

+0

Przepraszam pana, czy znajdujesz pożądane wyniki w ** intent.getStringExtra ("url") **? Czy w LogCat są również dziwne wiadomości? Dziękuję Ci. – statosdotcom

+0

@statosdotcom tak, znalazłem to w zamierzeniu. W programie Logcat pokazującym, że strona ładuje się, ale nie wyświetla.ie. strona nie zmienia się od poprzedniego –

+0

Proszę podać swoją metodę OnPause, jeśli używasz jej tak, jak nazywa się przed OnNewIntent. Masz również punkt przerw w OnNewIntent, np. Czy jesteś pewien, że został trafiony? –

Odpowiedz

6

Spróbuj tego skąd ładunki Webview

web.setWebViewClient(new WebViewClient() { 
     @Override 
     public boolean shouldOverrideUrlLoading(WebView view, String url) { 
      return super.shouldOverrideUrlLoading(view, url); 
     } 
    }); 
+0

tak, jesteś z calicut, prawda? –

+0

To nie jest odpowiedź, która nie zostanie wykonana po instrukcji return .Prawdę używam go. zobacz mój kod –

1

Można użyć WebClient do obsługi webview. Tutaj dołączam javascript z ładowaniem.

  String aboutURL="YOUR URL"; 

     final ProgressDialog pd = ProgressDialog.show(, "", "Please wait", true); 

     WebSettings settings=Webview.getSettings(); 

     settings.setJavaScriptEnabled(true); 
     settings.setAppCacheEnabled(true); 
     settings.setDomStorageEnabled(true); 
     settings.setLoadsImagesAutomatically(true); 
     settings.setDatabaseEnabled(true); 
     settings.setRenderPriority(WebSettings.RenderPriority.HIGH); 
     settings.setCacheMode(WebSettings.LOAD_NO_CACHE); 
     settings.setSupportZoom(true); 
     settings.setBuiltInZoomControls(true); 

     Webview.setWebViewClient(new WebViewClient() { 
      public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) { 
       Toast.makeText(activity, description, Toast.LENGTH_SHORT).show(); 
      } 

      @Override 
      public void onPageStarted(WebView view, String url, Bitmap favicon) 
      { 
       pd.show(); 
      } 
      @Override 
      public void onPageFinished(WebView view, String url) { 
       pd.dismiss(); 
      } 
     }); 
     Webview.loadUrl(aboutURL); 

Tutaj Ładowanie są przetwarzane na podstawie sieci

0

Korzystanie Handler aby umieścić akcję opóźnienia jak poniżej będzie to naprawić, ale nie wiadomo dlaczego.

new Handler().post(webView.loadurl(url)); 
Powiązane problemy