上一篇讲述了Notification的基础用法,本篇将介绍,自定义通知栏,并利用讲到的内容,实现一个简单的音乐播发器。

1.自定义通知的实现;

Notification有一个contentView属性,该属性接受的对象是RemoteView对象,用它即可实现自定义布局.

获取RemoteView对象的方法:

<span style="font-size:14px;">RemoteView remoteViews = new RemoteViews(getPackageName(),R.layout.notify_view);</span>

2.添加通知栏响应事件

Intent buttonplayIntent = new Intent("play");PendingIntent pendplayButtonIntent = PendingIntent.getBroadcast(getApplicationContext(), 0, buttonplayIntent, 0);mRemoteViews.setOnClickPendingIntent(R.id.play, pendplayButtonIntent);

其中关于PendingIntent

PendingIntent用于描述Intent及其最终的行为. 
        你可以通过getActivity(Context context, int requestCode, Intent intent, int flags)系列方法从系统取得一个用于启动一个Activity的PendingIntent对象,
       可以通过getService(Context context, int requestCode, Intent intent, int flags)方法从系统取得一个用于启动一个Service的PendingIntent对象

可以通过getBroadcast(Context context, int requestCode, Intent intent, int flags)方法从系统取得一个用于向BroadcastReceiver的Intent广播的PendingIntent对象

返回的PendingIntent可以递交给别的应用程序,然后继续处理。这里的话你可以稍后才处理PendingIntent中描述的Intent及其最终行为。

3.完整的创建自定义通知方法:

Notification mNotification;RemoteViews mRemoteViews;NotificationManager notificationManager;public void createNotifiView() {notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);mNotification = new Notification(R.drawable.ic_launcher, "MusicDemo",System.currentTimeMillis());mNotification.flags |= Notification.FLAG_ONGOING_EVENT;Intent intent = new Intent(Intent.ACTION_MAIN);intent.setClass(getApplicationContext(), MainActivity.class);PendingIntent pendingIntent = PendingIntent.getActivity(getApplicationContext(), 0, intent,PendingIntent.FLAG_CANCEL_CURRENT);mNotification.contentIntent = pendingIntent;if (mRemoteViews == null) {mRemoteViews = new RemoteViews(getPackageName(),R.layout.notify_view);}Intent buttoncloseIntent = new Intent("close");PendingIntent pendcloseButtonIntent = PendingIntent.getBroadcast(getApplicationContext(), 0, buttoncloseIntent, 0);mRemoteViews.setOnClickPendingIntent(R.id.close, pendcloseButtonIntent);Intent buttonplayIntent = new Intent("play");PendingIntent pendplayButtonIntent = PendingIntent.getBroadcast(getApplicationContext(), 0, buttonplayIntent, 0);mRemoteViews.setOnClickPendingIntent(R.id.play, pendplayButtonIntent);//Intent buttonnextIntent = new Intent("next");PendingIntent pendnextButtonIntent = PendingIntent.getBroadcast(getApplicationContext(), 0, buttonnextIntent, 0);mRemoteViews.setOnClickPendingIntent(R.id.next, pendnextButtonIntent);Intent buttonprewtIntent = new Intent("prew");PendingIntent pendprewButtonIntent = PendingIntent.getBroadcast(getApplicationContext(), 0, buttonprewtIntent, 0);mRemoteViews.setOnClickPendingIntent(R.id.prew, pendprewButtonIntent);mRemoteViews.setTextViewText(R.id.songName, "歌曲名");if (!MainActivity.isPlay) {mRemoteViews.setImageViewResource(R.id.play,R.drawable.statusbar_btn_play);mRemoteViews.setOnClickPendingIntent(R.id.play,pendplayButtonIntent);} else {mRemoteViews.setImageViewResource(R.id.play,R.drawable.statusbar_btn_pause);mRemoteViews.setOnClickPendingIntent(R.id.play,pendplayButtonIntent);}mNotification.contentView = mRemoteViews;notificationManager.notify(0, mNotification);}

因为这里用了getBroadCast()获取PendingIntent,所以该Intent是通过发送广播来告知通知栏控件发生了触发事件。

所以,需要在响应界面过滤action,注册响应广播。

先给出通知布局文件notifiy_view:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="wrap_content"android:orientation="vertical"tools:ignore="ContentDescription" ><RelativeLayoutandroid:layout_width="match_parent"android:layout_height="64dp"android:orientation="vertical" ><ImageViewandroid:id="@+id/icon_pic"android:layout_width="60dp"android:layout_height="60dp"android:layout_centerVertical="true" /><ImageButtonandroid:id="@+id/close"android:layout_width="30dp"android:layout_height="30dp"android:layout_alignParentRight="true"android:layout_alignParentTop="true"android:layout_marginRight="10dp"android:layout_marginTop="10dp"android:background="@drawable/status_bg"android:src="@drawable/statusbar_close" /><TextViewandroid:id="@+id/songName"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_marginLeft="10dp"android:layout_marginRight="5dp"android:layout_marginTop="10dp"android:layout_toLeftOf="@+id/close"android:layout_toRightOf="@+id/icon_pic"android:ellipsize="end"android:singleLine="true"android:text="歌名"android:textSize="15dp" /><ImageButtonandroid:id="@+id/prew"android:layout_width="30dp"android:layout_height="30dp"android:layout_alignParentBottom="true"android:layout_centerInParent="true"android:background="@drawable/status_bg"android:src="@drawable/statusbar_btn_prev" /><ImageButtonandroid:id="@+id/play"android:layout_width="30dp"android:layout_height="30dp"android:layout_alignTop="@+id/prew"android:layout_marginLeft="10dp"android:layout_toRightOf="@+id/prew"android:background="@drawable/status_bg"android:src="@drawable/statusbar_btn_play" /><ImageButtonandroid:id="@+id/next"android:layout_width="30dp"android:layout_height="30dp"android:layout_alignTop="@+id/prew"android:layout_marginLeft="10dp"android:layout_toRightOf="@+id/play"android:background="@drawable/status_bg"android:src="@drawable/statusbar_btn_next" /></RelativeLayout></LinearLayout>

我将会把项目放在CSDN上,大家可以下载,获取相应的资源文件

在这个小项目中,我将播放的service做为的是后台服务,然后广播也提出来了,作为一个公用的广播,如果只是做简单播放用,可以将广播放在播放界面。

项目中用到的广播:

public class MusicBroadCast extends BroadcastReceiver {@Overridepublic void onReceive(Context context, Intent intent) {Intent musicServiceIntent = new Intent(context, MusicService.class);if (intent.getAction().equals("play")) {musicServiceIntent.putExtra(MusicService.MusicCommandKey, ""+ MusicService.MusicPlayCommand);context.startService(musicServiceIntent);} else if (intent.getAction().equals("next")) {musicServiceIntent.putExtra(MusicService.MusicCommandKey, ""+ MusicService.MusicNextCommand);context.startService(musicServiceIntent);} else if (intent.getAction().equals("prew")) {musicServiceIntent.putExtra(MusicService.MusicCommandKey, ""+ MusicService.MusicNextCommand);context.startService(musicServiceIntent);} else if (intent.getAction().equals("close")) {musicServiceIntent.putExtra(MusicService.MusicCommandKey, "");context.startService(musicServiceIntent);} else if (intent.getAction().equals("android.media.AUDIO_BECOMING_NOISY")) {// 耳机拔出事件musicServiceIntent.putExtra(MusicService.MusicCommandKey,MusicService.MusicPauseCommand+ MusicService.MusicPauseCommand);context.startService(musicServiceIntent);}}}

我这里是在service注册的广播,这个应该有点夸张了,由于项目需要全局播放,然后由通知栏也可以控制,就这样做了。

service文件代码:

package com.example.musicdemo;import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.app.Service;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.media.AudioManager;
import android.media.MediaPlayer;
import android.os.IBinder;
import android.support.annotation.Nullable;
import android.telephony.PhoneStateListener;
import android.telephony.TelephonyManager;
import android.util.Log;
import android.widget.RemoteViews;import java.io.IOException;/*** Create by gaylen on 2015/12/9 11:07*/public class MusicService extends Service {// 其他对象控制Service进行音频播放操作// 全部采用命令+命令参数的形式处理public static final int MusicInitCommand = 0;public static final int MusicPlayCommand = 10;public static final int MusicStopCommand = 20;public static final int MusicPauseCommand = 30;public static final int MusicSeekToCommand = 40;public static final int MusicNextCommand = 50;public static final int MusicPrevCommand = 60;public static final int MusicNotificationCommand = 70;// 所有的命令参数都String传递// 非String类型,采取转型处理public static String MusicCommandKey = "CtrlCommand";public static String MusicParameterKey = "CommandParameter";private MusicBroadCast broadCast;@Overridepublic void onCreate() {super.onCreate();broadCast = new MusicBroadCast();IntentFilter filter = new IntentFilter();filter.addAction("play");filter.addAction("next");filter.addAction("prew");filter.addAction("close");// 耳机filter.addAction("android.media.AUDIO_BECOMING_NOISY");// 短信// mSystemFilter.addAction("android.provider.Telephony.SMS_RECEIVED");registerReceiver(broadCast, filter);regeisterCallLisenler();/*** 为了防止通知栏点击时出现闪屏,在开启service就将一些对象实例化了*/notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);mNotification = new Notification(R.drawable.ic_launcher, "MusicDemo",System.currentTimeMillis());mNotification.flags |= Notification.FLAG_ONGOING_EVENT;Intent intent = new Intent(Intent.ACTION_MAIN);intent.setClass(getApplicationContext(), MainActivity.class);PendingIntent pendingIntent = PendingIntent.getActivity(getApplicationContext(), 0, intent,PendingIntent.FLAG_CANCEL_CURRENT);mNotification.contentIntent = pendingIntent;}@Nullable@Overridepublic IBinder onBind(Intent intent) {return null;}@Overridepublic int onStartCommand(Intent intent, int flags, int startId) {// 分析传入的命令,根据不同命令调用不同方法String commandValue = intent.getStringExtra(MusicCommandKey);if (commandValue != null) {int command = Integer.parseInt(commandValue);switch (command) {case MusicService.MusicPlayCommand:// 得到play命令对应的参数String Param = intent.getStringExtra(MusicParameterKey);// 执行doPlayCommand方法doPlayCommand(Param);break;case MusicService.MusicStopCommand:stopPlayCommand();break;case MusicService.MusicSeekToCommand:// 解析命令参数执行相关方法// 得到SeekTo的进度(字符串形式)String strProgressSet = intent.getStringExtra(MusicService.MusicParameterKey);doSeekToCommand(strProgressSet);break;case MusicService.MusicNextCommand:doNextCommand();break;case MusicService.MusicPrevCommand:doPreCommand();break;case MusicService.MusicNotificationCommand:createNotifiView();break;}}return super.onStartCommand(intent, flags, startId);}@Overridepublic void onDestroy() {super.onDestroy();// Service 被结束,则音乐停止unregisterReceiver(broadCast);}/*** 停止播放*/private void stopPlayCommand() {Log.i("play", "stop");createNotifiView();}private void doPause() {Log.i("play", "pause");}/*** 播放* * @param param*/private void doPlayCommand(String param) {if (MainActivity.isPlay) {doPause();} else {Log.i("play", "play");}createNotifiView();}// 播放下一首命令处理private void doNextCommand() {Log.i("play", "next");}// 播放上一首命令处理private void doPreCommand() {Log.i("play", "pre");}private void doSeekToCommand(String seekToValue) {int seekTo = Integer.parseInt(seekToValue);// 设置跳转进度// mMediaPlayer.seekTo(seekTo);}Notification mNotification;RemoteViews mRemoteViews;NotificationManager notificationManager;public void createNotifiView() {if (mRemoteViews == null) {mRemoteViews = new RemoteViews(getPackageName(),R.layout.notify_view);}Intent buttoncloseIntent = new Intent("close");PendingIntent pendcloseButtonIntent = PendingIntent.getBroadcast(getApplicationContext(), 0, buttoncloseIntent, 0);mRemoteViews.setOnClickPendingIntent(R.id.close, pendcloseButtonIntent);Intent buttonplayIntent = new Intent("play");PendingIntent pendplayButtonIntent = PendingIntent.getBroadcast(getApplicationContext(), 0, buttonplayIntent, 0);mRemoteViews.setOnClickPendingIntent(R.id.play, pendplayButtonIntent);//Intent buttonnextIntent = new Intent("next");PendingIntent pendnextButtonIntent = PendingIntent.getBroadcast(getApplicationContext(), 0, buttonnextIntent, 0);mRemoteViews.setOnClickPendingIntent(R.id.next, pendnextButtonIntent);Intent buttonprewtIntent = new Intent("prew");PendingIntent pendprewButtonIntent = PendingIntent.getBroadcast(getApplicationContext(), 0, buttonprewtIntent, 0);mRemoteViews.setOnClickPendingIntent(R.id.prew, pendprewButtonIntent);mRemoteViews.setTextViewText(R.id.songName, "歌曲名");if (!MainActivity.isPlay) {mRemoteViews.setImageViewResource(R.id.play,R.drawable.statusbar_btn_play);mRemoteViews.setOnClickPendingIntent(R.id.play,pendplayButtonIntent);} else {mRemoteViews.setImageViewResource(R.id.play,R.drawable.statusbar_btn_pause);mRemoteViews.setOnClickPendingIntent(R.id.play,pendplayButtonIntent);}mNotification.contentView = mRemoteViews;notificationManager.notify(0, mNotification);}private AudioManager mAudioManager;public void regeisterCallLisenler() {mAudioManager = (AudioManager) getSystemService(Context.AUDIO_SERVICE);// 添加来电监听事件TelephonyManager telManager = (TelephonyManager) getSystemService(Context.TELEPHONY_SERVICE); // 获取系统服务telManager.listen(new MobliePhoneStateListener(),PhoneStateListener.LISTEN_CALL_STATE);}/*** @author wwj 电话监听器类*/private class MobliePhoneStateListener extends PhoneStateListener {@Overridepublic void onCallStateChanged(int state, String incomingNumber) {switch (state) {case TelephonyManager.CALL_STATE_IDLE: // 挂机状态// doPlayCommand("");break;case TelephonyManager.CALL_STATE_OFFHOOK: // 通话状态case TelephonyManager.CALL_STATE_RINGING: // 响铃状态Log.i("tag", "接收到来电-->");doPause();break;default:break;}}}
}

最后就是播放主界面:

public class MainActivity extends ActionBarActivity {public static boolean isPlay = false;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);player();}public void player() {Intent musicServiceIntent = new Intent(MainActivity.this,MusicService.class);// 设置播放控制命令:playCommandmusicServiceIntent.putExtra(MusicService.MusicCommandKey, ""+ MusicService.MusicPlayCommand);MainActivity.this.startService(musicServiceIntent);}
}

布局跟通知栏布局差不多,这里就不写了。

完整项目源码可以去:http://download.csdn.net/detail/caihuajian235/9365027下载。

Android之Notification制作多媒体控制器相关推荐

  1. Android 通知栏Notification

    Android 通知栏Notification 在android的应用层中,涉及到很多应用框架,例如:Service框架,Activity管理机制,Broadcast机制,对话框框架,标题栏框架,状态 ...

  2. android开发提示对话框,Android中Notification 提示对话框

    Notification,俗称通知,是一种具有全局效果的通知,它展示在屏幕的顶端,首先会表现为一个图标的形式,当用户向下滑动的时候,展示出通知具体的内容. 一.Notification用于状态栏显示通 ...

  3. android之Notification通知

    我们在用手机的时候,如果来了短信,而我们没有点击查看的话,是不是在手机的最上边的状态栏里有一个短信的小图标提示啊?你是不是也想实现这种功能呢?今天的Notification就是解决这个问题的. pac ...

  4. Android关于notification的在不同API下的用法说明

    当我们在用手机的时候,如果来了短信,而我们没有点击查看的话,是不是在手机的最上边的状态栏里有一个短信的小图标提示啊?你是不是也想实现这种功能呢?今天的Notification就是解决这个问题的. 我们 ...

  5. android语音播放工具类,Android开发之MediaPlayer多媒体(音频,视频)播放工具类

    本文实例讲述了Android开发之MediaPlayer多媒体(音频,视频)播放工具类.分享给大家供大家参考,具体如下: package com.android.imooc.chat; import ...

  6. android自定义抽奖,Android自定义view制作抽奖转盘

    本文实例为大家分享了Android自定义view制作抽奖转盘的具体代码,供大家参考,具体内容如下 效果图 TurntableActivity package com.bawei.myapplicati ...

  7. android activity 被notification启动,Android通知Notification全面剖析

    原标题:Android通知Notification全面剖析 通知 通知是您可以在应用的常规 UI 外部向用户显示的消息.当您告知系统发出通知时,它将先以图标的形式显示在通知区域中.用户可以打开抽屉式通 ...

  8. android led闪烁功能,如何在Android应用层中制作一个LED指示灯效果

    如何在Android应用层中制作一个LED指示灯效果 发布时间:2020-12-08 16:12:59 来源:亿速云 阅读:86 作者:Leah 本篇文章给大家分享的是有关如何在Android应用层中 ...

  9. 利用计算机制作多媒体最后一步,福建省高中会考 多媒体技术应用 选择题专项练习十一(201206)(有答案)...

    多媒体技术应用选择题专项练习十一(201206) 1.下列都属于数字图像采集工具的是( ) A.数码照相机.扫描仪 B.麦克风.扫描仪 C.打印机.数码照相机 D.数码摄像机.打印机 2.下列关于制作 ...

最新文章

  1. mysql 资深dba_MySQL数据库专家分享资深DBA经验
  2. DHCP的安装与分配
  3. opencv_python 读取4通道png图片
  4. Linux—进程管理
  5. 从Tronbull引狂欢,看APENFT与波场带来的新可能
  6. @RequestMapping报404错误问题解决
  7. 【HDU - 1024 】Max Sum Plus Plus (dp及优化,最大m子段和)
  8. B9.流行的框架与新技术
  9. 关于嵌入式可执行程序,你了解多少?
  10. Java程序员月薪三万,需要技术达到什么水平?
  11. 什么是 CD 管道?一文告诉你如何借助 Kubernetes、Ansible 和 Jenkins 创建 CD 管道!...
  12. python删除文件命令_python 删除文件夹
  13. LVS+KeepAlived,RabbitMQ高可用负载均衡
  14. 机器学习重塑供应链管理的10个途径
  15. 容器和泛型 容器重点掌握
  16. 从程序员到项目经理(2)
  17. 界面开发控件DotNetBar for WPF教程:MobileRibbon快速入门指南
  18. 几张趣图助你理解HTTP状态码
  19. UESTC 1636 梦后楼台高锁,酒醒帘幕低垂 最小生成树Kruskal算法的扩展
  20. python登陆pc微信_GitHub - ccboby/WechatPCAPI: 微信PC版的API接口,可通过Python调用微信获取好友、群、公众号列表,并收发消息等功能。...

热门文章

  1. 前端学习(2009)vue之电商管理系统电商系统之渲染商品属性的结构
  2. oracle之数据处理
  3. 第一百一十期:详解SpringBoot应用跨域访问解决方案
  4. spring mvc学习(15)Referenced file contains errors
  5. html:(34):下划线和删除线
  6. html:(30):继承和特殊性
  7. 1.web技术的前世今生
  8. matlab LSTM序列分类的官方示例
  9. asic面试题目 英伟达_免笔试!不限量!全球可编程图形处理技术领袖英伟达2021校园招聘火热进行中!...
  10. JS实现滚动监听以及滑动到顶部