NavDrawer contents visible through status bar

pull/281/head
Alex Baker 9 years ago
parent 8e909a26ba
commit 48a4a4c32e

@ -354,6 +354,10 @@ public class AndroidUtilities {
return !atLeastJellybean(); return !atLeastJellybean();
} }
public static boolean preLollipop() {
return !atLeastLollipop();
}
public static boolean atLeastFroyo() { public static boolean atLeastFroyo() {
return Build.VERSION.SDK_INT >= Build.VERSION_CODES.FROYO; return Build.VERSION.SDK_INT >= Build.VERSION_CODES.FROYO;
} }

@ -49,7 +49,7 @@ public class TagSettingsActivity extends InjectingAppCompatActivity {
@Override @Override
protected void onCreate(Bundle savedInstanceState) { protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
preferences.applyTheme(); preferences.applyThemeAndStatusBarColor();
setContentView(R.layout.tag_settings_activity); setContentView(R.layout.tag_settings_activity);
tagData = getIntent().getParcelableExtra(TagViewFragment.EXTRA_TAG_DATA); tagData = getIntent().getParcelableExtra(TagViewFragment.EXTRA_TAG_DATA);

@ -21,6 +21,7 @@ import com.commonsware.cwac.tlv.TouchListView.DropListener;
import org.tasks.R; import org.tasks.R;
import org.tasks.injection.InjectingListActivity; import org.tasks.injection.InjectingListActivity;
import org.tasks.preferences.ActivityPreferences;
import org.tasks.preferences.Preferences; import org.tasks.preferences.Preferences;
import java.util.ArrayList; import java.util.ArrayList;
@ -41,11 +42,12 @@ public class BeastModePreferences extends InjectingListActivity {
private HashMap<String, String> prefsToDescriptions; private HashMap<String, String> prefsToDescriptions;
@Inject Preferences preferences; @Inject ActivityPreferences preferences;
@Override @Override
protected void onCreate(Bundle savedInstanceState) { protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
preferences.applyLightStatusBarColor();
setContentView(R.layout.beast_mode_pref_activity); setContentView(R.layout.beast_mode_pref_activity);
setTitle(R.string.EPr_beastMode_desc); setTitle(R.string.EPr_beastMode_desc);

@ -28,7 +28,7 @@ public class TaskEditActivity extends AstridActivity {
@Override @Override
protected void onCreate(Bundle savedInstanceState) { protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
preferences.applyTheme(); preferences.applyThemeAndStatusBarColor();
setContentView(R.layout.task_edit_wrapper_activity); setContentView(R.layout.task_edit_wrapper_activity);

@ -8,6 +8,9 @@ import android.view.ViewGroup;
import android.widget.LinearLayout; import android.widget.LinearLayout;
import org.tasks.R; import org.tasks.R;
import org.tasks.preferences.ActivityPreferences;
import javax.inject.Inject;
import dagger.ObjectGraph; import dagger.ObjectGraph;
@ -17,6 +20,8 @@ public abstract class InjectingPreferenceActivity extends PreferenceActivity imp
protected Toolbar toolbar; protected Toolbar toolbar;
@Inject ActivityPreferences activityPreferences;
@Override @Override
public void onCreate(Bundle savedInstanceState) { public void onCreate(Bundle savedInstanceState) {
objectGraph = ((Injector) getApplication()).getObjectGraph().plus(new ActivityModule(this)); objectGraph = ((Injector) getApplication()).getObjectGraph().plus(new ActivityModule(this));
@ -41,6 +46,8 @@ public abstract class InjectingPreferenceActivity extends PreferenceActivity imp
finish(); finish();
} }
}); });
activityPreferences.applyLightStatusBarColor();
} }
@Override @Override

@ -14,6 +14,7 @@ import javax.inject.Inject;
import javax.inject.Singleton; import javax.inject.Singleton;
import static com.todoroo.andlib.utility.AndroidUtilities.atLeastLollipop; import static com.todoroo.andlib.utility.AndroidUtilities.atLeastLollipop;
import static com.todoroo.andlib.utility.AndroidUtilities.preLollipop;
@Singleton @Singleton
public class ActivityPreferences extends Preferences { public class ActivityPreferences extends Preferences {
@ -33,20 +34,30 @@ public class ActivityPreferences extends Preferences {
return isTabletSized(context); return isTabletSized(context);
} }
public void applyThemeAndStatusBarColor() {
applyTheme();
applyStatusBarColor();
}
public void applyTheme() { public void applyTheme() {
applyTheme(isDarkTheme() ? R.style.Tasks_Dark : R.style.Tasks);
}
public void applyStatusBarColor() {
applyStatusBarColor(isDarkTheme() ? android.R.color.black : R.color.primary_dark);
}
public void applyLightStatusBarColor() {
applyStatusBarColor(R.color.primary_dark);
}
private void applyStatusBarColor(int color) {
if (preLollipop()) {
return;
}
Window window = activity.getWindow(); Window window = activity.getWindow();
Resources resources = activity.getResources(); Resources resources = activity.getResources();
if (isDarkTheme()) { window.setStatusBarColor(resources.getColor(color));
if (atLeastLollipop()) {
window.setStatusBarColor(resources.getColor(android.R.color.black));
}
applyTheme(R.style.Tasks_Dark);
} else {
if (atLeastLollipop()) {
window.setStatusBarColor(resources.getColor(R.color.primary_dark));
}
applyTheme(R.style.Tasks);
}
} }
public void applyTranslucentDialogTheme() { public void applyTranslucentDialogTheme() {

@ -7,6 +7,7 @@ import android.content.DialogInterface;
import android.content.Intent; import android.content.Intent;
import android.content.IntentFilter; import android.content.IntentFilter;
import android.graphics.Bitmap; import android.graphics.Bitmap;
import android.graphics.Rect;
import android.graphics.drawable.BitmapDrawable; import android.graphics.drawable.BitmapDrawable;
import android.os.Bundle; import android.os.Bundle;
import android.support.v4.view.GravityCompat; import android.support.v4.view.GravityCompat;
@ -49,6 +50,8 @@ import org.tasks.preferences.Preferences;
import javax.inject.Inject; import javax.inject.Inject;
import static com.todoroo.andlib.utility.AndroidUtilities.atLeastLollipop;
public class NavigationDrawerFragment extends InjectingFragment { public class NavigationDrawerFragment extends InjectingFragment {
private static final Logger log = LoggerFactory.getLogger(NavigationDrawerFragment.class); private static final Logger log = LoggerFactory.getLogger(NavigationDrawerFragment.class);
@ -131,6 +134,14 @@ public class NavigationDrawerFragment extends InjectingFragment {
public View onCreateView(LayoutInflater inflater, ViewGroup container, public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) { Bundle savedInstanceState) {
View layout = inflater.inflate(R.layout.fragment_navigation_drawer, container, false); View layout = inflater.inflate(R.layout.fragment_navigation_drawer, container, false);
if (atLeastLollipop()) {
((ScrimInsetsFrameLayout) layout.findViewById(R.id.scrim_layout)).setOnInsetsCallback(new ScrimInsetsFrameLayout.OnInsetsCallback() {
@Override
public void onInsetsChanged(Rect insets) {
mDrawerListView.setPadding(0, insets.top, 0, 0);
}
});
}
mDrawerListView = (ListView) layout.findViewById(android.R.id.list); mDrawerListView = (ListView) layout.findViewById(android.R.id.list);
mDrawerListView.setOnItemClickListener(new AdapterView.OnItemClickListener() { mDrawerListView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override @Override

@ -0,0 +1,142 @@
/*
* Copyright 2014 Google Inc.
*
* 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 org.tasks.ui;
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Canvas;
import android.graphics.Rect;
import android.graphics.drawable.Drawable;
import android.support.v4.view.ViewCompat;
import android.util.AttributeSet;
import android.widget.FrameLayout;
import org.tasks.R;
/**
* A layout that draws something in the insets passed to {@link #fitSystemWindows(Rect)}, i.e. the area above UI chrome
* (status and navigation bars, overlay action bars).
*/
public class ScrimInsetsFrameLayout extends FrameLayout {
private Drawable mInsetForeground;
private Rect mInsets;
private Rect mTempRect = new Rect();
private OnInsetsCallback mOnInsetsCallback;
public ScrimInsetsFrameLayout(Context context) {
super(context);
init(context, null, 0);
}
public ScrimInsetsFrameLayout(Context context, AttributeSet attrs) {
super(context, attrs);
init(context, attrs, 0);
}
public ScrimInsetsFrameLayout(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
init(context, attrs, defStyle);
}
private void init(Context context, AttributeSet attrs, int defStyle) {
final TypedArray a = context.obtainStyledAttributes(attrs,
R.styleable.ScrimInsetsFrameLayout, defStyle, 0);
if (a == null) {
return;
}
mInsetForeground = a.getDrawable(R.styleable.ScrimInsetsFrameLayout_insetForeground);
a.recycle();
setWillNotDraw(true);
}
@Override
protected boolean fitSystemWindows(Rect insets) {
mInsets = new Rect(insets);
setWillNotDraw(mInsetForeground == null);
ViewCompat.postInvalidateOnAnimation(this);
if (mOnInsetsCallback != null) {
mOnInsetsCallback.onInsetsChanged(insets);
}
return true; // consume insets
}
@Override
public void draw(Canvas canvas) {
super.draw(canvas);
int width = getWidth();
int height = getHeight();
if (mInsets != null && mInsetForeground != null) {
int sc = canvas.save();
canvas.translate(getScrollX(), getScrollY());
// Top
mTempRect.set(0, 0, width, mInsets.top);
mInsetForeground.setBounds(mTempRect);
mInsetForeground.draw(canvas);
// Bottom
mTempRect.set(0, height - mInsets.bottom, width, height);
mInsetForeground.setBounds(mTempRect);
mInsetForeground.draw(canvas);
// Left
mTempRect.set(0, mInsets.top, mInsets.left, height - mInsets.bottom);
mInsetForeground.setBounds(mTempRect);
mInsetForeground.draw(canvas);
// Right
mTempRect.set(width - mInsets.right, mInsets.top, width, height - mInsets.bottom);
mInsetForeground.setBounds(mTempRect);
mInsetForeground.draw(canvas);
canvas.restoreToCount(sc);
}
}
@Override
protected void onAttachedToWindow() {
super.onAttachedToWindow();
if (mInsetForeground != null) {
mInsetForeground.setCallback(this);
}
}
@Override
protected void onDetachedFromWindow() {
super.onDetachedFromWindow();
if (mInsetForeground != null) {
mInsetForeground.setCallback(null);
}
}
/**
* Allows the calling container to specify a callback for custom processing when insets change (i.e. when
* {@link #fitSystemWindows(Rect)} is called. This is useful for setting padding on UI elements based on
* UI chrome insets (e.g. a Google Map or a ListView). When using with ListView or GridView, remember to set
* clipToPadding to false.
*/
public void setOnInsetsCallback(OnInsetsCallback onInsetsCallback) {
mOnInsetsCallback = onInsetsCallback;
}
public static interface OnInsetsCallback {
public void onInsetsChanged(Rect insets);
}
}

@ -1,50 +1,57 @@
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" <org.tasks.ui.ScrimInsetsFrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools" xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/scrim_layout"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" android:layout_height="match_parent"
android:orientation="vertical"> android:fitsSystemWindows="true"
android:background="?attr/drawer_background"
<ListView app:insetForeground="#4000">
android:id="@android:id/list"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"
android:background="?attr/drawer_background"
android:cacheColorHint="@android:color/transparent"
android:choiceMode="singleChoice"
android:divider="@android:color/transparent"
android:fitsSystemWindows="true"
android:scrollbars="vertical"
android:scrollingCache="false"
tools:context=".NavigationDrawerFragment" />
<LinearLayout <LinearLayout
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="wrap_content" android:layout_height="match_parent"
android:layout_gravity="bottom"
android:background="?attr/drawer_background"
android:orientation="vertical"> android:orientation="vertical">
<View <ListView
android:id="@android:id/list"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="1px" android:layout_height="0dp"
android:background="?attr/asSeparatorBackground" /> android:layout_weight="1"
android:choiceMode="singleChoice"
android:divider="@android:color/transparent"
android:scrollbars="vertical"
android:clipToPadding="false"
tools:context=".NavigationDrawerFragment" />
<Button <LinearLayout
android:id="@+id/settings_row"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="45dp" android:layout_height="wrap_content"
android:gravity="start|center_vertical" android:layout_gravity="bottom"
android:drawableStart="?attr/ic_action_settings" android:orientation="vertical">
android:drawableLeft="?attr/ic_action_settings"
android:drawablePadding="10dp" <View
android:paddingLeft="10dp" android:layout_width="match_parent"
android:paddingStart="10dp" android:layout_height="1px"
android:textAppearance="@style/TextAppearance.FLA_Filter" android:background="?attr/asSeparatorBackground" />
android:layout_gravity="start"
android:text="@string/TLA_menu_settings" <Button
android:background="?attr/selectableItemBackground"/> android:id="@+id/settings_row"
android:layout_width="match_parent"
android:layout_height="45dp"
android:gravity="start|center_vertical"
android:drawableStart="?attr/ic_action_settings"
android:drawableLeft="?attr/ic_action_settings"
android:drawablePadding="10dp"
android:paddingLeft="10dp"
android:paddingStart="10dp"
android:textAppearance="@style/TextAppearance.FLA_Filter"
android:layout_gravity="start"
android:text="@string/TLA_menu_settings"
android:background="?attr/selectableItemBackground" />
</LinearLayout>
</LinearLayout> </LinearLayout>
</LinearLayout> </org.tasks.ui.ScrimInsetsFrameLayout>

@ -2,6 +2,7 @@
<resources> <resources>
<style name="AppThemeBase" parent="Theme.AppCompat.Light.NoActionBar"> <style name="AppThemeBase" parent="Theme.AppCompat.Light.NoActionBar">
<item name="android:windowDrawsSystemBarBackgrounds">true</item> <item name="android:windowDrawsSystemBarBackgrounds">true</item>
<item name="android:statusBarColor">@android:color/transparent</item>
</style> </style>
<style name="edit_text_style"> <style name="edit_text_style">

@ -58,4 +58,8 @@
<attr name="summary" format="string" /> <attr name="summary" format="string" />
</declare-styleable> </declare-styleable>
<declare-styleable name="ScrimInsetsFrameLayout">
<attr name="insetForeground" format="reference|color" />
</declare-styleable>
</resources> </resources>

Loading…
Cancel
Save