效果图大概如下

这个功能的完成主要是广播和服务的应用

1.首先需要创建一个asset文件夹用来放音乐文件

然后将MP3文件拖入这个文件夹

2.在mainfest里添加一行代码:

<service android:name=".MusicService"></service>

3.布局设置

首先需要一个开始/暂停按钮和停止按钮,因此我们要在网上找到下载这三个图标文件放入drawable文件夹中,布局中在LinearLayout中添加两个ImageButton

然后除了这两个按钮旁边应该还要一行显示歌名和歌手的说明,因此还需要一个LinearLayout并添加两个textview

调整LinearLayout大小、位置、方向,我的代码示例如下

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:orientation="horizontal"android:layout_width="match_parent"android:layout_height="wrap_content"><ImageButtonandroid:id="@+id/play"android:layout_width="wrap_content"android:layout_height="wrap_content"android:src="@drawable/play"/><ImageButtonandroid:id="@+id/stop"android:layout_width="wrap_content"android:layout_height="wrap_content"android:src="@drawable/stop"/><LinearLayoutandroid:orientation="vertical"android:layout_width="match_parent"android:layout_height="match_parent"><TextViewandroid:id="@+id/title"android:layout_width="wrap_content"android:layout_height="wrap_content"android:textSize="25sp"android:textColor="#9C27B0"android:ellipsize="marquee"android:layout_weight="1"android:marqueeRepeatLimit="marquee_forever"/><TextViewandroid:id="@+id/author"android:textSize="25sp"android:gravity="center_vertical"android:layout_weight="1"android:layout_width="wrap_content"android:layout_height="wrap_content"/></LinearLayout>
</LinearLayout>

再写MainActivity和MusicService
MainActivity设置可以点击按钮,不同状态下按钮图标的切换,代码如下

package com.example.mymusicbox;import android.app.Activity;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.ImageButton;
import android.widget.TextView;public class MainActivity extends Activity implements OnClickListener
{// 获取界面中显示歌曲标题、作者文本框TextView title, author;// 播放/暂停、停止按钮ImageButton play, stop;ActivityReceiver activityReceiver;public static final String CTL_ACTION ="org.xr.action.CTL_ACTION";public static final String UPDATE_ACTION ="org.xr.action.UPDATE_ACTION";// 定义音乐的播放状态,0x11代表没有播放;0x12代表正在播放;0x13代表暂停int status = 0x11;String[] titleStrs = new String[] { "BeautifulGirl", "我的一个道姑朋友", "牛奶面包" };String[] authorStrs = new String[] { "HAHA & Skull", "双笙", "杨紫" };@Overridepublic void onCreate(Bundle savedInstanceState){super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);// 获取程序界面界面中的两个按钮play = (ImageButton) this.findViewById(R.id.play);stop = (ImageButton) this.findViewById(R.id.stop);title = (TextView) findViewById(R.id.title);author = (TextView) findViewById(R.id.author);// 为两个按钮的单击事件添加监听器play.setOnClickListener(this);stop.setOnClickListener(this);activityReceiver = new ActivityReceiver();// 创建IntentFilterIntentFilter filter = new IntentFilter();// 指定BroadcastReceiver监听的Actionfilter.addAction(UPDATE_ACTION);// 注册BroadcastReceiverregisterReceiver(activityReceiver, filter);Intent intent = new Intent(this, MusicService.class);// 启动后台ServicestartService(intent);}// 自定义的BroadcastReceiver,负责监听从Service传回来的广播public class ActivityReceiver extends BroadcastReceiver{@Overridepublic void onReceive(Context context, Intent intent){// 获取Intent中的update消息,update代表播放状态int update = intent.getIntExtra("update", -1);// 获取Intent中的current消息,current代表当前正在播放的歌曲int current = intent.getIntExtra("current", -1);if (current >= 0){title.setText(titleStrs[current]);author.setText(authorStrs[current]);}switch (update){case 0x11:play.setImageResource(R.drawable.play);status = 0x11;break;// 控制系统进入播放状态case 0x12:// 播放状态下设置使用暂停图标play.setImageResource(R.drawable.pause);// 设置当前状态status = 0x12;break;// 控制系统进入暂停状态case 0x13:// 暂停状态下设置使用播放图标play.setImageResource(R.drawable.play);// 设置当前状态status = 0x13;break;}}}@Overridepublic void onClick(View source){// 创建IntentIntent intent = new Intent("org.xr.action.CTL_ACTION");switch (source.getId()){// 按下播放/暂停按钮case R.id.play:intent.putExtra("control", 1);break;// 按下停止按钮case R.id.stop:intent.putExtra("control", 2);break;}// 发送广播,将被Service组件中的BroadcastReceiver接收到sendBroadcast(intent);}
}

MusicService

package com.example.mymusicbox;import java.io.IOException;import android.app.Service;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.content.res.AssetFileDescriptor;
import android.content.res.AssetManager;
import android.media.MediaPlayer;
import android.media.MediaPlayer.OnCompletionListener;
import android.os.IBinder;public class MusicService extends Service
{MyReceiver serviceReceiver;AssetManager am;String[] musics = new String[] { "BeautifulGirl.mp3", "我的一个道姑朋友.mp3","牛奶面包.mp3" };MediaPlayer mPlayer;// 当前的状态,0x11代表没有播放;0x12代表正在播放;0x13代表暂停int status = 0x11;// 记录当前正在播放的音乐int current = 0;@Overridepublic IBinder onBind(Intent intent){return null;}@Overridepublic void onCreate(){super.onCreate();am = getAssets();// 创建BroadcastReceiverserviceReceiver = new MyReceiver();// 创建IntentFilterIntentFilter filter = new IntentFilter();filter.addAction(MainActivity.CTL_ACTION);registerReceiver(serviceReceiver, filter);// 创建MediaPlayermPlayer = new MediaPlayer();// 为MediaPlayer播放完成事件绑定监听器mPlayer.setOnCompletionListener(new OnCompletionListener() // ①{@Overridepublic void onCompletion(MediaPlayer mp){current++;if (current >= 3){current = 0;}//发送广播通知Activity更改文本框Intent sendIntent = new Intent(MainActivity.UPDATE_ACTION);sendIntent.putExtra("current", current);// 发送广播,将被Activity组件中的BroadcastReceiver接收到sendBroadcast(sendIntent);// 准备并播放音乐prepareAndPlay(musics[current]);}});}public class MyReceiver extends BroadcastReceiver{@Overridepublic void onReceive(final Context context, Intent intent){int control = intent.getIntExtra("control", -1);switch (control){// 播放或暂停case 1:// 原来处于没有播放状态if (status == 0x11){// 准备并播放音乐prepareAndPlay(musics[current]);status = 0x12;}// 原来处于播放状态else if (status == 0x12){// 暂停mPlayer.pause();// 改变为暂停状态status = 0x13;}// 原来处于暂停状态else if (status == 0x13){// 播放mPlayer.start();// 改变状态status = 0x12;}break;// 停止声音case 2:// 如果原来正在播放或暂停if (status == 0x12 || status == 0x13){// 停止播放mPlayer.stop();status = 0x11;}}// 广播通知Activity更改图标、文本框Intent sendIntent = new Intent(MainActivity.UPDATE_ACTION);sendIntent.putExtra("update", status);sendIntent.putExtra("current", current);// 发送广播,将被Activity组件中的BroadcastReceiver接收到sendBroadcast(sendIntent);}}private void prepareAndPlay(String music){try{// 打开指定音乐文件AssetFileDescriptor afd = am.openFd(music);mPlayer.reset();// 使用MediaPlayer加载指定的声音文件。mPlayer.setDataSource(afd.getFileDescriptor(),afd.getStartOffset(), afd.getLength());// 准备声音mPlayer.prepare();// 播放mPlayer.start();}catch (IOException e){e.printStackTrace();}}
}

至此,我们就制作了可以播放、暂停和停止音乐的功能了,但是还需要添加可以播放上一首和下一首的按钮

我们需要在AndroidManifest在加两行代码,修改后的代码如下:

        <serviceandroid:name=".MusicService"android:enabled="true"android:exported="true"></service>

在布局文件中增加两个Button
增加的代码部分如下:

   <Buttonandroid:id="@+id/btnptrack"android:layout_width="73dp"android:layout_height="match_parent"android:text="上一首" />
    <Buttonandroid:id="@+id/btnntrack"android:layout_width="wrap_content"android:layout_height="match_parent"android:text="下一首" />

在MusicService中onReceive函数添加上一首和下一首的功能事件

  // 上一首case 3:if (status == 0x12 ||status == 0x13){current = ((current - 1)+ musics.length) % musics.length;prepareAndPlay(musics[current]);status = 0x12;}break;// 下一首case 4:if (status == 0x12 ||status == 0x13){current = (current + 1) % musics.length;prepareAndPlay(musics[current]);status = 0x12;}break;}

最后在MainActivity中调用新增的功能即可

public class MainActivity extends Activity implements OnClickListener
{// 获取界面中显示歌曲标题、作者文本框TextView title, author;// 播放/暂停、停止按钮ImageButton play, stop;//以下为新增 //上一首/下一首的Button ptrack,ntrack;
  // 获取程序界面界面中的两个按钮play = (ImageButton) this.findViewById(R.id.play);stop = (ImageButton) this.findViewById(R.id.stop);title = (TextView) findViewById(R.id.title);author = (TextView) findViewById(R.id.author);//以下为新增ptrack = (Button) findViewById(R.id.btnptrack);ntrack = (Button) findViewById(R.id.btnntrack);// 为两个按钮的单击事件添加监听器play.setOnClickListener(this);stop.setOnClickListener(this);//以下为新增ptrack.setOnClickListener(this);ntrack.setOnClickListener(this);
 switch (source.getId()){// 按下播放/暂停按钮case R.id.play:intent.putExtra("control", 1);break;// 按下停止按钮case R.id.stop:intent.putExtra("control", 2);break;//以下为新增// 按下 上一首case R.id.btnptrack:intent.putExtra("control",3);break;// 按下 下一首case R.id.btnntrack:intent.putExtra("control",4);break;}

源码已上传: 链接.

Android Studio学习之制作音乐盒相关推荐

  1. Android Studio --- [学习笔记]RadioButton、CheckBox、ImageView、ListView、TCP的三次握手

    说明 源代码 在2.x里有TCP的三次挥手与四次握手,先对它进行简单的回答(百度).预计在下一篇里,会继续说明TCP 接上一篇: Android Studio - > [学习笔记]Button. ...

  2. 【Android Studio学习】第二篇、APP实现画简易的波形图

    目录 第一部分.前言 1.效果展示 2.参考博客 3.实现方式 第二部分.详细步骤 1.添加波形函数的依赖 2.添加一个管理类 3.修改activity_main.xml文件的代码 4.修改MainA ...

  3. Android Studio --- [学习笔记]TCP(第2弹)、GridView、ScrollView

    说明 这篇主要接上一篇Android Studio - > [学习笔记]RadioButton.CheckBox.ImageView.ListView.TCP的三次握手 对上面回答的细解,并用J ...

  4. Android Studio 学习实例记录-手电筒

    Android Studio 学习实例记录-手电筒 刚安装好Android Studio3.1.2,上网搜了一个实例进行实践学习,仅用这篇文章来记录学习过程 MainActivity.java的源码来 ...

  5. 安卓开发Android studio学习笔记12:读取解析XML(案例演示)

    Android studio学习笔记 第一步:配置Student.XML 第二步:配置activity_main.xml 第三步:配置student.xml 第四步:配置Student用户类 第五步: ...

  6. Android Studio之菜单栏制作

    Android Studio之菜单栏制作 静态菜单栏XML文件准备工作 一.准备好布局首页展示页面XML文件 该布局文件适应于三种菜单栏. 此处说明一下菜单栏的种类:选项菜单(也称三点菜单键).上下文 ...

  7. android studio gradle 添加jar,android studio学习----通过gradle来导入jar包

    转载地址:http://www.th7.cn/Program/Android/201507/495477.shtml File->Project Structure 可以打开下面的图: 1.通过 ...

  8. Android Studio学习记录之简单的页面切换及宫格菜单

    Android Studio学习记录之简单的页面切换及宫格菜单 之前上课听老师讲的一些东西自己其实并没有消化,今天把不懂的都去网上搜了一下,有了一种恍然大悟的感觉,包括很多方方面面的东西.有些东西听说 ...

  9. 深度学习(六)——CNN识别典型地标建筑,并制作pb文件,部署在android studio端,制作app实现该功能

    一.背景 两年前的一个项目,识别典型地标,并对图片进行标记.这里只写一下简单思路,最开始是打算用特征点匹配来做的,可以参考:基于特征点匹配方法--SIFT, SURF, ORB的图像识别 ,后来发现效 ...

最新文章

  1. 关于技术方案与架构宣讲的思考
  2. unzipped list
  3. 鸿蒙系统的升级名单,定档6月2日!鸿蒙“首批”升级名单公布,共计11款华为机型!...
  4. python教程-4.数据处理numpy-pandas
  5. 冷知识,PCB工程师的等级之分
  6. java创建线程的5种方法
  7. java中文转换为拼音的pinyin4j学习笔记
  8. 屌炸天,像写代码一样写PPT,reveal-md 详解
  9. css:clac计算
  10. 029:vue+openlayers:使用MVT格式读取瓦片数据(示例代码)
  11. 中间件系列——EMQX 的集群搭建
  12. MPAndroidchart自定义样式二在柱状图上显示文本和间断式显示柱状图
  13. python模拟登录12306_python模拟登录12306缺少cookies
  14. SYN包TCP选项的设置
  15. Nginx的优化和压力测试
  16. web课程设计网页规划与设计----公司官网带轮播图 (页面精美 1页)
  17. EasyDl快速上手教程
  18. 网易企业邮箱日程管理
  19. Hystrix 1.5 滑动窗口实现原理总结
  20. Service的onUnbind方法不执行的问题

热门文章

  1. lua中的sort排序
  2. 华为三层交换机VLAN配置
  3. string append方法
  4. WPF实现聚光灯查看内容特效
  5. python鸭子类型_你知道什么是Python里的鸭子类型和猴子补丁吗?
  6. 定时自动远程备份服务器数据
  7. Github 如何删除项目
  8. ubuntu 删除文件和文件夹的命令— rm
  9. JQuery定时器(jQuery Timers)
  10. 鼠标事件:onclick、onmousedown、onmouseup、onmouseover、onmouseout、onmouseenter、onmouseleave、鼠标的按键、 div简单拖拽