Fixed recently introduced UI bug in desktop tab mode.

This commit is contained in:
Anthony Restaino 2015-10-15 22:45:56 -04:00
parent 577efb76a4
commit 7bba86d963
8 changed files with 70 additions and 100 deletions

View File

@ -88,7 +88,6 @@
<category android:name="android.intent.category.DEFAULT" /> <category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" /> <category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="" />
<data android:scheme="http" /> <data android:scheme="http" />
<data android:scheme="https" /> <data android:scheme="https" />
</intent-filter> </intent-filter>

View File

@ -28,6 +28,7 @@ import android.os.Bundle;
import android.os.Handler; import android.os.Handler;
import android.os.Message; import android.os.Message;
import android.provider.MediaStore; import android.provider.MediaStore;
import android.support.annotation.ColorInt;
import android.support.annotation.IdRes; import android.support.annotation.IdRes;
import android.support.annotation.NonNull; import android.support.annotation.NonNull;
import android.support.annotation.Nullable; import android.support.annotation.Nullable;
@ -240,16 +241,12 @@ public abstract class BrowserActivity extends ThemableBrowserActivity implements
mIconColor = mDarkTheme ? ThemeUtils.getIconDarkThemeColor(this) : ThemeUtils.getIconLightThemeColor(this); mIconColor = mDarkTheme ? ThemeUtils.getIconDarkThemeColor(this) : ThemeUtils.getIconLightThemeColor(this);
mShowTabsInDrawer = mPreferences.getShowTabsInDrawer(!isTablet()); mShowTabsInDrawer = mPreferences.getShowTabsInDrawer(!isTablet());
// initialize background ColorDrawable // initialize background ColorDrawable
mBackground.setColor(((ColorDrawable) mToolbarLayout.getBackground()).getColor()); mBackground.setColor(((ColorDrawable) mToolbarLayout.getBackground()).getColor());
// Drawer stutters otherwise // Drawer stutters otherwise
mDrawerLeft.setLayerType(View.LAYER_TYPE_HARDWARE, null); mDrawerLeft.setLayerType(View.LAYER_TYPE_HARDWARE, null);
mDrawerRight.setLayerType(View.LAYER_TYPE_HARDWARE, null); mDrawerRight.setLayerType(View.LAYER_TYPE_HARDWARE, null);
// TODO Please review this
// ImageView tabTitleImage = (ImageView) findViewById(R.id.plusIcon);
// tabTitleImage.setColorFilter(mIconColor, PorterDuff.Mode.SRC_IN);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP && !mShowTabsInDrawer) { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP && !mShowTabsInDrawer) {
getWindow().setStatusBarColor(Color.BLACK); getWindow().setStatusBarColor(Color.BLACK);
@ -413,9 +410,8 @@ public abstract class BrowserActivity extends ThemableBrowserActivity implements
} else { } else {
mSearch.setText(url); mSearch.setText(url);
} }
((AutoCompleteTextView) v).selectAll(); // Hack to make sure // Hack to make sure the text gets selected
// the text gets ((AutoCompleteTextView) v).selectAll();
// selected
mIcon = mClearIcon; mIcon = mClearIcon;
mSearch.setCompoundDrawables(null, null, mClearIcon, null); mSearch.setCompoundDrawables(null, null, mClearIcon, null);
} }
@ -1211,7 +1207,8 @@ public abstract class BrowserActivity extends ThemableBrowserActivity implements
* @param favicon the Bitmap to extract the color from * @param favicon the Bitmap to extract the color from
* @param tabBackground the optional LinearLayout to color * @param tabBackground the optional LinearLayout to color
*/ */
private void changeToolbarBackground(@NonNull Bitmap favicon, @Nullable final Drawable tabBackground) { @Override
public void changeToolbarBackground(@NonNull Bitmap favicon, @Nullable final Drawable tabBackground) {
final int defaultColor = ContextCompat.getColor(this, R.color.primary_color); final int defaultColor = ContextCompat.getColor(this, R.color.primary_color);
if (mCurrentUiColor == Color.BLACK) { if (mCurrentUiColor == Color.BLACK) {
mCurrentUiColor = defaultColor; mCurrentUiColor = defaultColor;
@ -1259,6 +1256,12 @@ public abstract class BrowserActivity extends ThemableBrowserActivity implements
}); });
} }
@ColorInt
@Override
public int getUiColor() {
return mCurrentUiColor;
}
@Override @Override
public void updateUrl(String url, boolean shortUrl) { public void updateUrl(String url, boolean shortUrl) {
final LightningView currentTab = tabsManager.getCurrentTab(); final LightningView currentTab = tabsManager.getCurrentTab();

View File

@ -3,8 +3,13 @@
*/ */
package acr.browser.lightning.controller; package acr.browser.lightning.controller;
import android.graphics.Bitmap;
import android.graphics.drawable.Drawable;
import android.net.Uri; import android.net.Uri;
import android.os.Message; import android.os.Message;
import android.support.annotation.ColorInt;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import android.view.View; import android.view.View;
import android.webkit.ValueCallback; import android.webkit.ValueCallback;
import android.webkit.WebChromeClient.CustomViewCallback; import android.webkit.WebChromeClient.CustomViewCallback;
@ -13,6 +18,11 @@ import acr.browser.lightning.view.LightningView;
public interface BrowserController { public interface BrowserController {
void changeToolbarBackground(@NonNull Bitmap favicon, @Nullable Drawable drawable);
@ColorInt
int getUiColor();
void updateUrl(String title, boolean shortUrl); void updateUrl(String title, boolean shortUrl);
void updateProgress(int n); void updateProgress(int n);
@ -21,8 +31,6 @@ public interface BrowserController {
void openFileChooser(ValueCallback<Uri> uploadMsg); void openFileChooser(ValueCallback<Uri> uploadMsg);
// void onLongPress();
void onShowCustomView(View view, CustomViewCallback callback); void onShowCustomView(View view, CustomViewCallback callback);
void onHideCustomView(); void onHideCustomView();
@ -35,12 +43,8 @@ public interface BrowserController {
void showActionBar(); void showActionBar();
// void longClickPage(String url);
void showFileChooser(ValueCallback<Uri[]> filePathCallback); void showFileChooser(ValueCallback<Uri[]> filePathCallback);
void closeEmptyTab(); void closeEmptyTab();
// void updateBookmarkIndicator(String url);
} }

View File

@ -1,9 +1,6 @@
package acr.browser.lightning.fragment; package acr.browser.lightning.fragment;
import android.animation.ArgbEvaluator;
import android.animation.ValueAnimator;
import android.content.Context; import android.content.Context;
import android.content.res.Resources;
import android.graphics.Bitmap; import android.graphics.Bitmap;
import android.graphics.Canvas; import android.graphics.Canvas;
import android.graphics.Color; import android.graphics.Color;
@ -13,7 +10,6 @@ import android.graphics.ColorMatrixColorFilter;
import android.graphics.Paint; import android.graphics.Paint;
import android.graphics.PorterDuff; import android.graphics.PorterDuff;
import android.graphics.drawable.BitmapDrawable; import android.graphics.drawable.BitmapDrawable;
import android.graphics.drawable.ColorDrawable;
import android.graphics.drawable.Drawable; import android.graphics.drawable.Drawable;
import android.os.Build; import android.os.Build;
import android.os.Bundle; import android.os.Bundle;
@ -21,9 +17,7 @@ import android.support.annotation.IdRes;
import android.support.annotation.NonNull; import android.support.annotation.NonNull;
import android.support.annotation.Nullable; import android.support.annotation.Nullable;
import android.support.v4.app.Fragment; import android.support.v4.app.Fragment;
import android.support.v4.content.ContextCompat;
import android.support.v4.view.ViewCompat; import android.support.v4.view.ViewCompat;
import android.support.v7.graphics.Palette;
import android.support.v7.widget.LinearLayoutManager; import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView; import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.RecyclerView.LayoutManager; import android.support.v7.widget.RecyclerView.LayoutManager;
@ -46,14 +40,18 @@ import acr.browser.lightning.app.BrowserApp;
import acr.browser.lightning.bus.BrowserEvents; import acr.browser.lightning.bus.BrowserEvents;
import acr.browser.lightning.bus.NavigationEvents; import acr.browser.lightning.bus.NavigationEvents;
import acr.browser.lightning.bus.TabEvents; import acr.browser.lightning.bus.TabEvents;
import acr.browser.lightning.controller.BrowserController;
import acr.browser.lightning.preference.PreferenceManager; import acr.browser.lightning.preference.PreferenceManager;
import acr.browser.lightning.utils.ThemeUtils; import acr.browser.lightning.utils.ThemeUtils;
import acr.browser.lightning.utils.Utils; import acr.browser.lightning.utils.Utils;
import acr.browser.lightning.view.LightningView; import acr.browser.lightning.view.LightningView;
/** /**
* @author Stefano Pacifici based on Anthony C. Restaino's code * A fragment that holds and manages the tabs and interaction with the tabs.
* @date 2015/09/14 * It is reliant on the BrowserController in order to get the current UI state
* of the browser. It also uses the BrowserController to signal that the UI needs
* to change. This class contains the adapter used by both the drawer tabs and
* the desktop tabs. It delegates touch events for the tab UI appropriately.
*/ */
public class TabsFragment extends Fragment implements View.OnClickListener, View.OnLongClickListener { public class TabsFragment extends Fragment implements View.OnClickListener, View.OnLongClickListener {
@ -70,16 +68,16 @@ public class TabsFragment extends Fragment implements View.OnClickListener, View
private int mIconColor; private int mIconColor;
private boolean mColorMode = true; private boolean mColorMode = true;
private boolean mShowInNavigationDrawer; private boolean mShowInNavigationDrawer;
private int mCurrentUiColor = Color.BLACK; // TODO Only temporary
private RecyclerView mRecyclerView; private RecyclerView mRecyclerView;
private LightningViewAdapter mTabsAdapter; private LightningViewAdapter mTabsAdapter;
private BrowserController mUiController;
@Inject @Inject
TabsManager tabsManager; TabsManager tabsManager;
@Inject @Inject
Bus bus; Bus mBus;
@Inject @Inject
PreferenceManager mPreferences; PreferenceManager mPreferences;
@ -93,6 +91,7 @@ public class TabsFragment extends Fragment implements View.OnClickListener, View
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
final Bundle arguments = getArguments(); final Bundle arguments = getArguments();
final Context context = getContext(); final Context context = getContext();
mUiController = (BrowserController) getActivity();
mIsIncognito = arguments.getBoolean(IS_INCOGNITO, false); mIsIncognito = arguments.getBoolean(IS_INCOGNITO, false);
mShowInNavigationDrawer = arguments.getBoolean(VERTICAL_MODE, true); mShowInNavigationDrawer = arguments.getBoolean(VERTICAL_MODE, true);
mDarkTheme = mPreferences.getUseTheme() != 0 || mIsIncognito; mDarkTheme = mPreferences.getUseTheme() != 0 || mIsIncognito;
@ -106,7 +105,6 @@ public class TabsFragment extends Fragment implements View.OnClickListener, View
@Nullable @Nullable
@Override @Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
final Bundle arguments = getArguments();
final View view; final View view;
final LayoutManager layoutManager; final LayoutManager layoutManager;
if (mShowInNavigationDrawer) { if (mShowInNavigationDrawer) {
@ -148,7 +146,7 @@ public class TabsFragment extends Fragment implements View.OnClickListener, View
@Override @Override
public void onStart() { public void onStart() {
super.onStart(); super.onStart();
bus.register(this); mBus.register(this);
} }
@Override @Override
@ -161,7 +159,7 @@ public class TabsFragment extends Fragment implements View.OnClickListener, View
@Override @Override
public void onStop() { public void onStop() {
super.onStop(); super.onStop();
bus.unregister(this); mBus.unregister(this);
} }
@Subscribe @Subscribe
@ -175,16 +173,16 @@ public class TabsFragment extends Fragment implements View.OnClickListener, View
public void onClick(View v) { public void onClick(View v) {
switch (v.getId()) { switch (v.getId()) {
case R.id.new_tab_button: case R.id.new_tab_button:
bus.post(new TabEvents.NewTab()); mBus.post(new TabEvents.NewTab());
break; break;
case R.id.action_back: case R.id.action_back:
bus.post(new NavigationEvents.GoBack()); mBus.post(new NavigationEvents.GoBack());
break; break;
case R.id.action_forward: case R.id.action_forward:
bus.post(new NavigationEvents.GoForward()); mBus.post(new NavigationEvents.GoForward());
break; break;
case R.id.action_home: case R.id.action_home:
bus.post(new NavigationEvents.GoHome()); mBus.post(new NavigationEvents.GoHome());
default: default:
break; break;
} }
@ -194,7 +192,7 @@ public class TabsFragment extends Fragment implements View.OnClickListener, View
public boolean onLongClick(View v) { public boolean onLongClick(View v) {
switch (v.getId()) { switch (v.getId()) {
case R.id.action_new_tab: case R.id.action_new_tab:
bus.post(new TabEvents.NewTabLongPress()); mBus.post(new TabEvents.NewTabLongPress());
break; break;
default: default:
break; break;
@ -204,7 +202,7 @@ public class TabsFragment extends Fragment implements View.OnClickListener, View
public class LightningViewAdapter extends RecyclerView.Adapter<LightningViewAdapter.LightningViewHolder> { public class LightningViewAdapter extends RecyclerView.Adapter<LightningViewAdapter.LightningViewHolder> {
private final int layoutResourceId; private final int mLayoutResourceId;
private final Drawable mBackgroundTabDrawable; private final Drawable mBackgroundTabDrawable;
private final Drawable mForegroundTabDrawable; private final Drawable mForegroundTabDrawable;
private final Bitmap mForegroundTabBitmap; private final Bitmap mForegroundTabBitmap;
@ -213,11 +211,11 @@ public class TabsFragment extends Fragment implements View.OnClickListener, View
private ColorFilter mFilter; private ColorFilter mFilter;
private static final float DESATURATED = 0.5f; private static final float DESATURATED = 0.5f;
private final boolean vertical; private final boolean mDrawerTabs;
public LightningViewAdapter(final boolean vertical) { public LightningViewAdapter(final boolean vertical) {
this.layoutResourceId = vertical ? R.layout.tab_list_item : R.layout.tab_list_item_horizontal; this.mLayoutResourceId = vertical ? R.layout.tab_list_item : R.layout.tab_list_item_horizontal;
this.vertical = vertical; this.mDrawerTabs = vertical;
if (vertical) { if (vertical) {
mBackgroundTabDrawable = null; mBackgroundTabDrawable = null;
@ -239,7 +237,7 @@ public class TabsFragment extends Fragment implements View.OnClickListener, View
@Override @Override
public LightningViewHolder onCreateViewHolder(ViewGroup viewGroup, int i) { public LightningViewHolder onCreateViewHolder(ViewGroup viewGroup, int i) {
LayoutInflater inflater = LayoutInflater.from(viewGroup.getContext()); LayoutInflater inflater = LayoutInflater.from(viewGroup.getContext());
View view = inflater.inflate(layoutResourceId, viewGroup, false); View view = inflater.inflate(mLayoutResourceId, viewGroup, false);
return new LightningViewHolder(view); return new LightningViewHolder(view);
} }
@ -263,10 +261,10 @@ public class TabsFragment extends Fragment implements View.OnClickListener, View
holder.txtTitle.setTextAppearance(getContext(), R.style.boldText); holder.txtTitle.setTextAppearance(getContext(), R.style.boldText);
} }
Drawable foregroundDrawable; Drawable foregroundDrawable;
if (!vertical) { if (!mDrawerTabs) {
foregroundDrawable = new BitmapDrawable(getResources(), mForegroundTabBitmap); foregroundDrawable = new BitmapDrawable(getResources(), mForegroundTabBitmap);
if (!mIsIncognito && mColorMode) { if (!mIsIncognito && mColorMode) {
foregroundDrawable.setColorFilter(mCurrentUiColor, PorterDuff.Mode.SRC_IN); foregroundDrawable.setColorFilter(mUiController.getUiColor(), PorterDuff.Mode.SRC_IN);
} }
} else { } else {
foregroundDrawable = mForegroundTabDrawable; foregroundDrawable = mForegroundTabDrawable;
@ -277,7 +275,7 @@ public class TabsFragment extends Fragment implements View.OnClickListener, View
holder.layout.setBackgroundDrawable(foregroundDrawable); holder.layout.setBackgroundDrawable(foregroundDrawable);
} }
if (!mIsIncognito && mColorMode) { if (!mIsIncognito && mColorMode) {
changeToolbarBackground(favicon, foregroundDrawable); mUiController.changeToolbarBackground(favicon, foregroundDrawable);
} }
holder.favicon.setImageBitmap(favicon); holder.favicon.setImageBitmap(favicon);
} else { } else {
@ -317,57 +315,6 @@ public class TabsFragment extends Fragment implements View.OnClickListener, View
return grayscaleBitmap; return grayscaleBitmap;
} }
/**
* Animates the color of the toolbar from one color to another. Optionally animates
* the color of the tab background, for use when the tabs are displayed on the top
* of the screen.
*
* @param favicon the Bitmap to extract the color from
* @param tabBackground the optional LinearLayout to color
*/
private void changeToolbarBackground(@NonNull Bitmap favicon, @Nullable final Drawable tabBackground) {
if (mShowInNavigationDrawer) {
return;
}
final int defaultColor = ContextCompat.getColor(getContext(), R.color.primary_color);
if (mCurrentUiColor == Color.BLACK) {
mCurrentUiColor = defaultColor;
}
Palette.from(favicon).generate(new Palette.PaletteAsyncListener() {
@Override
public void onGenerated(Palette palette) {
// OR with opaque black to remove transparency glitches
int color = 0xff000000 | palette.getVibrantColor(defaultColor);
int finalColor = Utils.mixTwoColors(defaultColor, color, 0.25f);
ValueAnimator anim = ValueAnimator.ofInt(mCurrentUiColor, finalColor);
anim.setEvaluator(new ArgbEvaluator());
// final Window window = getWindow();
// TODO Check this
// if (!mShowInNavigationDrawer) {
// window.setBackgroundDrawable(new ColorDrawable(Color.BLACK));
// }
anim.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(ValueAnimator animation) {
final int color = (Integer) animation.getAnimatedValue();
if (tabBackground != null) {
tabBackground.setColorFilter(color, PorterDuff.Mode.SRC_IN);
}
mCurrentUiColor = color;
}
});
anim.setDuration(300);
anim.start();
}
});
}
public class LightningViewHolder extends RecyclerView.ViewHolder implements View.OnClickListener, View.OnLongClickListener { public class LightningViewHolder extends RecyclerView.ViewHolder implements View.OnClickListener, View.OnLongClickListener {
public LightningViewHolder(View view) { public LightningViewHolder(View view) {
@ -394,17 +341,17 @@ public class TabsFragment extends Fragment implements View.OnClickListener, View
public void onClick(View v) { public void onClick(View v) {
if (v == exitButton) { if (v == exitButton) {
// Close tab // Close tab
bus.post(new TabEvents.CloseTab(getAdapterPosition())); mBus.post(new TabEvents.CloseTab(getAdapterPosition()));
} }
if (v == layout) { if (v == layout) {
bus.post(new TabEvents.ShowTab(getAdapterPosition())); mBus.post(new TabEvents.ShowTab(getAdapterPosition()));
} }
} }
@Override @Override
public boolean onLongClick(View v) { public boolean onLongClick(View v) {
// Show close dialog // Show close dialog
bus.post(new TabEvents.ShowCloseDialog(getAdapterPosition())); mBus.post(new TabEvents.ShowCloseDialog(getAdapterPosition()));
return true; return true;
} }
} }

View File

@ -35,6 +35,7 @@ import com.squareup.otto.Bus;
import java.io.File; import java.io.File;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
import java.io.FileOutputStream; import java.io.FileOutputStream;
import java.lang.ref.WeakReference;
import javax.inject.Inject; import javax.inject.Inject;
@ -74,7 +75,7 @@ public class LightningView {
0, 0, -1.0f, 0, 255, // blue 0, 0, -1.0f, 0, 255, // blue
0, 0, 0, 1.0f, 0 // alpha 0, 0, 0, 1.0f, 0 // alpha
}; };
private final WebViewHandler mWebViewHandler = new WebViewHandler(); private final WebViewHandler mWebViewHandler = new WebViewHandler(this);
@Inject @Inject
Bus mEventBus; Bus mEventBus;
@ -773,12 +774,22 @@ public class LightningView {
} }
} }
private class WebViewHandler extends Handler { private static class WebViewHandler extends Handler {
private WeakReference<LightningView> mReference;
public WebViewHandler(LightningView view) {
mReference = new WeakReference<>(view);
}
@Override @Override
public void handleMessage(Message msg) { public void handleMessage(Message msg) {
super.handleMessage(msg); super.handleMessage(msg);
final String url = msg.getData().getString("url"); final String url = msg.getData().getString("url");
longClickPage(url); LightningView view = mReference.get();
if (view != null) {
view.longClickPage(url);
}
} }
} }
} }

View File

@ -123,7 +123,6 @@
<string name="licenses">Licenze Open Source</string> <string name="licenses">Licenze Open Source</string>
<string name="suggestion">Cerca</string> <string name="suggestion">Cerca</string>
<string name="block_ads">Blocca Annunci</string> <string name="block_ads">Blocca Annunci</string>
<string name="message_untrusted_certificate">Il certificato di questo sito non è sicuro. Vuoi procedere lo stesso?</string>
<string name="title_form_resubmission">Reinvio Modulo</string> <string name="title_form_resubmission">Reinvio Modulo</string>
<string name="message_form_resubmission">Vuoi inviare nuovamente i dati?</string> <string name="message_form_resubmission">Vuoi inviare nuovamente i dati?</string>
<string name="message_location">\nVorrebbe usare la tua posizione</string> <string name="message_location">\nVorrebbe usare la tua posizione</string>

View File

@ -0,0 +1,8 @@
<?xml version="1.0" encoding="utf-8"?>
<resources>
<style name="normalText">
<item name="android:textStyle">normal</item>
<item name="android:fontFamily">sans-serif-light</item>
</style>
</resources>

View File

@ -123,7 +123,6 @@
<style name="normalText"> <style name="normalText">
<item name="android:textStyle">normal</item> <item name="android:textStyle">normal</item>
<item name="android:fontFamily">sans-serif-light</item>
</style> </style>
<style name="TwoWayView"> <style name="TwoWayView">