Merge "Add new attributes to our notification" into lmp-dev

This commit is contained in:
Jean Chalard 2014-08-28 09:22:18 +00:00 committed by Android (Google) Code Review
commit 6bd267f4f7
3 changed files with 95 additions and 3 deletions

View file

@ -82,4 +82,6 @@
<color name="setup_text_action">@android:color/holo_blue_light</color> <color name="setup_text_action">@android:color/holo_blue_light</color>
<color name="setup_step_background">@android:color/background_light</color> <color name="setup_step_background">@android:color/background_light</color>
<color name="setup_welcome_video_margin_color">#FFCCCCCC</color> <color name="setup_welcome_video_margin_color">#FFCCCCCC</color>
<!-- Accent color for the notification. We need to match this to the OS build -->
<color name="notification_accent_color">#FF607D8B</color>
</resources> </resources>

View file

@ -0,0 +1,83 @@
/*
* Copyright (C) 2014 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.inputmethod.compat;
import android.app.Notification;
import android.os.Build;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
public class NotificationCompatUtils {
// Note that TextInfo.getCharSequence() is supposed to be available in API level 21 and later.
private static final Method METHOD_setColor =
CompatUtils.getMethod(Notification.Builder.class, "setColor", int.class);
private static final Method METHOD_setVisibility =
CompatUtils.getMethod(Notification.Builder.class, "setVisibility", int.class);
private static final Method METHOD_setCategory =
CompatUtils.getMethod(Notification.Builder.class, "setCategory", String.class);
private static final Method METHOD_setPriority =
CompatUtils.getMethod(Notification.Builder.class, "setPriority", int.class);
private static final Method METHOD_build =
CompatUtils.getMethod(Notification.Builder.class, "build");
private static final Field FIELD_VISIBILITY_SECRET =
CompatUtils.getField(Notification.class, "VISIBILITY_SECRET");
private static final int VISIBILITY_SECRET = null == FIELD_VISIBILITY_SECRET ? 0
: (Integer) CompatUtils.getFieldValue(null /* receiver */, null /* defaultValue */,
FIELD_VISIBILITY_SECRET);
private static final Field FIELD_CATEGORY_RECOMMENDATION =
CompatUtils.getField(Notification.class, "CATEGORY_RECOMMENDATION");
private static final String CATEGORY_RECOMMENDATION = null == FIELD_CATEGORY_RECOMMENDATION ? ""
: (String) CompatUtils.getFieldValue(null /* receiver */, null /* defaultValue */,
FIELD_CATEGORY_RECOMMENDATION);
private static final Field FIELD_PRIORITY_LOW =
CompatUtils.getField(Notification.class, "PRIORITY_LOW");
private static final int PRIORITY_LOW = null == FIELD_PRIORITY_LOW ? 0
: (Integer) CompatUtils.getFieldValue(null /* receiver */, null /* defaultValue */,
FIELD_PRIORITY_LOW);
private NotificationCompatUtils() {
// This class is non-instantiable.
}
// Sets the accent color
public static void setColor(final Notification.Builder builder, final int color) {
CompatUtils.invoke(builder, null, METHOD_setColor, color);
}
public static void setVisibilityToSecret(final Notification.Builder builder) {
CompatUtils.invoke(builder, null, METHOD_setVisibility, VISIBILITY_SECRET);
}
public static void setCategoryToRecommendation(final Notification.Builder builder) {
CompatUtils.invoke(builder, null, METHOD_setCategory, CATEGORY_RECOMMENDATION);
}
public static void setPriorityToLow(final Notification.Builder builder) {
CompatUtils.invoke(builder, null, METHOD_setPriority, PRIORITY_LOW);
}
public static Notification build(final Notification.Builder builder) {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN) {
// #build was added in API level 16, JELLY_BEAN
return (Notification) CompatUtils.invoke(builder, null, METHOD_build);
} else {
// #getNotification was deprecated in API level 16, JELLY_BEAN
return builder.getNotification();
}
}
}

View file

@ -31,12 +31,14 @@ import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteDatabase;
import android.net.ConnectivityManager; import android.net.ConnectivityManager;
import android.net.Uri; import android.net.Uri;
import android.os.Build;
import android.os.ParcelFileDescriptor; import android.os.ParcelFileDescriptor;
import android.text.TextUtils; import android.text.TextUtils;
import android.util.Log; import android.util.Log;
import com.android.inputmethod.compat.ConnectivityManagerCompatUtils; import com.android.inputmethod.compat.ConnectivityManagerCompatUtils;
import com.android.inputmethod.compat.DownloadManagerCompatUtils; import com.android.inputmethod.compat.DownloadManagerCompatUtils;
import com.android.inputmethod.compat.NotificationCompatUtils;
import com.android.inputmethod.latin.R; import com.android.inputmethod.latin.R;
import com.android.inputmethod.latin.utils.ApplicationUtils; import com.android.inputmethod.latin.utils.ApplicationUtils;
import com.android.inputmethod.latin.utils.DebugLogUtils; import com.android.inputmethod.latin.utils.DebugLogUtils;
@ -858,7 +860,7 @@ public final class UpdateHandler {
final String language = (null == locale ? "" : locale.getDisplayLanguage()); final String language = (null == locale ? "" : locale.getDisplayLanguage());
final String titleFormat = context.getString(R.string.dict_available_notification_title); final String titleFormat = context.getString(R.string.dict_available_notification_title);
final String notificationTitle = String.format(titleFormat, language); final String notificationTitle = String.format(titleFormat, language);
final Notification notification = new Notification.Builder(context) final Notification.Builder builder = new Notification.Builder(context)
.setAutoCancel(true) .setAutoCancel(true)
.setContentIntent(notificationIntent) .setContentIntent(notificationIntent)
.setContentTitle(notificationTitle) .setContentTitle(notificationTitle)
@ -866,8 +868,13 @@ public final class UpdateHandler {
.setTicker(notificationTitle) .setTicker(notificationTitle)
.setOngoing(false) .setOngoing(false)
.setOnlyAlertOnce(true) .setOnlyAlertOnce(true)
.setSmallIcon(R.drawable.ic_notify_dictionary) .setSmallIcon(R.drawable.ic_notify_dictionary);
.getNotification(); NotificationCompatUtils.setColor(builder,
context.getResources().getColor(R.color.notification_accent_color));
NotificationCompatUtils.setPriorityToLow(builder);
NotificationCompatUtils.setVisibilityToSecret(builder);
NotificationCompatUtils.setCategoryToRecommendation(builder);
final Notification notification = NotificationCompatUtils.build(builder);
notificationManager.notify(DICT_AVAILABLE_NOTIFICATION_ID, notification); notificationManager.notify(DICT_AVAILABLE_NOTIFICATION_ID, notification);
} }