diff options
author | John Reck <jreck@google.com> | 2011-02-16 16:43:03 -0800 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2011-02-16 16:43:03 -0800 |
commit | 15c0f987a09f24658946ce58dfb5a71dc0f04450 (patch) | |
tree | 5f2c4bd88fdd24e94d5b7b766fcff832687938ad /src | |
parent | 745f3704dccfb228d358bbe25bba90ffa88eeb97 (diff) | |
parent | 94b7e04932d77d73f348efecf7f2dd6b4ee5e5a1 (diff) | |
download | packages_apps_Browser-15c0f987a09f24658946ce58dfb5a71dc0f04450.zip packages_apps_Browser-15c0f987a09f24658946ce58dfb5a71dc0f04450.tar.gz packages_apps_Browser-15c0f987a09f24658946ce58dfb5a71dc0f04450.tar.bz2 |
Merge "Phone UI title bar work"
Diffstat (limited to 'src')
-rw-r--r-- | src/com/android/browser/BaseUi.java | 5 | ||||
-rw-r--r-- | src/com/android/browser/TitleBar.java | 61 | ||||
-rw-r--r-- | src/com/android/browser/TitleBarBase.java | 6 | ||||
-rw-r--r-- | src/com/android/browser/TitleBarXLarge.java | 3 | ||||
-rw-r--r-- | src/com/android/browser/XLargeUi.java | 8 |
5 files changed, 24 insertions, 59 deletions
diff --git a/src/com/android/browser/BaseUi.java b/src/com/android/browser/BaseUi.java index 9bce3cd..6e8f603 100644 --- a/src/com/android/browser/BaseUi.java +++ b/src/com/android/browser/BaseUi.java @@ -193,7 +193,10 @@ public abstract class BaseUi implements UI, WebViewFactory { @Override public void bookmarkedStatusHasChanged(Tab tab) { - // no op in base case + if (tab.inForeground()) { + boolean isBookmark = tab.isBookmarkedSite(); + getTitleBar().setCurrentUrlIsBookmark(isBookmark); + } } @Override diff --git a/src/com/android/browser/TitleBar.java b/src/com/android/browser/TitleBar.java index 56db187..686416c 100644 --- a/src/com/android/browser/TitleBar.java +++ b/src/com/android/browser/TitleBar.java @@ -21,15 +21,12 @@ import android.content.Intent; import android.content.pm.PackageManager; import android.content.pm.ResolveInfo; import android.content.res.Resources; -import android.graphics.drawable.Animatable; import android.graphics.drawable.Drawable; import android.speech.RecognizerIntent; import android.text.SpannableString; import android.text.Spanned; import android.text.TextUtils; import android.text.style.ImageSpan; -import android.util.DisplayMetrics; -import android.util.TypedValue; import android.view.ContextMenu; import android.view.LayoutInflater; import android.view.MenuInflater; @@ -38,7 +35,6 @@ import android.view.View.OnClickListener; import android.view.View.OnFocusChangeListener; import android.widget.ImageButton; import android.widget.ImageView; -import android.widget.ProgressBar; /** * This class represents a title bar for a particular "tab" or "window" in the @@ -49,19 +45,13 @@ public class TitleBar extends TitleBarBase implements OnFocusChangeListener, private Activity mActivity; private ImageButton mBookmarkButton; - private Drawable mCircularProgress; - private ProgressBar mHorizontalProgress; + private PageProgressView mHorizontalProgress; private ImageButton mStopButton; private Drawable mBookmarkDrawable; private Drawable mVoiceDrawable; private boolean mInLoad; - private View mTitleBg; private Intent mVoiceSearchIntent; - private Drawable mVoiceModeBackground; - private Drawable mNormalBackground; private ImageSpan mArcsSpan; - private int mLeftMargin; - private int mRightMargin; public TitleBar(Activity activity, UiController controller, PhoneUi ui) { super(activity, controller, ui); @@ -77,7 +67,6 @@ public class TitleBar extends TitleBarBase implements OnFocusChangeListener, mUrlInput.setUrlInputListener(this); mUrlInput.setOnFocusChangeListener(this); - mTitleBg = findViewById(R.id.title_bg); mLockIcon = (ImageView) findViewById(R.id.lock); mFavicon = (ImageView) findViewById(R.id.favicon); mStopButton = (ImageButton) findViewById(R.id.stop); @@ -85,18 +74,7 @@ public class TitleBar extends TitleBarBase implements OnFocusChangeListener, mStopButton.setOnClickListener(this); mBookmarkButton.setOnClickListener(this); - Resources resources = activity.getResources(); - mCircularProgress = resources.getDrawable( - com.android.internal.R.drawable.search_spinner); - DisplayMetrics metrics = resources.getDisplayMetrics(); - mLeftMargin = (int) TypedValue.applyDimension( - TypedValue.COMPLEX_UNIT_DIP, 8f, metrics); - mRightMargin = (int) TypedValue.applyDimension( - TypedValue.COMPLEX_UNIT_DIP, 6f, metrics); - int iconDimension = (int) TypedValue.applyDimension( - TypedValue.COMPLEX_UNIT_DIP, 20f, metrics); - mCircularProgress.setBounds(0, 0, iconDimension, iconDimension); - mHorizontalProgress = (ProgressBar) findViewById( + mHorizontalProgress = (PageProgressView) findViewById( R.id.progress_horizontal); mVoiceSearchIntent = new Intent(RecognizerIntent.ACTION_WEB_SEARCH); mVoiceSearchIntent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL, @@ -110,6 +88,7 @@ public class TitleBar extends TitleBarBase implements OnFocusChangeListener, PackageManager pm = activity.getPackageManager(); ResolveInfo ri = pm.resolveActivity(mVoiceSearchIntent, PackageManager.MATCH_DEFAULT_ONLY); + Resources resources = getResources(); if (ri == null) { mVoiceSearchIntent = null; } else { @@ -117,9 +96,6 @@ public class TitleBar extends TitleBarBase implements OnFocusChangeListener, android.R.drawable.ic_btn_speak_now); } mBookmarkDrawable = mBookmarkButton.getDrawable(); - mVoiceModeBackground = resources.getDrawable( - R.drawable.title_voice); - mNormalBackground = mTitleBg.getBackground(); mArcsSpan = new ImageSpan(activity, R.drawable.arcs, ImageSpan.ALIGN_BASELINE); } @@ -142,13 +118,9 @@ public class TitleBar extends TitleBarBase implements OnFocusChangeListener, Drawable titleDrawable; if (mInVoiceMode) { mBookmarkButton.setImageDrawable(mVoiceDrawable); - titleDrawable = mVoiceModeBackground; mUrlInput.setEllipsize(null); mBookmarkButton.setVisibility(View.VISIBLE); mStopButton.setVisibility(View.GONE); - mTitleBg.setBackgroundDrawable(titleDrawable); - mTitleBg.setPadding(mLeftMargin, mTitleBg.getPaddingTop(), - mRightMargin, mTitleBg.getPaddingBottom()); } else { if (mInLoad) { mBookmarkButton.setVisibility(View.GONE); @@ -159,7 +131,6 @@ public class TitleBar extends TitleBarBase implements OnFocusChangeListener, mBookmarkButton.setImageDrawable(mBookmarkDrawable); } mUrlInput.setEllipsize(TextUtils.TruncateAt.END); - mTitleBg.setPadding(mLeftMargin, 0, mRightMargin, 0); } mUrlInput.setSingleLine(!mInVoiceMode); } @@ -169,31 +140,20 @@ public class TitleBar extends TitleBarBase implements OnFocusChangeListener, */ @Override void setProgress(int newProgress) { - if (newProgress >= mHorizontalProgress.getMax()) { - mUrlInput.setCompoundDrawables(null, null, null, null); - ((Animatable) mCircularProgress).stop(); - mHorizontalProgress.setVisibility(View.INVISIBLE); + if (newProgress >= PROGRESS_MAX) { + mHorizontalProgress.setVisibility(View.GONE); if (!mInVoiceMode) { mBookmarkButton.setImageDrawable(mBookmarkDrawable); mBookmarkButton.setVisibility(View.VISIBLE); mStopButton.setVisibility(View.GONE); - mTitleBg.setBackgroundDrawable(mNormalBackground); - mTitleBg.setPadding(mLeftMargin, 0, mRightMargin, 0); } mInLoad = false; } else { - mHorizontalProgress.setProgress(newProgress); - if (!mInLoad && getWindowToken() != null) { - // checking the window token lets us be sure that we - // are attached to a window before starting the animation, - // preventing a potential race condition - // (fix for bug http://b/2115736) - mUrlInput.setCompoundDrawables(null, null, mCircularProgress, - null); - ((Animatable) mCircularProgress).start(); + mHorizontalProgress.setProgress(newProgress * PageProgressView.MAX_PROGRESS + / PROGRESS_MAX); + if (!mInLoad) { mHorizontalProgress.setVisibility(View.VISIBLE); if (!mInVoiceMode) { - mTitleBg.setPadding(mLeftMargin, 0, mRightMargin, 0); mBookmarkButton.setVisibility(View.GONE); mStopButton.setVisibility(View.VISIBLE); } @@ -243,4 +203,9 @@ public class TitleBar extends TitleBarBase implements OnFocusChangeListener, true); } } + + @Override + public void setCurrentUrlIsBookmark(boolean isBookmark) { + mBookmarkButton.setActivated(isBookmark); + } } diff --git a/src/com/android/browser/TitleBarBase.java b/src/com/android/browser/TitleBarBase.java index f62e0e4..2b64aa3 100644 --- a/src/com/android/browser/TitleBarBase.java +++ b/src/com/android/browser/TitleBarBase.java @@ -39,6 +39,9 @@ import android.widget.LinearLayout; * Base class for a title bar used by the browser. */ public class TitleBarBase extends LinearLayout implements UrlInputListener { + + protected static final int PROGRESS_MAX = 100; + // These need to be set by the subclass. protected ImageView mFavicon; protected ImageView mLockIcon; @@ -168,4 +171,7 @@ public class TitleBarBase extends LinearLayout implements UrlInputListener { } } + public void setCurrentUrlIsBookmark(boolean isBookmark) { + } + } diff --git a/src/com/android/browser/TitleBarXLarge.java b/src/com/android/browser/TitleBarXLarge.java index 3931526..c732da8 100644 --- a/src/com/android/browser/TitleBarXLarge.java +++ b/src/com/android/browser/TitleBarXLarge.java @@ -48,8 +48,6 @@ public class TitleBarXLarge extends TitleBarBase implements OnClickListener, OnFocusChangeListener, TextWatcher { - private static final int PROGRESS_MAX = 100; - private XLargeUi mUi; private Drawable mStopDrawable; @@ -210,6 +208,7 @@ public class TitleBarXLarge extends TitleBarBase mUrlInput.clearNeedsUpdate(); } + @Override public void setCurrentUrlIsBookmark(boolean isBookmark) { mStar.setActivated(isBookmark); } diff --git a/src/com/android/browser/XLargeUi.java b/src/com/android/browser/XLargeUi.java index f361e57..90e3683 100644 --- a/src/com/android/browser/XLargeUi.java +++ b/src/com/android/browser/XLargeUi.java @@ -161,14 +161,6 @@ public class XLargeUi extends BaseUi implements ScrollListener { // WebView callbacks @Override - public void bookmarkedStatusHasChanged(Tab tab) { - if (tab.inForeground()) { - boolean isBookmark = tab.isBookmarkedSite(); - mTitleBar.setCurrentUrlIsBookmark(isBookmark); - } - } - - @Override public void onProgressChanged(Tab tab) { int progress = tab.getLoadProgress(); mTabBar.onProgress(tab, progress); |