summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJohn Reck <jreck@google.com>2010-11-09 08:41:09 -0800
committerJohn Reck <jreck@google.com>2010-11-09 16:37:13 -0800
commitf176bda08f46588667c185603e2ac648ec8291aa (patch)
tree5905c586773ffba25fa07ebda23e4e0c31b16e74
parent6eb77c79f9a88ea0e76eb07ea0412bbd2446a110 (diff)
downloadpackages_apps_browser-f176bda08f46588667c185603e2ac648ec8291aa.zip
packages_apps_browser-f176bda08f46588667c185603e2ac648ec8291aa.tar.gz
packages_apps_browser-f176bda08f46588667c185603e2ac648ec8291aa.tar.bz2
Add support for preloaded thumbnails and favicons
Bug: 3091535 This change adds support for preloading thumbnails and favicons for the default bookmark set. Change-Id: Iaead4c08b343467f6c46cf571959d42d6baf497c
-rw-r--r--res/raw/favicon_amazon.icobin0 -> 17542 bytes
-rw-r--r--res/raw/favicon_bbc.icobin0 -> 958 bytes
-rw-r--r--res/raw/favicon_cnn.icobin0 -> 11502 bytes
-rw-r--r--res/raw/favicon_ebay.icobin0 -> 1406 bytes
-rw-r--r--res/raw/favicon_espn.icobin0 -> 2862 bytes
-rw-r--r--res/raw/favicon_facebook.icobin0 -> 318 bytes
-rw-r--r--res/raw/favicon_google.icobin0 -> 1150 bytes
-rw-r--r--res/raw/favicon_msn.icobin0 -> 1150 bytes
-rw-r--r--res/raw/favicon_myspace.icobin0 -> 1406 bytes
-rw-r--r--res/raw/favicon_nytimes.icobin0 -> 1406 bytes
-rw-r--r--res/raw/favicon_picasa.icobin0 -> 1406 bytes
-rw-r--r--res/raw/favicon_weatherchannel.icobin0 -> 1406 bytes
-rw-r--r--res/raw/favicon_wikipedia.icobin0 -> 318 bytes
-rw-r--r--res/raw/favicon_yahoo.icobin0 -> 318 bytes
-rw-r--r--res/raw/thumb_amazon.pngbin0 -> 2471 bytes
-rw-r--r--res/raw/thumb_bbc.pngbin0 -> 14406 bytes
-rw-r--r--res/raw/thumb_cnn.pngbin0 -> 5440 bytes
-rw-r--r--res/raw/thumb_ebay.pngbin0 -> 2989 bytes
-rw-r--r--res/raw/thumb_espn.pngbin0 -> 5127 bytes
-rw-r--r--res/raw/thumb_facebook.pngbin0 -> 936 bytes
-rw-r--r--res/raw/thumb_google.pngbin0 -> 5905 bytes
-rw-r--r--res/raw/thumb_msn.pngbin0 -> 5684 bytes
-rw-r--r--res/raw/thumb_myspace.pngbin0 -> 1601 bytes
-rw-r--r--res/raw/thumb_nytimes.pngbin0 -> 16333 bytes
-rw-r--r--res/raw/thumb_picasa.pngbin0 -> 3889 bytes
-rw-r--r--res/raw/thumb_weatherchannel.pngbin0 -> 1599 bytes
-rw-r--r--res/raw/thumb_wikipedia.pngbin0 -> 8640 bytes
-rw-r--r--res/raw/thumb_yahoo.pngbin0 -> 5166 bytes
-rw-r--r--res/values/bookmarks_icons.xml33
-rw-r--r--src/com/android/browser/provider/BrowserProvider2.java54
30 files changed, 83 insertions, 4 deletions
diff --git a/res/raw/favicon_amazon.ico b/res/raw/favicon_amazon.ico
new file mode 100644
index 0000000..20a959c
--- /dev/null
+++ b/res/raw/favicon_amazon.ico
Binary files differ
diff --git a/res/raw/favicon_bbc.ico b/res/raw/favicon_bbc.ico
new file mode 100644
index 0000000..8f62b07
--- /dev/null
+++ b/res/raw/favicon_bbc.ico
Binary files differ
diff --git a/res/raw/favicon_cnn.ico b/res/raw/favicon_cnn.ico
new file mode 100644
index 0000000..4a8421d
--- /dev/null
+++ b/res/raw/favicon_cnn.ico
Binary files differ
diff --git a/res/raw/favicon_ebay.ico b/res/raw/favicon_ebay.ico
new file mode 100644
index 0000000..d7c8a5e
--- /dev/null
+++ b/res/raw/favicon_ebay.ico
Binary files differ
diff --git a/res/raw/favicon_espn.ico b/res/raw/favicon_espn.ico
new file mode 100644
index 0000000..2dbe28a
--- /dev/null
+++ b/res/raw/favicon_espn.ico
Binary files differ
diff --git a/res/raw/favicon_facebook.ico b/res/raw/favicon_facebook.ico
new file mode 100644
index 0000000..ea0c6a3
--- /dev/null
+++ b/res/raw/favicon_facebook.ico
Binary files differ
diff --git a/res/raw/favicon_google.ico b/res/raw/favicon_google.ico
new file mode 100644
index 0000000..ee7c943
--- /dev/null
+++ b/res/raw/favicon_google.ico
Binary files differ
diff --git a/res/raw/favicon_msn.ico b/res/raw/favicon_msn.ico
new file mode 100644
index 0000000..b2279f5
--- /dev/null
+++ b/res/raw/favicon_msn.ico
Binary files differ
diff --git a/res/raw/favicon_myspace.ico b/res/raw/favicon_myspace.ico
new file mode 100644
index 0000000..22c46be
--- /dev/null
+++ b/res/raw/favicon_myspace.ico
Binary files differ
diff --git a/res/raw/favicon_nytimes.ico b/res/raw/favicon_nytimes.ico
new file mode 100644
index 0000000..fb4d000
--- /dev/null
+++ b/res/raw/favicon_nytimes.ico
Binary files differ
diff --git a/res/raw/favicon_picasa.ico b/res/raw/favicon_picasa.ico
new file mode 100644
index 0000000..22133b8
--- /dev/null
+++ b/res/raw/favicon_picasa.ico
Binary files differ
diff --git a/res/raw/favicon_weatherchannel.ico b/res/raw/favicon_weatherchannel.ico
new file mode 100644
index 0000000..5a56818
--- /dev/null
+++ b/res/raw/favicon_weatherchannel.ico
Binary files differ
diff --git a/res/raw/favicon_wikipedia.ico b/res/raw/favicon_wikipedia.ico
new file mode 100644
index 0000000..31b0e38
--- /dev/null
+++ b/res/raw/favicon_wikipedia.ico
Binary files differ
diff --git a/res/raw/favicon_yahoo.ico b/res/raw/favicon_yahoo.ico
new file mode 100644
index 0000000..d7761e5
--- /dev/null
+++ b/res/raw/favicon_yahoo.ico
Binary files differ
diff --git a/res/raw/thumb_amazon.png b/res/raw/thumb_amazon.png
new file mode 100644
index 0000000..eec1d77
--- /dev/null
+++ b/res/raw/thumb_amazon.png
Binary files differ
diff --git a/res/raw/thumb_bbc.png b/res/raw/thumb_bbc.png
new file mode 100644
index 0000000..9cdd902
--- /dev/null
+++ b/res/raw/thumb_bbc.png
Binary files differ
diff --git a/res/raw/thumb_cnn.png b/res/raw/thumb_cnn.png
new file mode 100644
index 0000000..70b7ea2
--- /dev/null
+++ b/res/raw/thumb_cnn.png
Binary files differ
diff --git a/res/raw/thumb_ebay.png b/res/raw/thumb_ebay.png
new file mode 100644
index 0000000..070fa6c
--- /dev/null
+++ b/res/raw/thumb_ebay.png
Binary files differ
diff --git a/res/raw/thumb_espn.png b/res/raw/thumb_espn.png
new file mode 100644
index 0000000..94918e2
--- /dev/null
+++ b/res/raw/thumb_espn.png
Binary files differ
diff --git a/res/raw/thumb_facebook.png b/res/raw/thumb_facebook.png
new file mode 100644
index 0000000..6e295b1
--- /dev/null
+++ b/res/raw/thumb_facebook.png
Binary files differ
diff --git a/res/raw/thumb_google.png b/res/raw/thumb_google.png
new file mode 100644
index 0000000..1753788
--- /dev/null
+++ b/res/raw/thumb_google.png
Binary files differ
diff --git a/res/raw/thumb_msn.png b/res/raw/thumb_msn.png
new file mode 100644
index 0000000..2240e12
--- /dev/null
+++ b/res/raw/thumb_msn.png
Binary files differ
diff --git a/res/raw/thumb_myspace.png b/res/raw/thumb_myspace.png
new file mode 100644
index 0000000..3f39ac5
--- /dev/null
+++ b/res/raw/thumb_myspace.png
Binary files differ
diff --git a/res/raw/thumb_nytimes.png b/res/raw/thumb_nytimes.png
new file mode 100644
index 0000000..d6849c3
--- /dev/null
+++ b/res/raw/thumb_nytimes.png
Binary files differ
diff --git a/res/raw/thumb_picasa.png b/res/raw/thumb_picasa.png
new file mode 100644
index 0000000..dca6a7d
--- /dev/null
+++ b/res/raw/thumb_picasa.png
Binary files differ
diff --git a/res/raw/thumb_weatherchannel.png b/res/raw/thumb_weatherchannel.png
new file mode 100644
index 0000000..c91e54c
--- /dev/null
+++ b/res/raw/thumb_weatherchannel.png
Binary files differ
diff --git a/res/raw/thumb_wikipedia.png b/res/raw/thumb_wikipedia.png
new file mode 100644
index 0000000..7929468
--- /dev/null
+++ b/res/raw/thumb_wikipedia.png
Binary files differ
diff --git a/res/raw/thumb_yahoo.png b/res/raw/thumb_yahoo.png
new file mode 100644
index 0000000..115d8bb
--- /dev/null
+++ b/res/raw/thumb_yahoo.png
Binary files differ
diff --git a/res/values/bookmarks_icons.xml b/res/values/bookmarks_icons.xml
new file mode 100644
index 0000000..3f1b5d6
--- /dev/null
+++ b/res/values/bookmarks_icons.xml
@@ -0,0 +1,33 @@
+<?xml version="1.0" encoding="utf-8"?>
+<resources>
+ <array name="bookmark_preloads">
+ <item>@raw/favicon_google</item>
+ <item>@raw/thumb_google</item>
+ <item>@raw/favicon_picasa</item>
+ <item>@raw/thumb_picasa</item>
+ <item>@raw/favicon_yahoo</item>
+ <item>@raw/thumb_yahoo</item>
+ <item>@raw/favicon_msn</item>
+ <item>@raw/thumb_msn</item>
+ <item>@raw/favicon_myspace</item>
+ <item>@raw/thumb_myspace</item>
+ <item>@raw/favicon_facebook</item>
+ <item>@raw/thumb_facebook</item>
+ <item>@raw/favicon_wikipedia</item>
+ <item>@raw/thumb_wikipedia</item>
+ <item>@raw/favicon_ebay</item>
+ <item>@raw/thumb_ebay</item>
+ <item>@raw/favicon_cnn</item>
+ <item>@raw/thumb_cnn</item>
+ <item>@raw/favicon_nytimes</item>
+ <item>@raw/thumb_nytimes</item>
+ <item>@raw/favicon_espn</item>
+ <item>@raw/thumb_espn</item>
+ <item>@raw/favicon_amazon</item>
+ <item>@raw/thumb_amazon</item>
+ <item>@raw/favicon_weatherchannel</item>
+ <item>@raw/thumb_weatherchannel</item>
+ <item>@raw/favicon_bbc</item>
+ <item>@raw/thumb_bbc</item>
+ </array>
+</resources>
diff --git a/src/com/android/browser/provider/BrowserProvider2.java b/src/com/android/browser/provider/BrowserProvider2.java
index 03f0557..5b87d0f 100644
--- a/src/com/android/browser/provider/BrowserProvider2.java
+++ b/src/com/android/browser/provider/BrowserProvider2.java
@@ -25,6 +25,8 @@ import android.content.ContentUris;
import android.content.ContentValues;
import android.content.Context;
import android.content.UriMatcher;
+import android.content.res.Resources;
+import android.content.res.TypedArray;
import android.database.Cursor;
import android.database.DatabaseUtils;
import android.database.sqlite.SQLiteDatabase;
@@ -45,6 +47,9 @@ import android.provider.ContactsContract.RawContacts;
import android.provider.SyncStateContract;
import android.text.TextUtils;
+import java.io.ByteArrayOutputStream;
+import java.io.IOException;
+import java.io.InputStream;
import java.util.HashMap;
public class BrowserProvider2 extends SQLiteContentProvider {
@@ -275,8 +280,6 @@ public class BrowserProvider2 extends SQLiteContentProvider {
// TODO indices
- createDefaultBookmarks(db);
-
db.execSQL("CREATE TABLE " + TABLE_HISTORY + "(" +
History._ID + " INTEGER PRIMARY KEY AUTOINCREMENT," +
History.TITLE + " TEXT," +
@@ -339,6 +342,8 @@ public class BrowserProvider2 extends SQLiteContentProvider {
"FROM bookmarks LEFT OUTER JOIN images ON bookmarks.url = images.url_key WHERE url NOT IN (SELECT url FROM history)");
mSyncHelper.createDatabase(db);
+
+ createDefaultBookmarks(db);
}
@Override
@@ -377,9 +382,11 @@ public class BrowserProvider2 extends SQLiteContentProvider {
}
private void addDefaultBookmarks(SQLiteDatabase db, long parentId) {
- final CharSequence[] bookmarks = getContext().getResources().getTextArray(
+ Resources res = getContext().getResources();
+ final CharSequence[] bookmarks = res.getTextArray(
R.array.bookmarks);
int size = bookmarks.length;
+ TypedArray preloads = res.obtainTypedArray(R.array.bookmark_preloads);
try {
String parent = Long.toString(parentId);
String now = Long.toString(System.currentTimeMillis());
@@ -401,11 +408,50 @@ public class BrowserProvider2 extends SQLiteContentProvider {
Integer.toString(i) + "," +
now +
");");
+
+ int faviconId = preloads.getResourceId(i, 0);
+ int thumbId = preloads.getResourceId(i + 1, 0);
+ byte[] thumb = null, favicon = null;
+ try {
+ thumb = readRaw(res, thumbId);
+ } catch (IOException e) {
+ }
+ try {
+ favicon = readRaw(res, faviconId);
+ } catch (IOException e) {
+ }
+ if (thumb != null || favicon != null) {
+ ContentValues imageValues = new ContentValues();
+ imageValues.put(Images.URL, bookmarkDestination.toString());
+ if (favicon != null) {
+ imageValues.put(Images.FAVICON, favicon);
+ }
+ if (thumb != null) {
+ imageValues.put(Images.THUMBNAIL, thumb);
+ }
+ db.insert(TABLE_IMAGES, Images.FAVICON, imageValues);
+ }
}
} catch (ArrayIndexOutOfBoundsException e) {
}
}
+ private byte[] readRaw(Resources res, int id) throws IOException {
+ InputStream is = res.openRawResource(id);
+ try {
+ ByteArrayOutputStream bos = new ByteArrayOutputStream();
+ byte[] buf = new byte[4096];
+ int read;
+ while ((read = is.read(buf)) > 0) {
+ bos.write(buf, 0, read);
+ }
+ bos.flush();
+ return bos.toByteArray();
+ } finally {
+ is.close();
+ }
+ }
+
// XXX: This is a major hack to remove our dependency on gsf constants and
// its content provider. http://b/issue?id=2425179
private String getClientId(ContentResolver cr) {
@@ -844,7 +890,7 @@ public class BrowserProvider2 extends SQLiteContentProvider {
insertSettingsInTransaction(db, values);
break;
}
-
+
default: {
throw new UnsupportedOperationException("Unknown insert URI " + uri);
}