app开发快速理解——推送通知⼩红点⾓标
ample.chapter11;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
t.Context;
t.Intent;
aphics.BitmapFactory;
import android.os.Build;
import android.os.Bundle;
TextUtils;
import android.view.View;
import android.widget.EditText;
import android.widget.Toast;
import androidx.appcompat.app.AppCompatActivity;
ample.chapter11.util.ViewUtil;
public class NotifySimpleActivity extends AppCompatActivity implements View.OnClickListener {
private EditText et_title;
private EditText et_message;
@Override
protected void onCreate(Bundle savedInstanceState) {
setContentView(R.layout.activity_notify_simple);
et_title = findViewById(_title);
et_message = findViewById(_message);
findViewById(R.id.btn_send_simple).setOnClickListener(this);
}
@Override
public void onClick(View v) {
if (v.getId() == R.id.btn_send_simple) {
ViewUtil.hideOneInputMethod(this, et_message); // 隐藏输⼊法软键盘
if (TextUtils.isEmpty(Text())) {
Toast.makeText(this, "请填写消息标题", Toast.LENGTH_SHORT).show();
return;
}
if (TextUtils.isEmpty(Text())) {
Toast.makeText(this, "请填写消息内容", Toast.LENGTH_SHORT).show();
return;
}app开发实例
String title = Text().toString();
String message = Text().toString();
sendSimpleNotify(title, message); // 发送简单的通知消息
}
}
/
/ 发送简单的通知消息(包括消息标题和消息内容)
private void sendSimpleNotify(String title, String message) {
// 发送消息之前要先创建通知渠道,创建代码见MainApplication.java
// 创建⼀个跳转到活动页⾯的意图
Intent clickIntent = new Intent(this, MainActivity.class);
// 创建⼀个⽤于页⾯跳转的延迟意图
PendingIntent contentIntent = Activity(this,
R.string.app_name, clickIntent, PendingIntent.FLAG_UPDATE_CURRENT);
// 创建⼀个通知消息的建造器
Notification.Builder builder = new Notification.Builder(this);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
/
/ Android 8.0开始必须给每个通知分配对应的渠道
builder = new Notification.Builder(this, getString(R.string.app_name));
}
builder.setContentIntent(contentIntent) // 设置内容的点击意图
.setAutoCancel(true) // 点击通知栏后是否⾃动清除该通知
.setSmallIcon(R.mipmap.ic_launcher) // 设置应⽤名称左边的⼩图标
.setSubText("这⾥是副本") // 设置通知栏⾥⾯的附加说明⽂本
// 设置通知栏右边的⼤图标
.setLargeIcon(BitmapFactory.decodeResource(getResources(), R.drawable.ic_app))
.setContentTitle(title) // 设置通知栏⾥⾯的标题⽂本
.setContentText(message); // 设置通知栏⾥⾯的内容⽂本
Notification notify = builder.build(); // 根据通知建造器构建⼀个通知对象
// 从系统服务中获取通知管理器
NotificationManager notifyMgr = (NotificationManager)
getSystemService(Context.NOTIFICATION_SERVICE);
// 使⽤通知管理器推送通知,然后在⼿机的通知栏就会看到该消息
}
}
ample.chapter11;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
t.Context;
t.Intent;
aphics.BitmapFactory;
import android.os.Build;
import android.os.Bundle;
TextUtils;
import android.view.View;
import android.widget.EditText;
import android.widget.Toast;
import androidx.appcompat.app.AppCompatActivity;
ample.chapter11.util.ViewUtil;
public class NotifyCounterActivity extends AppCompatActivity implements View.OnClickListener { private EditText et_title;
private EditText et_message;
@Override
protected void onCreate(Bundle savedInstanceState) {
setContentView(R.layout.activity_notify_counter);
et_title = findViewById(_title);
et_message = findViewById(_message);
findViewById(R.id.btn_send_counter).setOnClickListener(this);
}
@Override
public void onClick(View v) {
if (v.getId() == R.id.btn_send_counter) {
ViewUtil.hideOneInputMethod(this, et_message); // 隐藏输⼊法软键盘
if (TextUtils.isEmpty(Text())) {
Toast.makeText(this, "请填写消息标题", Toast.LENGTH_SHORT).show();
return;
}
if (TextUtils.isEmpty(Text())) {
Toast.makeText(this, "请填写消息内容", Toast.LENGTH_SHORT).show();
return;
}
String title = Text().toString();
String message = Text().toString();
sendCounterNotify(title, message); // 发送计时的通知消息
}
}
// 发送计时的通知消息
private void sendCounterNotify(String title, String message) {
// 发送消息之前要先创建通知渠道,创建代码见MainApplication.java
// 创建⼀个跳转到活动页⾯的意图
Intent cancelIntent = new Intent(this, MainActivity.class);
/
/ 创建⼀个⽤于页⾯跳转的延迟意图
PendingIntent deleteIntent = Activity(this,
R.string.app_name, cancelIntent, PendingIntent.FLAG_UPDATE_CURRENT);
// 创建⼀个通知消息的建造器
Notification.Builder builder = new Notification.Builder(this);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
// Android 8.0开始必须给每个通知分配对应的渠道
builder = new Notification.Builder(this, getString(R.string.app_name));
}
builder.setDeleteIntent(deleteIntent) // 设置内容的清除意图
.setSmallIcon(R.mipmap.ic_launcher) // 设置应⽤名称左边的⼩图标
/
/ 设置通知栏右边的⼤图标
.setLargeIcon(BitmapFactory.decodeResource(getResources(), R.drawable.ic_app))
.setProgress(100, 60, false) // 设置进度条及其具体进度
.setUsesChronometer(true) // 设置是否显⽰计时器
.setContentTitle(title) // 设置通知栏⾥⾯的标题⽂本
.setContentText(message); // 设置通知栏⾥⾯的内容⽂本
Notification notify = builder.build(); // 根据通知建造器构建⼀个通知对象
// 从系统服务中获取通知管理器
NotificationManager notifyMgr = (NotificationManager)
getSystemService(Context.NOTIFICATION_SERVICE);
// 使⽤通知管理器推送通知,然后在⼿机的通知栏就会看到该消息
}
}
ample.chapter11.util;
import android.annotation.TargetApi;
import android.app.Notification;
import android.app.NotificationChannel;
import android.app.NotificationManager;
t.Context;
import android.Uri;
import android.os.Build;
import android.os.Bundle;
import android.util.Log;
ample.chapter11.BuildConfig;
import flect.Field;
import flect.Method;
public class NotifyUtil {
private final static String TAG = "NotifyUtil";
@TargetApi(Build.VERSION_CODES.O)
// 创建通知渠道。Android 8.0开始必须给每个通知分配对应的渠道
public static void createNotifyChannel(Context ctx, String channelId, String channelName, int importance)
{
// 从系统服务中获取通知管理器
NotificationManager notifyMgr = (NotificationManager)
if (NotificationChannel(channelId) == null)
{ // 已经存在指定编号的通知渠道
// 创建指定编号、指定名称、指定级别的通知渠道
NotificationChannel channel = new NotificationChannel(channelId, channelName, importance);
channel.setSound(null, null); // 设置推送通知之时的铃声。null表⽰静⾳推送
channel.setShowBadge(true); // 通知渠道是否在应⽤图标的右上⾓展⽰⼩红点
/
/ VISIBILITY_PUBLIC显⽰所有通知信息,VISIBILITY_PRIVATE只显⽰通知标题不显⽰通知内容,VISIBILITY_SECRET不显⽰任何通知信息 channel.setLockscreenVisibility(Notification.VISIBILITY_PRIVATE); // 设置锁屏时候的可见性
channel.setImportance(importance); // 设置通知渠道的重要性级别
}
}
// 在桌⾯上的应⽤图标右上⾓显⽰数字⾓标
public static void showMarkerCount(Context ctx, int count, Notification notify) {
showBadgeOfEMUI(ctx, count); // 华为⼿机EMUI系统的消息⾓标
// ⼩⽶⼿机还要进⼊设置⾥⾯的应⽤管理,开启当前App的“显⽰桌⾯图标⾓标”
showBadgeOfMIUI(count, notify); // ⼩⽶⼿机MIUI系统的消息⾓标
}
// 华为的消息⾓标需要事先声明两个权限:android.permission.INTERNET、com.huawei.android.launcher.permission.CHANGE_BADGE
private static void showBadgeOfEMUI(Context ctx, int count) {
try {
Bundle extra = new Bundle(); // 创建⼀个包裹对象
extra.putString("package", BuildConfig.APPLICATION_ID); // 应⽤的包名
// 应⽤的⾸屏页⾯路径
extra.putString("class", BuildConfig.APPLICATION_ID+".MainActivity");
extra.putInt("badgenumber", count); // 应⽤的消息数量
Uri uri = Uri.parse("content://com.huawei.android.launcher.settings/badge/");
// 通过内容解析器调⽤华为内核的消息⾓标服务
} catch (Exception e) {
e.printStackTrace();
}
}
// ⼩⽶的消息⾓标需要在发送通知的时候⼀块调⽤
private static void showBadgeOfMIUI(int count, Notification notify) {
try {
// 利⽤反射技术获得额外的新增字段extraNotification
Field field = Class().getDeclaredField("extraNotification");
Log.d(TAG, "Name="+Name());
/
/ 该字段为Notification类型,下⾯获取它的实例对象
Object extra = (notify);
Log.d(TAG, "String="+String());
// 利⽤反射技术获得额外的新增⽅法setMessageCount
Method method = Class().getDeclaredMethod("setMessageCount", int.class);
Log.d(TAG, "Name="+Name());
// 利⽤反射技术调⽤实例对象的setMessageCount⽅法,设置消息⾓标的数量
method.invoke(extra, count);
Log.d(TAG, "invoke count="+count);
} catch (Exception e) {
e.printStackTrace();
}
}
}
ample.chapter11;
import android.app.Application;
import android.app.NotificationManager;
import android.os.Build;
import android.util.Log;
ample.chapter11.util.NotifyUtil;
public class MainApplication extends Application {
private final static String TAG = "MainApplication";
@Override
public void onCreate() {
// 这⾥不能屏蔽通知渠道代码,因为后⾯活动会给该渠道发送通知
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
// Android 8.0开始必须给每个通知分配对应的渠道
Log.d(TAG, "onCreate");
}
}
ample.chapter11;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
t.Context;
t.Intent;
import android.os.Build;
import android.os.Bundle;
TextUtils;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.EditText;
import android.widget.Spinner;
import android.widget.Toast;
import androidx.appcompat.app.AppCompatActivity;
ample.chapter11.util.NotifyUtil;
ample.chapter11.util.ViewUtil;
public class NotifyChannelActivity extends AppCompatActivity implements View.OnClickListener {
private EditText et_title;
private EditText et_message;
private String mChannelId = "0"; // 通知渠道的编号
private String mChannelName; // 通知渠道的名称
private int mImportance; // 通知渠道的级别
@Override
protected void onCreate(Bundle savedInstanceState) {
setContentView(R.layout.activity_notify_channel);
et_title = findViewById(_title);
et_message = findViewById(_message);
findViewById(R.id.btn_send_channel).setOnClickListener(this);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
initImportanceSpinner(); // 初始化渠道级别的下拉框
}
}
// 初始化渠道级别的下拉框
private void initImportanceSpinner() {
findViewById(R.id.ll_channel).setVisibility(View.VISIBLE);
ArrayAdapter<String> importanceAdapter = new ArrayAdapter<String>(this,
R.layout.item_select, importanceDescArray);
Spinner sp_importance = findViewById(R.id.sp_importance);
sp_importance.setPrompt("请选择渠道级别");
sp_importance.setAdapter(importanceAdapter);
sp_importance.setSelection(3);
sp_importance.setOnItemSelectedListener(new TypeSelectedListener());
}
private int[] importanceTypeArray = {NotificationManager.IMPORTANCE_NONE,
NotificationManager.IMPORTANCE_MIN,
NotificationManager.IMPORTANCE_LOW,
NotificationManager.IMPORTANCE_DEFAULT,
NotificationManager.IMPORTANCE_HIGH,
NotificationManager.IMPORTANCE_MAX};
private String[] importanceDescArray = {"不重要", // ⽆通知
"最⼩级别", // 通知栏折叠,⽆提⽰声⾳,⽆锁屏通知
"有点重要", // 通知栏展开,⽆提⽰声⾳,有锁屏通知
"⼀般重要", // 通知栏展开,有提⽰声⾳,有锁屏通知
"⾮常重要", // 通知栏展开,有提⽰声⾳,有锁屏通知,在屏幕顶部短暂悬浮(有的⼿机需要在设置页⾯开启横幅) "最⾼级别" // 通知栏展开,有提⽰声⾳,有锁屏通知,在屏幕顶部短暂悬浮(有的⼿机需要在设置页⾯开启横幅) };
class TypeSelectedListener implements AdapterView.OnItemSelectedListener {
public void onItemSelected(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
mImportance = importanceTypeArray[arg2];
mChannelId = "" + arg2;
mChannelName = importanceDescArray[arg2];
}
public void onNothingSelected(AdapterView<?> arg0) {
}
}
// 发送指定渠道的通知消息(包括消息标题和消息内容)
private void sendChannelNotify(String title, String message) {
// 创建⼀个跳转到活动页⾯的意图
Intent clickIntent = new Intent(this, MainActivity.class);
// 创建⼀个⽤于页⾯跳转的延迟意图
PendingIntent contentIntent = Activity(this,
R.string.app_name, clickIntent, PendingIntent.FLAG_UPDATE_CURRENT);
// 创建⼀个通知消息的建造器
Notification.Builder builder = new Notification.Builder(this);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
// Android 8.0开始必须给每个通知分配对应的渠道
builder = new Notification.Builder(this, mChannelId);
}
builder.setContentIntent(contentIntent) // 设置内容的点击意图
.setAutoCancel(true) // 点击通知栏后是否⾃动清除该通知
.setSmallIcon(R.mipmap.ic_launcher) // 设置应⽤名称左边的⼩图标
.setContentTitle(title) // 设置通知栏⾥⾯的标题⽂本
.setContentText(message); // 设置通知栏⾥⾯的内容⽂本
Notification notify = builder.build(); // 根据通知建造器构建⼀个通知对象
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
}
/
/ 从系统服务中获取通知管理器
NotificationManager notifyMgr = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
// 使⽤通知管理器推送通知,然后在⼿机的通知栏就会看到该消息,多条通知需要指定不同的通知编号
if (mImportance != NotificationManager.IMPORTANCE_NONE) {
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论