Comment modifier ou créer une page d'erreur personnalisée pour WebView?
-
29-09-2019 - |
Question
J'ai créé une mise en page de WebView, qui permet d'accéder à un site spécifique, mais il serait utile de modifier ou de créer une coutume « Web non disponible » ressource lorsqu'un combiné ne une connexion réseau ou les temps de page sur. Je sais qu'il est possible parce que si vous ouvrez l'application " Wikidroid " alors qu'un combiné est en mode Avion, vous recevez " Article non disponible " page d'erreur au lieu de l'Android standard " Web non disponible " page d'erreur.
Je recherche haut et bas sur internet et ne sont pas venus avec des ressources en ligne qui répondent à cette demande. Toute aide est très appréciée. Merci à l'avance.
La solution
Pour déterminer quand l'appareil dispose d'une connexion réseau, demander la permission <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
et vous pouvez vérifier avec le code suivant. Tout d'abord définir ces variables comme variables de classe.
private Context c;
private boolean isConnected = true;
Dans la méthode onCreate()
initialize c = this;
Ensuite, vérifier la connectivité.
ConnectivityManager connectivityManager = (ConnectivityManager)
c.getSystemService(Context.CONNECTIVITY_SERVICE);
if (connectivityManager != null) {
NetworkInfo ni = connectivityManager.getActiveNetworkInfo();
if (ni.getState() != NetworkInfo.State.CONNECTED) {
// record the fact that there is not connection
isConnected = false;
}
}
Ensuite, pour intercepter les Requets de WebView
, vous pouvez faire quelque chose comme ce qui suit. Si vous utilisez, vous voudrez probablement personnaliser les messages d'erreur pour inclure certaines des informations qui sont disponibles dans la méthode onReceivedError
.
final String offlineMessageHtml = "DEFINE THIS";
final String timeoutMessageHtml = "DEFINE THIS";
WebView browser = (WebView) findViewById(R.id.webview);
browser.setNetworkAvailable(isConnected);
browser.setWebViewClient(new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
if (isConnected) {
// return false to let the WebView handle the URL
return false;
} else {
// show the proper "not connected" message
view.loadData(offlineMessageHtml, "text/html", "utf-8");
// return true if the host application wants to leave the current
// WebView and handle the url itself
return true;
}
}
@Override
public void onReceivedError (WebView view, int errorCode,
String description, String failingUrl) {
if (errorCode == ERROR_TIMEOUT) {
view.stopLoading(); // may not be needed
view.loadData(timeoutMessageHtml, "text/html", "utf-8");
}
}
});
Autres conseils
Marco W. est correct.
myWebView.setWebViewClient(new WebViewClient() {
public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
myWebView.loadUrl("file:///android_asset/custom_url_error.htm");
}
});
J'ai essayé d'utiliser toutes les solutions ci-dessus, mais aucun d'entre eux travaillent. Tordu mon code un peu et ont obtenu la solution:
package com.samnjor.tipsmaster;
import android.content.Context; import android.graphics.Bitmap;
import android.net.ConnectivityManager; import
android.net.NetworkInfo; import
android.support.v7.app.AppCompatActivity; import android.os.Bundle;
import android.view.View; import android.webkit.WebSettings; import
android.webkit.WebView; import android.webkit.WebViewClient; import
android.widget.ProgressBar; import android.widget.TextView;
import com.google.android.gms.ads.AdListener; import
com.google.android.gms.ads.AdRequest; import
com.google.android.gms.ads.InterstitialAd;
public class TodayTips extends AppCompatActivity {
String ShowOrHideWebViewInitialUse = "show";
private WebView webview ;
private ProgressBar spinner;
private String TAG = TodayTips.class.getSimpleName();
InterstitialAd mInterstitialAd;
final String noconnectionHtml = "Failed to connect ot the internet";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_today_tips);
mInterstitialAd = new InterstitialAd(this);
// set the ad unit ID
mInterstitialAd.setAdUnitId(getString(R.string.adbig));
AdRequest adRequest = new AdRequest.Builder()
.build();
// Load ads into Interstitial Ads
mInterstitialAd.loadAd(adRequest);
mInterstitialAd.setAdListener(new AdListener() {
public void onAdLoaded() {
showInterstitial();
}
});
}
private void showInterstitial() {
if (mInterstitialAd.isLoaded()) {
mInterstitialAd.show();
}
webview =(WebView)findViewById(R.id.webView);
spinner = (ProgressBar)findViewById(R.id.progressBar1);
webview.setWebViewClient(new CustomWebViewClient());
webview.getSettings().setJavaScriptEnabled(true);
webview.getSettings().setDomStorageEnabled(true);
webview.setOverScrollMode(WebView.OVER_SCROLL_NEVER);
if(haveNetworkConnection()){
webview.loadUrl("http://you domain here");
} else {
webview.loadData(noconnectionHtml, "text/html", "utf-8"); //
}
}
private boolean haveNetworkConnection() {
boolean haveConnectedWifi = false;
boolean haveConnectedMobile = false;
ConnectivityManager cm = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
NetworkInfo[] netInfo = cm.getAllNetworkInfo();
for (NetworkInfo ni : netInfo) {
if (ni.getTypeName().equalsIgnoreCase("WIFI"))
if (ni.isConnected())
haveConnectedWifi = true;
if (ni.getTypeName().equalsIgnoreCase("MOBILE"))
if (ni.isConnected())
haveConnectedMobile = true;
}
return haveConnectedWifi || haveConnectedMobile;
}
// This allows for a splash screen
// (and hide elements once the page loads)
private class CustomWebViewClient extends WebViewClient {
@Override
public void onPageStarted(WebView webview, String url, Bitmap favicon) {
// only make it invisible the FIRST time the app is run
if (ShowOrHideWebViewInitialUse.equals("show")) {
webview.setVisibility(webview.INVISIBLE);
}
}
@Override
public void onPageFinished(WebView view, String url) {
ShowOrHideWebViewInitialUse = "hide";
spinner.setVisibility(View.GONE);
view.setVisibility(webview.VISIBLE);
super.onPageFinished(view, url);
}
}`` }