Add the favorite icon to the addressBarLinearLayout.
authorSoren Stoutner <soren@stoutner.com>
Sat, 24 Oct 2015 07:44:55 +0000 (00:44 -0700)
committerSoren Stoutner <soren@stoutner.com>
Sat, 24 Oct 2015 07:44:55 +0000 (00:44 -0700)
app/src/main/AndroidManifest.xml
app/src/main/java/com/stoutner/privacybrowser/Webview.java
app/src/main/res/layout/activity_webview.xml

index b07addeb9b1a89a6659c32c60e2fac2bc3906f4a..02deefaca231af5a89399aba8921b25447181bb5 100644 (file)
 
         <!-- configChanges orientation and screenSize makes the app not reload when the orientation changes. -->
         <!-- windowSoftInputMode stateAlwaysHidden hides the keyboard when the app starts. -->
-        <!-- Setting the label as null removes it from the action bar. -->
         <activity
             android:name=".Webview"
             android:configChanges="orientation|screenSize"
-            android:label=""
+            android:label="@string/privacy_browser"
             android:windowSoftInputMode="stateAlwaysHidden">
             <intent-filter>
                 <action android:name="android.intent.action.MAIN" />
index f920efa4f6f0d99d28b8304c8cf7df0eb083bb76..de16eae6c0d79fe2c26e5d62c5b83e942107242e 100644 (file)
@@ -17,10 +17,12 @@ import android.view.MenuItem;
 import android.view.View;
 import android.view.ViewTreeObserver;
 import android.view.inputmethod.InputMethodManager;
+import android.webkit.ClientCertRequest;
 import android.webkit.WebChromeClient;
 import android.webkit.WebView;
 import android.webkit.WebViewClient;
 import android.widget.EditText;
+import android.widget.ImageView;
 import android.widget.ProgressBar;
 import java.io.UnsupportedEncodingException;
 import java.net.MalformedURLException;
@@ -34,6 +36,7 @@ public class Webview extends AppCompatActivity {
     static ProgressBar progressBar;
     static SwipeRefreshLayout swipeToRefresh;
     static EditText urlTextBox;
+    static ImageView favoriteIcon;
     static final String homepage = "https://www.duckduckgo.com";
 
     @Override
@@ -45,7 +48,9 @@ public class Webview extends AppCompatActivity {
         swipeToRefresh = (SwipeRefreshLayout) findViewById(R.id.swipeRefreshLayoutContainer);
         mainWebView = (WebView) findViewById(R.id.mainWebView);
         progressBar = (ProgressBar) findViewById(R.id.progressBar);
+        favoriteIcon = (ImageView) findViewById(R.id.favoriteIcon);
 
+        // Remove the title from the action bar.
         final ActionBar actionBar = getSupportActionBar();
         if (actionBar != null) {
             actionBar.setDisplayShowTitleEnabled(false);
@@ -73,19 +78,30 @@ public class Webview extends AppCompatActivity {
             }
         });
 
-        // setWebViewClient makes this WebView the default handler for URLs inside the app, so that links are not kicked out to other apps.
-        // Save the URL to formattedUrlString and update urlTextBox before loading mainWebView.
         mainWebView.setWebViewClient(new WebViewClient() {
+
+            // setWebViewClient makes this WebView the default handler for URLs inside the app, so that links are not kicked out to other apps.
+            // Save the URL to formattedUrlString and update urlTextBox before loading mainWebView.
+            @Override
             public boolean shouldOverrideUrlLoading(WebView view, String url) {
                 formattedUrlString = url;
                 urlTextBox.setText(formattedUrlString);
                 mainWebView.loadUrl(formattedUrlString);
                 return true;
             }
+
+            @Override
+            public void onPageFinished(WebView view, String url) {
+                // Update the URL in urlTextBox.  It is necessary to do this after the page finishes loading to get the final URL, which can change during load.
+                formattedUrlString = mainWebView.getUrl();
+                urlTextBox.setText(formattedUrlString);
+            }
         });
 
-        // Update the progress bar when a page is loading.
         mainWebView.setWebChromeClient(new WebChromeClient() {
+
+            // Update the progress bar when a page is loading.
+            @Override
             public void onProgressChanged(WebView view, int progress) {
                 progressBar.setProgress(progress);
                 if (progress < 100) {
@@ -95,16 +111,34 @@ public class Webview extends AppCompatActivity {
 
                     // Stop the refreshing indicator if it is running.
                     swipeToRefresh.setRefreshing(false);
+                }
+            }
 
-                    // Update the URL in urlTextBox.  It is necessary to do this after the page finishes loading to get the final URL, which can change during load.
-                    formattedUrlString = mainWebView.getUrl();
-                    urlTextBox.setText(formattedUrlString);
+            // Set the favorite icon if it changes.
+            @Override
+            public void onReceivedIcon(WebView view, Bitmap icon) {
+                favoriteIcon.setImageBitmap(icon);
+            }
+        });
+
+        // Set the "go" button on the keyboard to load the URL.
+        urlTextBox.setOnKeyListener(new View.OnKeyListener() {
+            public boolean onKey(View v, int keyCode, KeyEvent event) {
 
-                    // Set the favorite icon
-                    Bitmap favoriteIconBitmap = mainWebView.getFavicon();
-                    Drawable favoriteIconDrawable = new BitmapDrawable(getResources(), favoriteIconBitmap);
-                    // TODO Display the favorite icon.
+                // If the event is a key-down event on the "enter" button, load the URL.
+                if ((event.getAction() == KeyEvent.ACTION_DOWN) &&
+                        (keyCode == KeyEvent.KEYCODE_ENTER)) {
+                    // Load the URL into the mainWebView and consume the event.
+                    try {
+                        loadUrlFromTextBox(mainWebView);
+                    } catch (UnsupportedEncodingException e) {
+                        e.printStackTrace();
+                    }
+                    // If the enter key was pressed, consume the event.
+                    return true;
                 }
+                // If any other key was pressed, do not consume the event.
+                return false;
             }
         });
 
@@ -137,26 +171,6 @@ public class Webview extends AppCompatActivity {
         // Place the formattedUrlString in the address bar and load the website.
         urlTextBox.setText(formattedUrlString);
         mainWebView.loadUrl(formattedUrlString);
-
-        // Set the "go" button on the keyboard to load the URL.
-        urlTextBox.setOnKeyListener(new View.OnKeyListener() {
-            public boolean onKey(View v, int keyCode, KeyEvent event) {
-                // If the event is a key-down event on the "enter" button
-                if ((event.getAction() == KeyEvent.ACTION_DOWN) &&
-                        (keyCode == KeyEvent.KEYCODE_ENTER)) {
-                    // Load the URL into the mainWebView and consume the event.
-                    try {
-                        loadUrlFromTextBox(mainWebView);
-                    } catch (UnsupportedEncodingException e) {
-                        e.printStackTrace();
-                    }
-                    return true;
-                }
-                // Do not consume the event.
-                return false;
-            }
-        });
-
     }
 
     @Override
index 6e22c007f885b92b82011377852cd014f876f6de..d235b83a8100327f0e878402729dc2396a620ae9 100644 (file)
             android:layout_width="match_parent"
             android:layout_height="wrap_content">
 
-            <!-- android:inputType="textUri" sets the keyboard to have a go arrow. -->
-            <EditText
-                android:id="@+id/urlTextBox"
+            <LinearLayout
+                android:id="@+id/addressBarLinearLayout"
                 android:layout_width="match_parent"
                 android:layout_height="wrap_content"
-                android:inputType="textUri"
-                android:imeOptions="actionGo" />
+                android:orientation="horizontal">
+
+                <ImageView
+                    android:id="@+id/favoriteIcon"
+                    android:src="@drawable/ic_home_black_24dp"
+                    android:layout_width="wrap_content"
+                    android:layout_height="wrap_content"
+                    android:layout_gravity="center" />
+
+                <!-- android:inputType="textUri" sets the keyboard to have a go arrow. -->
+                <!-- android:layout_weight="1" makes urlTextBox take up all the remaining space. -->
+                <EditText
+                    android:id="@+id/urlTextBox"
+                    android:layout_width="0dp"
+                    android:layout_weight="1"
+                    android:layout_height="wrap_content"
+                    android:inputType="textUri"
+                    android:imeOptions="actionGo" />
+            </LinearLayout>
 
             <!-- android:max changes the maximum ProgressBar value from 10000 to 100 to match progress percentage. -->
             <ProgressBar
@@ -40,7 +56,6 @@
                 android:visibility="gone" />
         </FrameLayout>
 
-
         <WebView
             android:id="@+id/mainWebView"
             android:layout_width="match_parent"