安卓java音乐播放器下一曲_Android应用开发--MP3音乐播放器代码实现(一)

本文主要是介绍安卓java音乐播放器下一曲_Android应用开发--MP3音乐播放器代码实现(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

需求1:将内存卡中的MP3音乐读取出来并显示到列表当中

1.   从数据库中查询所有音乐数据,保存到List集合当中,List当中存放的是Mp3Info对象

2.   迭代List集合,把每一个Mp3Info对象的所有属性,保存到Map对象当中

3.   定义一个List集合,把Map对象添加到List集合当中

4.   通过定义一个SimpleAdpter,调用setAdpter方法,将数据显示到列表当中

/**

* 用于从数据库中查询歌曲的信息,保存在List当中

*

* @return

*/

public List getMp3Infos() {

Cursor cursor = getContentResolver().query(

MediaStore.Audio.Media.EXTERNAL_CONTENT_URI, null, null, null,

MediaStore.Audio.Media.DEFAULT_SORT_ORDER);

List mp3Infos = new ArrayList();

for (int i = 0; i 

Mp3Info mp3Info = new Mp3Info();

cursor.moveToNext();

long id = cursor.getLong(cursor

.getColumnIndex(MediaStore.Audio.Media._ID));   //音乐id

String title = cursor.getString((cursor

.getColumnIndex(MediaStore.Audio.Media.TITLE)));//音乐标题

String artist = cursor.getString(cursor

.getColumnIndex(MediaStore.Audio.Media.ARTIST));//艺术家

long duration = cursor.getLong(cursor

.getColumnIndex(MediaStore.Audio.Media.DURATION));//时长

long size = cursor.getLong(cursor

.getColumnIndex(MediaStore.Audio.Media.SIZE));  //文件大小

String url = cursor.getString(cursor

.getColumnIndex(MediaStore.Audio.Media.DATA));              //文件路径

int isMusic = cursor.getInt(cursor

.getColumnIndex(MediaStore.Audio.Media.IS_MUSIC));//是否为音乐

if (isMusic != 0) {     //只把音乐添加到集合当中

mp3Info.setId(id);

mp3Info.setTitle(title);

mp3Info.setArtist(artist);

mp3Info.setDuration(duration);

mp3Info.setSize(size);

mp3Info.setUrl(url);

mp3Infos.add(mp3Info);

}

}

return mp3Infos;

}

/**

* 填充列表

* @param mp3Infos

*/

public void setListAdpter(List mp3Infos) {

List> mp3list = new ArrayList>();

for (Iterator iterator = mp3Infos.iterator(); iterator.hasNext();) {

Mp3Info mp3Info = (Mp3Info) iterator.next();

HashMap map = new HashMap();

map.put("title", mp3Info.getTitle());

map.put("Artist", mp3Info.getArtist());

map.put("duration", String.valueOf(mp3Info.getDuration()));

map.put("size", String.valueOf(mp3Info.getSize()));

map.put("url", mp3Info.getUrl());

mp3list.add(map);

}

mAdapter = new SimpleAdapter(this, mp3list,

R.layout.music_list_item_layout, new String[] { "title", "Artist", "duration" },

new int[] { R.id.music_title, R.id.music_Artist, R.id.music_duration });

mMusiclist.setAdapter(mAdapter);

}

实现效果如图:

0fdbd67b036183f0dfed792cda68353b.png

需求2:点击列表的每一项,启动一个服务来播放音乐

1.   注册条目点击监听器OnItemClickListener

2.   定义一个实现OnItemClickListener接口的内部类

3.   定义一个继承Service的服务类PlayerServie

1.   注册条目点击监听器OnItemClickListener

mMusiclist = (ListView) findViewById(R.id.music_list);

mMusiclist.setOnItemClickListener(new MusicListItemClickListener());

mp3Infos = getMp3Infos();

setListAdpter(getMp3Infos());

2.   定义一个实现OnItemClickListener接口的内部类

private class MusicListItemClickListener implements OnItemClickListener {

@Override

public void onItemClick(AdapterView> parent, View view, int position,

long id) {

if(mp3Infos != null) {

Mp3Info mp3Info = mp3Infos.get(position);

Log.d("mp3Info-->", mp3Info.toString());

Intent intent = new Intent();

intent.putExtra("url", mp3Info.getUrl());

intent.putExtra("MSG", AppConstant.PlayerMsg.PLAY_MSG);

intent.setClass(MainActivity.this, PlayerService.class);

startService(intent);       //启动服务

}

}

}

3.   定义一个继承Service的服务类PlayerServie(未完善的Service类)

package com.wwj.sb.service;

import android.annotation.SuppressLint;

import android.app.Service;

import android.content.Intent;

import android.media.MediaPlayer;

import android.media.MediaPlayer.OnPreparedListener;

import android.os.IBinder;

import com.wwj.sb.domain.AppConstant;

@SuppressLint("NewApi")

public class PlayerService extends Service {

private MediaPlayer mediaPlayer =  new MediaPlayer();       //媒体播放器对象

private String path;                        //音乐文件路径

private boolean isPause;                    //暂停状态

@Override

public IBinder onBind(Intent arg0) {

return null;

}

@Override

public int onStartCommand(Intent intent, int flags, int startId) {

if(mediaPlayer.isPlaying()) {

stop();

}

path = intent.getStringExtra("url");

int msg = intent.getIntExtra("MSG", 0);

if(msg == AppConstant.PlayerMsg.PLAY_MSG) {

play(0);

} else if(msg == AppConstant.PlayerMsg.PAUSE_MSG) {

pause();

} else if(msg == AppConstant.PlayerMsg.STOP_MSG) {

stop();

}

return super.onStartCommand(intent, flags, startId);

}

/**

* 播放音乐

* @param position

*/

private void play(int position) {

try {

mediaPlayer.reset();//把各项参数恢复到初始状态

mediaPlayer.setDataSource(path);

mediaPlayer.prepare();  //进行缓冲

mediaPlayer.setOnPreparedListener(new PreparedListener(position));//注册一个监听器

}

catch (Exception e) {

e.printStackTrace();

}

}

/**

* 暂停音乐

*/

private void pause() {

if (mediaPlayer != null && mediaPlayer.isPlaying()) {

mediaPlayer.pause();

isPause = true;

}

}

/**

* 停止音乐

*/

private void stop(){

if(mediaPlayer != null) {

mediaPlayer.stop();

try {

mediaPlayer.prepare(); // 在调用stop后如果需要再次通过start进行播放,需要之前调用prepare函数

} catch (Exception e) {

e.printStackTrace();

}

}

}

@Override

public void onDestroy() {

if(mediaPlayer != null){

mediaPlayer.stop();

mediaPlayer.release();

}

}

/**

*

* 实现一个OnPrepareLister接口,当音乐准备好的时候开始播放

*

*/

private final class PreparedListener implements OnPreparedListener {

private int positon;

public PreparedListener(int positon) {

this.positon = positon;

}

@Override

public void onPrepared(MediaPlayer mp) {

mediaPlayer.start();    //开始播放

if(positon > 0) {    //如果音乐不是从头播放

mediaPlayer.seekTo(positon);

}

}

}

}

public class MusicActivity extends Activity {

private boolean isStop = false;

private MediaPlayer mPlayer;

public final String TITLE = Environment.getExternalStorageDirectory()

+ "/iwantyourlove.mp3";

private File file;

private SeekBar seekBar;

private ImageView play;

private TextView title;

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.music_main);

initWidgets();

}

// 重新初始化播放器

public void initWidgets() {

play = (ImageView) findViewById(R.id.img_stop);

title = (TextView) findViewById(R.id.title);

seekBar = (SeekBar) findViewById(R.id.seek);

seekBar.setOnSeekBarChangeListener(new OnSeekBarChangeListener() {

@Override

public void onStopTrackingTouch(SeekBar seekBar) {

//seekBar.setProgress(mPlayer.getCurrentPosition() *seekBar.getMax() / total);

//Log.i("sss", seekBar.getProgress()+"");

//mPlayer.seekTo(mPlayer.getCurrentPosition());

mPlayer.seekTo(seekBar.getProgress() * mPlayer.getDuration() /100 );

}

@Override

public void onStartTrackingTouch(SeekBar seekBar) {

}

@Override

public void onProgressChanged(SeekBar seekBar, int progress,

boolean fromUser) {

//Log.i("progress", ""+progress);

//Log.i("qqq", seekBar.getProgress()+"");

//progress = currentPosition * 100 / duration;

//progress*duration/100

//mPlayer.seekTo(progress * mPlayer.getDuration() /100 );

}

});

file = new File(TITLE);

title.setText(file.getName());

mPlayer = new MediaPlayer();

try {

mPlayer.setDataSource(TITLE);

mPlayer.prepare();

} catch (Exception e) {

e.printStackTrace();

}

}

public void play(View v) {

if (!mPlayer.isPlaying()) {

mPlayer.start();

}

}

public void pause(View v) {

if (mPlayer.isPlaying()) {

mPlayer.pause();

}

}

public void replay(View v) {

mPlayer.reset();

initWidgets();// 重新构建播放器

// mPlayer.start();

play(v);

}

public void stop(View v) {

isStop = true;

mPlayer.stop();

play.setImageResource(R.drawable.player_play);

}

// 用图片代替按钮

public void playOrPause(View v) {

if (isStop) {// 停止后重新开始播放

mPlayer.reset();

initWidgets();

mPlayer.start();

play.setImageResource(R.drawable.player_pause);

isStop = false;

} else if (mPlayer.isPlaying()) {// 播放状态

play.setImageResource(R.drawable.player_play);

mPlayer.pause();

} else {// 暂停状态

play.setImageResource(R.drawable.player_pause);

mPlayer.start();

}

// 异步任务

new MusicTask().execute();

}

@Override

protected void onDestroy() {

super.onDestroy();

// 释放资源

mPlayer.release();

}

// 音乐播放异步任务

class MusicTask extends AsyncTask {

//int current = mPlayer.getCurrentPosition();// 当前播放是什么位置,

int total = mPlayer.getDuration(); // 音乐总共多长时间

@Override

protected Void doInBackground(Void... params) {

// 让SeekBar跟着音乐一起向右边走

while (mPlayer.getCurrentPosition() <= total&&!isStop) {//!isPause不是停止状态

try {

Thread.sleep(1000);

} catch (InterruptedException e) {

e.printStackTrace();

}

publishProgress();

}

return null;

}

@Override

protected void onProgressUpdate(Void... values) {

super.onProgressUpdate(values);

//Log.i("msg", ""+mPlayer.getCurrentPosition() * 100 / total);

seekBar.setProgress(mPlayer.getCurrentPosition() *seekBar.getMax() / total);

}

@Override

protected void onPostExecute(Void result) {

super.onPostExecute(result);

}

}

}

这篇关于安卓java音乐播放器下一曲_Android应用开发--MP3音乐播放器代码实现(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/314338

相关文章

Qt实现对Word网页的读取功能

《Qt实现对Word网页的读取功能》文章介绍了几种在Qt中实现Word文档(.docx/.doc)读写功能的方法,包括基于QAxObject的COM接口调用、DOCX模板替换及跨平台解决方案,重点讨论... 目录1. 核心实现方式2. 基于QAxObject的COM接口调用(Windows专用)2.1 环境

MySQL查看表的历史SQL的几种实现方法

《MySQL查看表的历史SQL的几种实现方法》:本文主要介绍多种查看MySQL表历史SQL的方法,包括通用查询日志、慢查询日志、performance_schema、binlog、第三方工具等,并... 目录mysql 查看某张表的历史SQL1.查看MySQL通用查询日志(需提前开启)2.查看慢查询日志3.

Java实现字符串大小写转换的常用方法

《Java实现字符串大小写转换的常用方法》在Java中,字符串大小写转换是文本处理的核心操作之一,Java提供了多种灵活的方式来实现大小写转换,适用于不同场景和需求,本文将全面解析大小写转换的各种方法... 目录前言核心转换方法1.String类的基础方法2. 考虑区域设置的转换3. 字符级别的转换高级转换

使用Python实现局域网远程监控电脑屏幕的方法

《使用Python实现局域网远程监控电脑屏幕的方法》文章介绍了两种使用Python在局域网内实现远程监控电脑屏幕的方法,方法一使用mss和socket,方法二使用PyAutoGUI和Flask,每种方... 目录方法一:使用mss和socket实现屏幕共享服务端(被监控端)客户端(监控端)方法二:使用PyA

HTML5的input标签的`type`属性值详解和代码示例

《HTML5的input标签的`type`属性值详解和代码示例》HTML5的`input`标签提供了多种`type`属性值,用于创建不同类型的输入控件,满足用户输入的多样化需求,从文本输入、密码输入、... 目录一、引言二、文本类输入类型2.1 text2.2 password2.3 textarea(严格

Agent开发核心技术解析以及现代Agent架构设计

《Agent开发核心技术解析以及现代Agent架构设计》在人工智能领域,Agent并非一个全新的概念,但在大模型时代,它被赋予了全新的生命力,简单来说,Agent是一个能够自主感知环境、理解任务、制定... 目录一、回归本源:到底什么是Agent?二、核心链路拆解:Agent的"大脑"与"四肢"1. 规划模

MyBatis-Plus逻辑删除实现过程

《MyBatis-Plus逻辑删除实现过程》本文介绍了MyBatis-Plus如何实现逻辑删除功能,包括自动填充字段、配置与实现步骤、常见应用场景,并展示了如何使用remove方法进行逻辑删除,逻辑删... 目录1. 逻辑删除的必要性编程1.1 逻辑删除的定义1.2 逻辑删php除的优点1.3 适用场景2.

SpringBoot简单整合ElasticSearch实践

《SpringBoot简单整合ElasticSearch实践》Elasticsearch支持结构化和非结构化数据检索,通过索引创建和倒排索引文档,提高搜索效率,它基于Lucene封装,分为索引库、类型... 目录一:ElasticSearch支持对结构化和非结构化的数据进行检索二:ES的核心概念Index:

C#借助Spire.XLS for .NET实现在Excel中添加文档属性

《C#借助Spire.XLSfor.NET实现在Excel中添加文档属性》在日常的数据处理和项目管理中,Excel文档扮演着举足轻重的角色,本文将深入探讨如何在C#中借助强大的第三方库Spire.... 目录为什么需要程序化添加Excel文档属性使用Spire.XLS for .NET库实现文档属性管理Sp

Python+FFmpeg实现视频自动化处理的完整指南

《Python+FFmpeg实现视频自动化处理的完整指南》本文总结了一套在Python中使用subprocess.run调用FFmpeg进行视频自动化处理的解决方案,涵盖了跨平台硬件加速、中间素材处理... 目录一、 跨平台硬件加速:统一接口设计1. 核心映射逻辑2. python 实现代码二、 中间素材处