X-Git-Url: https://gitweb.stoutner.com/?a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fcom%2Fstoutner%2Fprivacybrowser%2FWebview.java;h=bc8dd08d1bf555a0c68fff887f524bdccca11746;hb=c386d4c28669c3180d2fad08ec63da972b4d86ec;hp=6e8f237e0f5beb7937776bbb7bb653a317ec5709;hpb=9523d99614150970890e0d01cf0bf5e38c6ccf14;p=PrivacyBrowserAndroid.git diff --git a/app/src/main/java/com/stoutner/privacybrowser/Webview.java b/app/src/main/java/com/stoutner/privacybrowser/Webview.java index 6e8f237e..bc8dd08d 100644 --- a/app/src/main/java/com/stoutner/privacybrowser/Webview.java +++ b/app/src/main/java/com/stoutner/privacybrowser/Webview.java @@ -3,24 +3,27 @@ package com.stoutner.privacybrowser; import android.app.Activity; import android.content.Intent; import android.net.Uri; -import android.support.v7.app.ActionBarActivity; import android.os.Bundle; +import android.support.v7.app.AppCompatActivity; import android.view.KeyEvent; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.view.inputmethod.InputMethodManager; +import android.webkit.WebChromeClient; import android.webkit.WebView; import android.webkit.WebViewClient; import android.widget.EditText; +import android.widget.ProgressBar; import java.net.URL; -public class Webview extends ActionBarActivity { +public class Webview extends AppCompatActivity { static String formattedUrlString; static WebView mainWebView; + static ProgressBar progressBar; static final String homepage = "https://www.duckduckgo.com"; @Override @@ -30,9 +33,29 @@ public class Webview extends ActionBarActivity { final EditText urlTextBox = (EditText) findViewById(R.id.urlTextBox); mainWebView = (WebView) findViewById(R.id.mainWebView); + progressBar = (ProgressBar) findViewById(R.id.progressBar); // setWebViewClient makes this WebView the default handler for URLs inside the app, so that links are not kicked out to other apps. - mainWebView.setWebViewClient(new WebViewClient()); + // Save the URL to urlTextBox before loading mainWebView. + mainWebView.setWebViewClient(new WebViewClient() { + public boolean shouldOverrideUrlLoading(WebView view, String url) { + urlTextBox.setText(url); + mainWebView.loadUrl(url); + return true; + } + }); + + // Update the progress bar when a page is loading. + mainWebView.setWebChromeClient(new WebChromeClient() { + public void onProgressChanged(WebView view, int progress) { + if (progress < 100) { + progressBar.setVisibility(View.VISIBLE); + } else { + progressBar.setVisibility(View.GONE); + } + progressBar.setProgress(progress); + } + }); // Allow pinch to zoom. mainWebView.getSettings().setBuiltInZoomControls(true); @@ -80,7 +103,7 @@ public class Webview extends ActionBarActivity { if ((event.getAction() == KeyEvent.ACTION_DOWN) && (keyCode == KeyEvent.KEYCODE_ENTER)) { // Load the URL into the mainWebView and consume the event. - loadUrl(mainWebView); + loadUrlFromTextBox(mainWebView); return true; } // Do not consume the event. @@ -125,7 +148,7 @@ public class Webview extends ActionBarActivity { } } - public void loadUrl(View view) { + public void loadUrlFromTextBox(View view) { // Get the text from urlTextInput and convert it to a string. final EditText urlTextBox = (EditText) findViewById(R.id.urlTextBox); final String unformattedUrlString = urlTextBox.getText().toString(); @@ -150,24 +173,6 @@ public class Webview extends ActionBarActivity { formattedUrlString = "http://" + unformattedUrlString; } - /* - // Parse the unformattedURLString into a Uri. - - final Uri uriData = Uri.parse(unformattedUrlString); - - // Convert the Uri to a URL, chicking for any problems with the formatting. - URL urlData = null; - - try { - urlData = new URL(uriData.getScheme(), uriData.getHost(), uriData.getPath()); - } catch (Exception e) { - e.printStackTrace(); - } - - // Convert urlData to a string, which is reqauired by loadUrl method. - formattedUrlString = urlData.toString(); - */ - final WebView mainWebView = (WebView) findViewById(R.id.mainWebView); // Place the URL text back in the address bar and load the website.