Android Notification的创建有两种方式,一种是采用默认的Notifiaction布局,一种是自定义布局——通常需要使用RemoteViews来实现。下面主要讲述自定义布局Notification实现:
自定义布局Notification常见的场景是用于播放音乐时,在状态栏上有一些Button,用来控制音乐播放,下面是一个简单Demo,用来演示类似功能。
大致功能是:当点击整个Notification时,会跳转到音乐界面;当点击Button时,弹出Toast,类似与调整音乐播放。
代码:
主界面部分:
package com.natureday;
import android.os.Bundle;
import android.app.Activity;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.util.Log;
import android.view.Menu;
import android.widget.RemoteViews;
import android.widget.Toast;
public class MainActivity extends Activity {
public static final String TAG = "MainActivity";
public static final String CLICK_ACTION = "com.natureday.notification.click";
//用来接收点击Button时产生的广播。
private BroadcastReceiver mReceiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
if (intent.getAction().equals(CLICK_ACTION)) {
Log.i("TAG", "---------Click----------");
Toast.makeText(context, "Ha Ha !!!", Toast.LENGTH_SHORT).show();
}
}
};
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
IntentFilter filter = new IntentFilter();
filter.addAction(CLICK_ACTION);
this.registerReceiver(mReceiver, filter);
// Create RemoteViews Notification.
showRemoteViewNotification();
}
//创建包含Button的自定义布局Notification。
private void showRemoteViewNotification() {
// TODO Auto-generated method stub
RemoteViews views = new RemoteViews(getPackageName(),
R.layout.status_bar);
//这部分主要是对RemoteViews进行相关设定,关于Button的点击响应在这部分完成。
Intent intent = new Intent();
intent = new Intent(this.CLICK_ACTION);
PendingIntent pendingIntent = null;
pendingIntent = PendingIntent.getBroadcast(this,
0 /* no requestCode */, intent, 0 /* no flags */);
//根据不同组件的ID,为其指定不同PendingIntent——也就是当点击某一组件后,会发出不同的广播。
views.setOnClickPendingIntent(R.id.click, pendingIntent);
//这部分内容主要是对整个Notification进行相关设定。
Notification status = new Notification();
status.contentView = views;
status.flags |= Notification.FLAG_ONGOING_EVENT;
status.icon = R.drawable.ic_launcher;
//当点击Notification时会跳转到Music界面。
status.contentIntent = PendingIntent.getActivity(this, 0, new Intent(
"com.android.music.PLAYBACK_VIEWER")
.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK), 0);
NotificationManager manager = (NotificationManager) this
.getSystemService(Context.NOTIFICATION_SERVICE);
manager.notify(0, status);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.activity_main, menu);
return true;
}
@Override
protected void onDestroy() {
// TODO Auto-generated method stub
super.onDestroy();
this.unregisterReceiver(mReceiver);
}
}
自定义布局文件status_bar.xml:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<TextView
android:id="@+id/message"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:text="@string/test_notification"
android:textColor="#fffff000" />
<Button
android:id="@+id/click"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_marginLeft="30dip"
android:layout_toRightOf="@id/message"
android:text="@string/btn_click" />
</RelativeLayout>
结果:演示结果是当点击Notification中的Button时,会弹出Toast,当点击Notification中Button以外的地方会跳转到音乐界面。