diff options
Diffstat (limited to 'src/com/android/browser')
-rw-r--r-- | src/com/android/browser/BaseUi.java | 12 | ||||
-rw-r--r-- | src/com/android/browser/BrowserSnapshotPage.java | 233 | ||||
-rw-r--r-- | src/com/android/browser/CombinedBookmarkHistoryView.java | 73 | ||||
-rw-r--r-- | src/com/android/browser/Controller.java | 131 | ||||
-rw-r--r-- | src/com/android/browser/PhoneUi.java | 4 | ||||
-rw-r--r-- | src/com/android/browser/Tab.java | 9 | ||||
-rw-r--r-- | src/com/android/browser/TabControl.java | 20 | ||||
-rw-r--r-- | src/com/android/browser/UI.java | 8 | ||||
-rw-r--r-- | src/com/android/browser/UiController.java | 2 | ||||
-rw-r--r-- | src/com/android/browser/XLargeUi.java | 5 | ||||
-rw-r--r-- | src/com/android/browser/provider/BrowserProvider2.java | 1 |
11 files changed, 360 insertions, 138 deletions
diff --git a/src/com/android/browser/BaseUi.java b/src/com/android/browser/BaseUi.java index e577b1b..e2ad329 100644 --- a/src/com/android/browser/BaseUi.java +++ b/src/com/android/browser/BaseUi.java @@ -16,7 +16,6 @@ package com.android.browser; -import android.animation.ObjectAnimator; import android.app.Activity; import android.content.pm.PackageManager; import android.content.res.Configuration; @@ -477,15 +476,13 @@ public abstract class BaseUi implements UI, OnTouchListener { } @Override - public void showComboView(boolean startWithHistory, Bundle extras) { + public void showComboView(ComboViews startingView, Bundle extras) { if (mComboView != null) { return; } mComboView = new CombinedBookmarkHistoryView(mActivity, mUiController, - startWithHistory ? - CombinedBookmarkHistoryView.FRAGMENT_ID_HISTORY - : CombinedBookmarkHistoryView.FRAGMENT_ID_BOOKMARKS, + startingView, extras); FrameLayout wrapper = (FrameLayout) mContentView.findViewById(R.id.webview_wrapper); @@ -496,11 +493,6 @@ public abstract class BaseUi implements UI, OnTouchListener { if (mActiveTab != null) { mActiveTab.putInBackground(); } - mComboView.setAlpha(0f); - ObjectAnimator anim = ObjectAnimator.ofFloat(mComboView, "alpha", 0f, 1f); - Resources res = mActivity.getResources(); - anim.setDuration(res.getInteger(R.integer.comboViewFadeInDuration)); - anim.start(); mContentView.addView(mComboView, COVER_SCREEN_PARAMS); } diff --git a/src/com/android/browser/BrowserSnapshotPage.java b/src/com/android/browser/BrowserSnapshotPage.java new file mode 100644 index 0000000..06b2e42 --- /dev/null +++ b/src/com/android/browser/BrowserSnapshotPage.java @@ -0,0 +1,233 @@ +/* + * Copyright (C) 2011 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package com.android.browser; + +import android.app.Fragment; +import android.app.LoaderManager.LoaderCallbacks; +import android.content.ContentResolver; +import android.content.ContentUris; +import android.content.Context; +import android.content.CursorLoader; +import android.content.Loader; +import android.database.Cursor; +import android.graphics.Bitmap; +import android.graphics.BitmapFactory; +import android.net.Uri; +import android.os.Bundle; +import android.view.ContextMenu; +import android.view.ContextMenu.ContextMenuInfo; +import android.view.LayoutInflater; +import android.view.MenuInflater; +import android.view.MenuItem; +import android.view.View; +import android.view.View.MeasureSpec; +import android.view.ViewGroup; +import android.widget.AdapterView; +import android.widget.AdapterView.AdapterContextMenuInfo; +import android.widget.AdapterView.OnItemClickListener; +import android.widget.GridView; +import android.widget.ImageView; +import android.widget.ResourceCursorAdapter; +import android.widget.TextView; + +import com.android.browser.provider.BrowserProvider2.Snapshots; + +import java.text.DateFormat; +import java.util.Date; + +public class BrowserSnapshotPage extends Fragment implements + LoaderCallbacks<Cursor>, OnItemClickListener { + + public static final String EXTRA_ANIMATE_ID = "animate_id"; + + private static final int LOADER_SNAPSHOTS = 1; + private static final String[] PROJECTION = new String[] { + Snapshots._ID, + Snapshots.TITLE, + "length(" + Snapshots.VIEWSTATE + ")", + Snapshots.THUMBNAIL, + Snapshots.FAVICON, + Snapshots.URL, + }; + private static final int SNAPSHOT_TITLE = 1; + private static final int SNAPSHOT_VIEWSTATE_LENGTH = 2; + private static final int SNAPSHOT_THUMBNAIL = 3; + private static final int SNAPSHOT_FAVICON = 4; + private static final int SNAPSHOT_URL = 5; + + GridView mGrid; + View mEmpty; + SnapshotAdapter mAdapter; + UiController mUiController; + + public static BrowserSnapshotPage newInstance(UiController uiController, + Bundle extras) { + BrowserSnapshotPage instance = new BrowserSnapshotPage(); + instance.mUiController = uiController; + instance.setArguments(extras); + return instance; + } + + @Override + public View onCreateView(LayoutInflater inflater, ViewGroup container, + Bundle savedInstanceState) { + View view = inflater.inflate(R.layout.snapshots, container, false); + mEmpty = view.findViewById(android.R.id.empty); + mGrid = (GridView) view.findViewById(R.id.grid); + setupGrid(inflater); + getLoaderManager().initLoader(LOADER_SNAPSHOTS, null, this); + return view; + } + + @Override + public void onDestroyView() { + super.onDestroyView(); + getLoaderManager().destroyLoader(LOADER_SNAPSHOTS); + mAdapter.changeCursor(null); + mAdapter = null; + } + + void setupGrid(LayoutInflater inflater) { + View item = inflater.inflate(R.layout.snapshot_item, mGrid, false); + int mspec = MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED); + item.measure(mspec, mspec); + int width = item.getMeasuredWidth(); + mGrid.setColumnWidth(width); + mGrid.setOnItemClickListener(this); + mGrid.setOnCreateContextMenuListener(this); + } + + @Override + public Loader<Cursor> onCreateLoader(int id, Bundle args) { + if (id == LOADER_SNAPSHOTS) { + // TODO: Sort by date created + return new CursorLoader(getActivity(), + Snapshots.CONTENT_URI, PROJECTION, + null, null, null); + } + return null; + } + + @Override + public void onLoadFinished(Loader<Cursor> loader, Cursor data) { + if (loader.getId() == LOADER_SNAPSHOTS) { + if (mAdapter == null) { + mAdapter = new SnapshotAdapter(getActivity(), data); + mGrid.setAdapter(mAdapter); + } else { + mAdapter.changeCursor(data); + } + boolean empty = mAdapter.isEmpty(); + mGrid.setVisibility(empty ? View.GONE : View.VISIBLE); + mEmpty.setVisibility(empty ? View.VISIBLE : View.GONE); + } + } + + @Override + public void onLoaderReset(Loader<Cursor> loader) { + } + + @Override + public void onCreateContextMenu(ContextMenu menu, View v, + ContextMenuInfo menuInfo) { + MenuInflater inflater = getActivity().getMenuInflater(); + inflater.inflate(R.menu.snapshots_context, menu); + // Create the header, re-use BookmarkItem (has the layout we want) + BookmarkItem header = new BookmarkItem(getActivity()); + AdapterContextMenuInfo info = (AdapterContextMenuInfo) menuInfo; + populateBookmarkItem(mAdapter.getItem(info.position), header); + menu.setHeaderView(header); + } + + private void populateBookmarkItem(Cursor cursor, BookmarkItem item) { + item.setName(cursor.getString(SNAPSHOT_TITLE)); + item.setUrl(cursor.getString(SNAPSHOT_URL)); + item.setFavicon(getBitmap(cursor, SNAPSHOT_FAVICON)); + } + + static Bitmap getBitmap(Cursor cursor, int columnIndex) { + byte[] data = cursor.getBlob(columnIndex); + if (data == null) { + return null; + } + return BitmapFactory.decodeByteArray(data, 0, data.length); + } + + @Override + public boolean onContextItemSelected(MenuItem item) { + if (item.getItemId() == R.id.delete_context_menu_id) { + AdapterContextMenuInfo info = (AdapterContextMenuInfo) item.getMenuInfo(); + deleteSnapshot(info.id); + return true; + } + return super.onContextItemSelected(item); + } + + void deleteSnapshot(long id) { + final Uri uri = ContentUris.withAppendedId(Snapshots.CONTENT_URI, id); + final ContentResolver cr = getActivity().getContentResolver(); + new Thread() { + @Override + public void run() { + cr.delete(uri, null, null); + } + }.start(); + + } + + @Override + public void onItemClick(AdapterView<?> parent, View view, int position, + long id) { + mUiController.removeComboView(); + mUiController.createNewSnapshotTab(id, true); + } + + private static class SnapshotAdapter extends ResourceCursorAdapter { + + public SnapshotAdapter(Context context, Cursor c) { + super(context, R.layout.snapshot_item, c, 0); + } + + @Override + public void bindView(View view, Context context, Cursor cursor) { + ImageView thumbnail = (ImageView) view.findViewById(R.id.thumb); + byte[] thumbBlob = cursor.getBlob(SNAPSHOT_THUMBNAIL); + if (thumbBlob == null) { + thumbnail.setImageResource(R.drawable.browser_thumbnail); + } else { + Bitmap thumbBitmap = BitmapFactory.decodeByteArray( + thumbBlob, 0, thumbBlob.length); + thumbnail.setImageBitmap(thumbBitmap); + } + TextView title = (TextView) view.findViewById(R.id.title); + title.setText(cursor.getString(SNAPSHOT_TITLE)); + TextView size = (TextView) view.findViewById(R.id.size); + int stateLen = cursor.getInt(SNAPSHOT_VIEWSTATE_LENGTH); + size.setText(String.format("%.1fMB", stateLen / 1024f / 1024f)); + // We don't actually have the date in the database yet + // Use the current date as a placeholder + TextView date = (TextView) view.findViewById(R.id.date); + DateFormat dateFormat = DateFormat.getDateInstance(DateFormat.SHORT); + date.setText(dateFormat.format(new Date())); + } + + @Override + public Cursor getItem(int position) { + return (Cursor) super.getItem(position); + } + } + +} diff --git a/src/com/android/browser/CombinedBookmarkHistoryView.java b/src/com/android/browser/CombinedBookmarkHistoryView.java index 785b2cd..184314e 100644 --- a/src/com/android/browser/CombinedBookmarkHistoryView.java +++ b/src/com/android/browser/CombinedBookmarkHistoryView.java @@ -17,6 +17,8 @@ package com.android.browser; +import android.animation.Animator; +import android.animation.AnimatorListenerAdapter; import android.app.ActionBar; import android.app.ActionBar.Tab; import android.app.ActionBar.TabListener; @@ -28,7 +30,6 @@ import android.content.res.Configuration; import android.content.res.Resources; import android.database.Cursor; import android.graphics.Bitmap; -import android.net.Uri; import android.os.AsyncTask; import android.os.Bundle; import android.provider.Browser; @@ -45,6 +46,8 @@ import android.webkit.WebIconDatabase.IconListener; import android.widget.FrameLayout; import android.widget.LinearLayout; +import com.android.browser.UI.ComboViews; + import java.util.HashMap; import java.util.Vector; @@ -61,6 +64,7 @@ public class CombinedBookmarkHistoryView extends LinearLayout final static int INVALID_ID = 0; final static int FRAGMENT_ID_BOOKMARKS = 1; final static int FRAGMENT_ID_HISTORY = 2; + final static int FRAGMENT_ID_SNAPSHOTS = 3; private UiController mUiController; private Activity mActivity; @@ -72,10 +76,13 @@ public class CombinedBookmarkHistoryView extends LinearLayout ActionBar.Tab mTabBookmarks; ActionBar.Tab mTabHistory; + ActionBar.Tab mTabSnapshots; ViewGroup mBookmarksHeader; BrowserBookmarksPage mBookmarks; BrowserHistoryPage mHistory; + BrowserSnapshotPage mSnapshots; + boolean mIsAnimating; static class IconListenerSet implements IconListener { // Used to store favicons as we get them from the database @@ -115,7 +122,7 @@ public class CombinedBookmarkHistoryView extends LinearLayout } public CombinedBookmarkHistoryView(Activity activity, UiController controller, - int startingFragment, Bundle extras) { + ComboViews startingView, Bundle extras) { super(activity); mUiController = controller; mActivity = activity; @@ -124,7 +131,6 @@ public class CombinedBookmarkHistoryView extends LinearLayout View v = LayoutInflater.from(activity).inflate(R.layout.bookmarks_history, this); v.setOnTouchListener(this); - Resources res = activity.getResources(); // setDefaultKeyMode(DEFAULT_KEYS_SEARCH_LOCAL); @@ -152,11 +158,28 @@ public class CombinedBookmarkHistoryView extends LinearLayout } }).execute(); - setupActionBar(startingFragment); + mIsAnimating = true; + setAlpha(0f); + Resources res = mActivity.getResources(); + animate().alpha(1f) + .setDuration(res.getInteger(R.integer.comboViewFadeInDuration)) + .setListener(new AnimatorListenerAdapter() { + @Override + public void onAnimationEnd(Animator animation) { + super.onAnimationEnd(animation); + mIsAnimating = false; + FragmentManager fm = mActivity.getFragmentManager(); + FragmentTransaction ft = fm.beginTransaction(); + onTabSelected(mActionBar.getSelectedTab(), ft); + ft.commit(); + } + }); + + setupActionBar(startingView); mUiController.registerOptionsMenuHandler(this); } - void setupActionBar(int startingFragment) { + void setupActionBar(ComboViews startingView) { if (BrowserActivity.isTablet(mContext)) { mActionBar.setDisplayOptions(ActionBar.DISPLAY_SHOW_HOME | ActionBar.DISPLAY_USE_LOGO); @@ -168,15 +191,32 @@ public class CombinedBookmarkHistoryView extends LinearLayout mTabBookmarks = mActionBar.newTab(); mTabBookmarks.setText(R.string.tab_bookmarks); mTabBookmarks.setTabListener(this); - mActionBar.addTab(mTabBookmarks, FRAGMENT_ID_BOOKMARKS == startingFragment); + mActionBar.addTab(mTabBookmarks, ComboViews.Bookmarks == startingView); mTabHistory = mActionBar.newTab(); mTabHistory.setText(R.string.tab_history); mTabHistory.setTabListener(this); - mActionBar.addTab(mTabHistory, FRAGMENT_ID_HISTORY == startingFragment); + mActionBar.addTab(mTabHistory, ComboViews.History == startingView); + mTabSnapshots = mActionBar.newTab(); + mTabSnapshots.setText(R.string.tab_snapshots); + mTabSnapshots.setTabListener(this); + mActionBar.addTab(mTabSnapshots, ComboViews.Snapshots == startingView); mActionBar.setCustomView(mBookmarksHeader); mActionBar.show(); } + void tearDownActionBar() { + if (mActionBar != null) { + mActionBar.removeAllTabs(); + mTabBookmarks.setTabListener(null); + mTabHistory.setTabListener(null); + mTabSnapshots.setTabListener(null); + mTabBookmarks = null; + mTabHistory = null; + mTabSnapshots = null; + mActionBar = null; + } + } + @Override protected void onConfigurationChanged(Configuration newConfig) { super.onConfigurationChanged(newConfig); @@ -210,6 +250,7 @@ public class CombinedBookmarkHistoryView extends LinearLayout mBookmarks = BrowserBookmarksPage.newInstance(mBookmarkCallbackWrapper, extras, mBookmarksHeader); mHistory = BrowserHistoryPage.newInstance(mUiController, extras); + mSnapshots = BrowserSnapshotPage.newInstance(mUiController, extras); } private void loadFragment(int id, FragmentTransaction ft) { @@ -222,6 +263,9 @@ public class CombinedBookmarkHistoryView extends LinearLayout case FRAGMENT_ID_HISTORY: ft.replace(R.id.fragment, mHistory); break; + case FRAGMENT_ID_SNAPSHOTS: + ft.replace(R.id.fragment, mSnapshots); + break; default: throw new IllegalArgumentException(); } @@ -231,6 +275,7 @@ public class CombinedBookmarkHistoryView extends LinearLayout @Override protected void onDetachedFromWindow() { super.onDetachedFromWindow(); + tearDownActionBar(); if (mCurrentFragment != INVALID_ID) { try { FragmentManager fm = mActivity.getFragmentManager(); @@ -239,6 +284,8 @@ public class CombinedBookmarkHistoryView extends LinearLayout transaction.remove(mBookmarks); } else if (mCurrentFragment == FRAGMENT_ID_HISTORY) { transaction.remove(mHistory); + } else if (mCurrentFragment == FRAGMENT_ID_SNAPSHOTS) { + transaction.remove(mSnapshots); } transaction.commit(); } catch (IllegalStateException ex) { @@ -256,6 +303,9 @@ public class CombinedBookmarkHistoryView extends LinearLayout * callback for back key presses */ boolean onBackPressed() { + if (mIsAnimating) { + return true; + } if (mCurrentFragment == FRAGMENT_ID_BOOKMARKS) { return mBookmarks.onBackPressed(); } @@ -278,10 +328,19 @@ public class CombinedBookmarkHistoryView extends LinearLayout @Override public void onTabSelected(Tab tab, FragmentTransaction ft) { + if (mIsAnimating) { + // We delay set while animating (smooth animations) + // TODO: Signal to the fragment in advance so that it can start + // loading its data asynchronously + return; + } + if (tab == mTabBookmarks) { loadFragment(FRAGMENT_ID_BOOKMARKS, ft); } else if (tab == mTabHistory) { loadFragment(FRAGMENT_ID_HISTORY, ft); + } else if (tab == mTabSnapshots) { + loadFragment(FRAGMENT_ID_SNAPSHOTS, ft); } } diff --git a/src/com/android/browser/Controller.java b/src/com/android/browser/Controller.java index 9046745..88fcbd6 100644 --- a/src/com/android/browser/Controller.java +++ b/src/com/android/browser/Controller.java @@ -40,7 +40,6 @@ import android.net.Uri; import android.net.http.SslError; import android.os.AsyncTask; import android.os.Bundle; -import android.os.Environment; import android.os.Handler; import android.os.Message; import android.os.PowerManager; @@ -77,6 +76,7 @@ import android.webkit.WebView; import android.widget.Toast; import com.android.browser.IntentHandler.UrlData; +import com.android.browser.UI.ComboViews; import com.android.browser.UI.DropdownChangeListener; import com.android.browser.provider.BrowserProvider; import com.android.browser.provider.BrowserProvider2.Snapshots; @@ -330,7 +330,6 @@ public class Controller webView.setInitialScale(scale); } } - mTabControl.loadSnapshotTabs(); mUi.updateTabs(mTabControl.getTabs()); } else { mTabControl.restoreState(icicle, currentTabId, restoreIncognitoTabs, @@ -1179,7 +1178,8 @@ public class Controller // Disable opening in a new window if we have maxed out the windows extras.putBoolean(BrowserBookmarksPage.EXTRA_DISABLE_WINDOW, !mTabControl.canCreateNewTab()); - mUi.showComboView(startWithHistory, extras); + mUi.showComboView(startWithHistory + ? ComboViews.History : ComboViews.Bookmarks, extras); } // combo view callbacks @@ -1520,11 +1520,9 @@ public class Controller final MenuItem newtab = menu.findItem(R.id.new_tab_menu_id); newtab.setEnabled(getTabControl().canCreateNewTab()); - MenuItem archive = menu.findItem(R.id.save_webarchive_menu_id); - Tab tab = getTabControl().getCurrentTab(); - String url = tab != null ? tab.getUrl() : null; - archive.setVisible(!TextUtils.isEmpty(url) - && !url.endsWith(".webarchivexml")); + MenuItem saveSnapshot = menu.findItem(R.id.save_snapshot_menu_id); + Tab tab = getCurrentTab(); + saveSnapshot.setVisible(tab != null && !tab.isSnapshot()); break; } mCurrentMenuState = mMenuState; @@ -1619,83 +1617,32 @@ public class Controller getCurrentTopWebView().showFindDialog(null, true); break; - case R.id.freeze_tab_menu_id: - // TODO: Show error messages - Tab source = getTabControl().getCurrentTab(); + case R.id.save_snapshot_menu_id: + final Tab source = getTabControl().getCurrentTab(); if (source == null) break; final ContentResolver cr = mActivity.getContentResolver(); final ContentValues values = source.createSnapshotValues(); - new AsyncTask<Tab, Void, Long>() { - @Override - protected Long doInBackground(Tab... params) { - Tab t = params[0]; - if (values == null) { - return t.isSnapshot() - ? ((SnapshotTab)t).getSnapshotId() - : -1; + if (values != null) { + new AsyncTask<Tab, Void, Long>() { + + @Override + protected Long doInBackground(Tab... params) { + Uri result = cr.insert(Snapshots.CONTENT_URI, values); + long id = ContentUris.parseId(result); + return id; } - Uri result = cr.insert(Snapshots.CONTENT_URI, values); - long id = ContentUris.parseId(result); - return id; - } - - @Override - protected void onPostExecute(Long id) { - if (id > 0) { - createNewSnapshotTab(id, true); - } - }; - }.execute(source); - break; - case R.id.save_webarchive_menu_id: - String state = Environment.getExternalStorageState(); - if (!Environment.MEDIA_MOUNTED.equals(state)) { - Log.e(LOGTAG, "External storage not mounted"); - Toast.makeText(mActivity, R.string.webarchive_failed, - Toast.LENGTH_SHORT).show(); - break; - } - final String directory = Environment.getExternalStoragePublicDirectory( - Environment.DIRECTORY_DOWNLOADS) + File.separator; - File dir = new File(directory); - if (!dir.exists() && !dir.mkdirs()) { - Log.e(LOGTAG, "Save as Web Archive: mkdirs for " + directory + " failed!"); - Toast.makeText(mActivity, R.string.webarchive_failed, + @Override + protected void onPostExecute(Long id) { + Bundle b = new Bundle(); + b.putLong(BrowserSnapshotPage.EXTRA_ANIMATE_ID, id); + mUi.showComboView(ComboViews.Snapshots, b); + }; + }.execute(source); + } else { + Toast.makeText(mActivity, R.string.snapshot_failed, Toast.LENGTH_SHORT).show(); - break; } - final WebView topWebView = getCurrentTopWebView(); - final String title = topWebView.getTitle(); - final String url = topWebView.getUrl(); - topWebView.saveWebArchive(directory, true, - new ValueCallback<String>() { - @Override - public void onReceiveValue(final String value) { - if (value != null) { - File file = new File(value); - final long length = file.length(); - if (file.exists() && length > 0) { - Toast.makeText(mActivity, R.string.webarchive_saved, - Toast.LENGTH_SHORT).show(); - final DownloadManager manager = (DownloadManager) mActivity - .getSystemService(Context.DOWNLOAD_SERVICE); - new Thread("Add WebArchive to download manager") { - @Override - public void run() { - manager.addCompletedDownload( - null == title ? value : title, - value, true, "application/x-webarchive-xml", - value, length, true); - } - }.start(); - return; - } - } - DownloadHandler.onDownloadStartNoStream(mActivity, - url, null, null, null, topWebView.isPrivateBrowsingEnabled()); - } - }); break; case R.id.page_info_menu_id: @@ -2166,18 +2113,6 @@ public class Controller mUi.removeTab(tab); mTabControl.removeTab(tab); mCrashRecoveryHandler.backupState(); - if (tab.isSnapshot()) { - SnapshotTab st = (SnapshotTab) tab; - final Uri uri = ContentUris.withAppendedId( - Snapshots.CONTENT_URI, st.getSnapshotId()); - final ContentResolver cr = mActivity.getContentResolver(); - new Thread() { - @Override - public void run() { - cr.delete(uri, null, null); - } - }.start(); - } } @Override @@ -2326,11 +2261,17 @@ public class Controller return tab; } - private SnapshotTab createNewSnapshotTab(long snapshotId, boolean setActive) { - SnapshotTab tab = mTabControl.createSnapshotTab(snapshotId); - addTab(tab); - if (setActive) { - setActiveTab(tab); + @Override + public SnapshotTab createNewSnapshotTab(long snapshotId, boolean setActive) { + SnapshotTab tab = null; + if (mTabControl.canCreateNewTab()) { + tab = mTabControl.createSnapshotTab(snapshotId); + addTab(tab); + if (setActive) { + setActiveTab(tab); + } + } else { + mUi.showMaxTabsWarning(); } return tab; } diff --git a/src/com/android/browser/PhoneUi.java b/src/com/android/browser/PhoneUi.java index aedd712..0c236af 100644 --- a/src/com/android/browser/PhoneUi.java +++ b/src/com/android/browser/PhoneUi.java @@ -206,11 +206,11 @@ public class PhoneUi extends BaseUi { } @Override - public void showComboView(boolean startWithHistory, Bundle extras) { + public void showComboView(ComboViews startWith, Bundle extras) { if (mNavScreen != null) { hideNavScreen(false); } - super.showComboView(startWithHistory, extras); + super.showComboView(startWith, extras); } @Override diff --git a/src/com/android/browser/Tab.java b/src/com/android/browser/Tab.java index 334bd9d..a38c5f3 100644 --- a/src/com/android/browser/Tab.java +++ b/src/com/android/browser/Tab.java @@ -1875,6 +1875,15 @@ class Tab { public ContentValues createSnapshotValues() { if (mMainView == null) return null; + /* + * TODO: Compression + * Some quick tests indicate GZIPing the stream will result in + * some decent savings. There is little overhead for sites with mostly + * images (such as the "Most Visited" page), dropping from 235kb + * to 200kb. Sites with a decent amount of text (hardocp.com), the size + * drops from 522kb to 381kb. Do this as part of the switch to saving + * to the SD card. + */ ByteArrayOutputStream stream = new ByteArrayOutputStream(); if (!mMainView.saveViewState(stream)) { return null; diff --git a/src/com/android/browser/TabControl.java b/src/com/android/browser/TabControl.java index 1110bda..5f3995f 100644 --- a/src/com/android/browser/TabControl.java +++ b/src/com/android/browser/TabControl.java @@ -16,14 +16,10 @@ package com.android.browser; -import android.content.ContentResolver; -import android.database.Cursor; import android.os.Bundle; import android.util.Log; import android.webkit.WebView; -import com.android.browser.provider.BrowserProvider2.Snapshots; - import java.io.File; import java.util.ArrayList; import java.util.HashMap; @@ -215,7 +211,6 @@ class TabControl { } SnapshotTab createSnapshotTab(long snapshotId) { - // TODO: Don't count this against the limit SnapshotTab t = new SnapshotTab(mController, snapshotId); t.setId(getNextId()); mTabs.add(t); @@ -435,21 +430,6 @@ class TabControl { } } } - loadSnapshotTabs(); - - } - - void loadSnapshotTabs() { - ContentResolver cr = mController.getActivity().getContentResolver(); - Cursor c = cr.query(Snapshots.CONTENT_URI, new String[] { "_id" }, - null, null, null); - try { - while (c.moveToNext()) { - createSnapshotTab(c.getLong(0)); - } - } finally { - c.close(); - } } /** diff --git a/src/com/android/browser/UI.java b/src/com/android/browser/UI.java index a6356a3..93f6e63 100644 --- a/src/com/android/browser/UI.java +++ b/src/com/android/browser/UI.java @@ -33,6 +33,12 @@ import java.util.List; */ public interface UI { + public static enum ComboViews { + History, + Bookmarks, + Snapshots, + } + public void onPause(); public void onResume(); @@ -77,7 +83,7 @@ public interface UI { public void removeActiveTabsPage(); - public void showComboView(boolean startWithHistory, Bundle extra); + public void showComboView(ComboViews startingView, Bundle extra); public void hideComboView(); diff --git a/src/com/android/browser/UiController.java b/src/com/android/browser/UiController.java index 05eaf8e..4550a8a 100644 --- a/src/com/android/browser/UiController.java +++ b/src/com/android/browser/UiController.java @@ -97,4 +97,6 @@ public interface UiController extends BookmarksHistoryCallbacks { boolean onOptionsItemSelected(MenuItem item); + SnapshotTab createNewSnapshotTab(long snapshotId, boolean setActive); + } diff --git a/src/com/android/browser/XLargeUi.java b/src/com/android/browser/XLargeUi.java index 8455e74..81a6edb 100644 --- a/src/com/android/browser/XLargeUi.java +++ b/src/com/android/browser/XLargeUi.java @@ -77,9 +77,8 @@ public class XLargeUi extends BaseUi implements ScrollListener { } } - @Override - public void showComboView(boolean startWithHistory, Bundle extras) { - super.showComboView(startWithHistory, extras); + public void showComboView(ComboViews startWith, Bundle extras) { + super.showComboView(startWith, extras); if (mUseQuickControls) { mActionBar.show(); } diff --git a/src/com/android/browser/provider/BrowserProvider2.java b/src/com/android/browser/provider/BrowserProvider2.java index 06e4e4a..32fa172 100644 --- a/src/com/android/browser/provider/BrowserProvider2.java +++ b/src/com/android/browser/provider/BrowserProvider2.java @@ -78,6 +78,7 @@ public class BrowserProvider2 extends SQLiteContentProvider { public static final String TITLE = History.TITLE; public static final String URL = History.URL; public static final String FAVICON = History.FAVICON; + public static final String THUMBNAIL = History.THUMBNAIL; } public static final String PARAM_GROUP_BY = "groupBy"; |