在消息通知时,我们经常用到两个组件Toast和Notification。特别是重要的和需要长时间显示的信息,用Notification就最 合适不过了。当有消息通知时,状态栏会显示通知的图标和文字,通过下拉状态栏,就可以看到通知信息了,Android这一创新性的UI组件赢得了用户的一 致好评,就连苹果也开始模仿了。今天我们就结合实例,探讨一下Notification具体的使用方法。  首先说明一下我们需要实现的功能是:在程序启动时,发出一个通知,这个通知在软件运行过程中一直存在,相当于qq的托盘一样。

然后再演示一下普通的通知和自定义视图通知, 那我们就先建立一个安卓项目。

然后编辑/res/layout/main.xml文件,代码如下:

xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@android:color/black"
android:orientation="vertical" >
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_horizontal"
android:text="@string/title"
android:textColor="#0f0"
android:textSize="20sp"
android:textStyle="bold" />
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="50dp"
android:layout_marginRight="50dp"
android:layout_marginTop="30dp"
android:onClick="normal"
android:text="@string/notification"
android:textColor="#0f0"
android:textSize="20sp" />
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="50dp"
android:layout_marginRight="50dp"
android:layout_marginTop="30dp"
android:onClick="custom"
android:text="@string/custom"
android:textColor="#0f0"
android:textSize="20sp" />

上面的布局很简单,有两个按钮分别用于启动普通的notification和自定义的notification。

接下来自定义一个布局用于显示自定义的通知的。

android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#000"
android:orientation="vertical" >
android:id="@+id/iv"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:contentDescription="@string/action_settings"
android:src="@drawable/ic_launcher" />
android:id="@+id/tv"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_horizontal"
android:textColor="#0f0"
android:textSize="15sp" />

接下来就是上代码。

package com.itfom.notification;
import android.app.Activity;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.os.Environment;
import android.view.View;
import android.widget.RemoteViews;
public class MainActivity extends Activity {
private NotificationManager mNotificationManager;
private Context context;
private Notification notification;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
//普通的通知
@SuppressWarnings("deprecation")
public void normal(View v){
//创建通知
createNotification("普通的通知");
//把通知放在正在运行栏目中
notification.flags|=Notification.FLAG_ONGOING_EVENT;
//设定默认声音
notification.defaults|=Notification.DEFAULT_SOUND;
//设定默认震动
notification.defaults|=Notification.DEFAULT_VIBRATE;
//设定默认LED灯提醒
notification.defaults|=Notification.DEFAULT_LIGHTS;
//设置点击后通知自动清除
notification.defaults|=Notification.FLAG_AUTO_CANCEL;
String textTitle="Notification示例";
String textContent="程序正在运行,点击此处跳转到演示界面";
Intent it=new Intent(context, MainActivity.class);
PendingIntent pendintent=PendingIntent.getActivity(context, 0, it, 0);
notification.setLatestEventInfo(context, textTitle, textContent, pendintent);
mNotificationManager.notify(0, notification);
}
//自定义的通知
public void custom(View v){
//创建通知
createNotification("个性化的通知");
//自定义通知的声音
notification.sound=Uri.parse(Environment.getExternalStorageDirectory()+"/non.mp3");
//自定义震动参数分别为多长时间开始震动、第一次震动的时间、停止震动的时间
long[] vibrate={0,100,200,300};
notification.vibrate=vibrate;
//自定义闪光灯的方式
notification.ledARGB=0xff00ff00;
notification.ledOnMS=500;
notification.ledOffMS=500;
notification.flags|=Notification.FLAG_SHOW_LIGHTS;
RemoteViews contentView=new RemoteViews(this.getPackageName(),R.layout.notify);
contentView.setTextViewText(R.id.tv, "这是个性化的通知");
//指定个性化的视图
notification.contentView=contentView;
Intent it=new Intent(context, MainActivity.class);
PendingIntent pendintent=PendingIntent.getActivity(context, 0, it, 0);
//指定内容视图
notification.contentIntent=pendintent;
mNotificationManager.notify(1, notification);
}
//自定义一个方法创建通知
@SuppressWarnings("deprecation")
public Notification createNotification(String text){
context = this;
mNotificationManager=(NotificationManager) this.getSystemService(Context.NOTIFICATION_SERVICE);
int icon=R.drawable.ic_launcher;
long when=System.currentTimeMillis();
return notification = new Notification(icon, text, when);
}
//重写onBackpressed事件
@Override
public void onBackPressed() {
super.onBackPressed();
finish();
//取消通知
mNotificationManager.cancel(0);
android.os.Process.killProcess(android.os.Process.myPid());
System.exit(0);
}
}

上面的代码我们定义了一个方法createNotification(String text).该方法是用于创建一个通知。注意之所以这样写是因为。不管是普通的通知还是自定义的通知。前面的创建过程都是一样的。然后我们实现了两个按钮的点击事件。

运行结果如下所示:

android检测用户操作 android auto 检查设备消息_自定义

当点击两个按钮时会出现以下的情况:

android检测用户操作 android auto 检查设备消息_自定义_02

注 :这里是有声音效果的。如果手机支持闪光,还有LED效果。

以上就是关于Android中Notification通知提醒实现的过程详解,最近更新了许多关于Android中Notification通知提醒的文章,希望对大家的学习有所帮助。