全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Android利用SeekBar实现简单音乐播放器

一.Demo简介 

利用AIDL为Activity绑定服务,利用Handler机制,发送消息更新SeekBar的UI,利用计时器定时更新SeekBar的进度。实现对音乐的开始播放,到暂停,继续,以及停止播放的功能。以及实现拖动进度条播放音乐的功能。 

二.AIDL接口 

利用AIDL机制提供给MainActivity访问MyMusicService的方法,实现播放暂停等功能。

三.主要类代码

1.MyMusicService 

package my.com.mymusicp;

import android.app.Service;
import android.content.Intent;
import android.media.MediaPlayer;
import android.os.Bundle;
import android.os.IBinder;
import android.os.Message;
import android.os.RemoteException;
import android.support.annotation.Nullable;
import android.util.Log;

import java.io.IOException;
import java.util.Timer;
import java.util.TimerTask;

/**
 * Created by c_ljf on 16-12-26.
 */
public class MyMusicService extends Service {
  private String tag="MyMusicService";
  private MediaPlayer mediaPlayer;

  @Override
  public void onCreate() {
    super.onCreate();
    mediaPlayer = new MediaPlayer();
  }

  @Nullable
  @Override
  public IBinder onBind(Intent intent) {
    return new MyMusicBinder();
  }
  class MyMusicBinder extends IMyMusicService.Stub{

    @Override
    public void play() throws RemoteException {
      playmusic();
    }

    @Override
    public void pause() throws RemoteException {
     pausemusic();
    }

    @Override
    public void stop() throws RemoteException {
      stopmusic();
    }

    @Override
    public void continuePlay() throws RemoteException {
      rePlayMusic();
    }

    @Override
    public void seekPlayProgress(int position) throws RemoteException {
      seekPlayPositiom(position);
    }

  }
  //播放音乐
  public void playmusic(){
    mediaPlayer.reset();
    String url = "sdcard/Music/Fade.mp3";
    Log.i(tag,url);
    try {
      mediaPlayer.setDataSource(url);
      mediaPlayer.prepare();
    } catch (IOException e) {
      e.printStackTrace();
    }
     // might take long! (for buffering, etc)
    mediaPlayer.start();
    //更新播放进度条
    seekPlayProgress();
  }
  public void pausemusic(){
    mediaPlayer.pause();
    Log.i(tag,"暂停播放");

  }

  public void stopmusic(){
    mediaPlayer.reset();
    Log.i(tag,"停止播放");
    mediaPlayer.stop();
  }

  @Override
  public void onDestroy() {
    super.onDestroy();
  }
  public void seekPlayPositiom(int positon){
    Log.i(tag,"设置播放位置");
    mediaPlayer.seekTo(positon);
  }


  public void seekPlayProgress(){
     /*1.获取当前歌曲的总时长*/
    final int duration=mediaPlayer.getDuration();

    //计时器对象
    final Timer timer=new Timer();
    final TimerTask task=new TimerTask() {
      @Override
      public void run() {
        //开启线程定时获取当前播放进度
        int currentposition=mediaPlayer.getCurrentPosition();
        //利用message给主线程发消息更新seekbar进度
        Message ms=Message.obtain();
        Bundle bundle=new Bundle();
        bundle.putInt("duration",duration);
        Log.i(tag,"歌曲总长度"+duration);
        bundle.putInt("currentposition",currentposition);
        Log.i(tag,"当前长度"+currentposition);
        //设置发送的消息内容
        ms.setData(bundle);
        //发送消息
        MainActivity.handler.sendMessage(ms);
      }
    };
     timer.schedule(task,300,500);
    //当播放结束时停止播放
    mediaPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
      @Override
      public void onCompletion(MediaPlayer mp) {
        Log.i(tag,"取消计时任务");
        timer.cancel();
        task.cancel();
      }
    });

  }
  public void rePlayMusic() {
    Log.i(tag, "继续播放音乐");
    mediaPlayer.start();
  }
}

2.Mainactivity 

package my.com.mymusicp;

import android.Manifest;
import android.app.Activity;
import android.content.ComponentName;
import android.content.Intent;
import android.content.ServiceConnection;
import android.content.pm.PackageManager;
import android.os.Bundle;
import android.os.Handler;
import android.os.IBinder;
import android.os.Message;
import android.os.RemoteException;
import android.support.v4.app.ActivityCompat;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;
import android.widget.SeekBar;

public class MainActivity extends AppCompatActivity {
  private IMyMusicService iMyMusicService;
  private static SeekBar seekBar;
  private Button btpause_play;
  private boolean b=true;//判断暂停和继续播放
  public static Handler handler=new Handler(){
    @Override
    public void handleMessage(Message msg) {
      //处理消息
      Bundle bundle=msg.getData();
      //获取歌曲长度和当前播放位置,并设置到进度条上
      int duration=bundle.getInt("duration");
      int currentposition=bundle.getInt("currentposition");
      seekBar.setMax(duration);
      seekBar.setProgress(currentposition);
    }
  };

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    verifyStoragePermissions(MainActivity.this);
    //获取播放暂停按钮
    btpause_play=(Button) findViewById(R.id.bt_pause);
    Intent intent=new Intent(MainActivity.this,MyMusicService.class);
    bindService(intent,new MyConn(),BIND_AUTO_CREATE);
    seekBar=(SeekBar) findViewById(R.id.seekBar);
    seekBar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() {
      @Override
      public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) {
      }
      @Override
      public void onStartTrackingTouch(SeekBar seekBar) {
      }
      @Override
      public void onStopTrackingTouch(SeekBar seekBar) {
        try {
          iMyMusicService.seekPlayProgress(seekBar.getProgress());
        } catch (RemoteException e) {
          e.printStackTrace();
        }
      }
    });
  }
   //定义服务连接类
  class MyConn implements ServiceConnection{

    @Override
    public void onServiceConnected(ComponentName name, IBinder service) {
      iMyMusicService=IMyMusicService.Stub.asInterface(service);
    }
    @Override
    public void onServiceDisconnected(ComponentName name) {

    }
  }
  public void play(View v){
    try {
      iMyMusicService.play();

    } catch (RemoteException e) {
      e.printStackTrace();
    }
  }

  public void pause(View v){
    try {
      if(b)
      {
       iMyMusicService.pause();
        b=false;
        btpause_play.setText("继续播放");
      }
      else{
         b=true;
        iMyMusicService.continuePlay();
        btpause_play.setText("暂停播放");

      }

    } catch (RemoteException e) {
      e.printStackTrace();
    }
  }

  public void stop(View v){
    try {
        iMyMusicService.stop();
    } catch (RemoteException e) {
      e.printStackTrace();
    }
  }
  // Storage Permissions
  private static final int REQUEST_EXTERNAL_STORAGE = 1;
  private static String[] PERMISSIONS_STORAGE = {
      Manifest.permission.READ_EXTERNAL_STORAGE,
      Manifest.permission.WRITE_EXTERNAL_STORAGE,
  };

  /**
   * Checks if the app has permission to write to device storage
   *
   * If the app does not has permission then the user will be prompted to grant permissions
   *
   * @param activity
   */
  public static void verifyStoragePermissions(Activity activity) {
    // Check if we have write permission
    int permission = ActivityCompat.checkSelfPermission(activity, Manifest.permission.WRITE_EXTERNAL_STORAGE);

    if (permission != PackageManager.PERMISSION_GRANTED) {
      // We don't have permission so prompt the user
      ActivityCompat.requestPermissions(
          activity,
          PERMISSIONS_STORAGE,
          REQUEST_EXTERNAL_STORAGE
      );
    }
  }
} 

四.布局文件 

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:paddingLeft="@dimen/activity_horizontal_margin"
  android:paddingRight="@dimen/activity_horizontal_margin"
  android:paddingTop="@dimen/activity_vertical_margin"
  android:paddingBottom="@dimen/activity_vertical_margin"
  tools:context="my.com.mymusicp.MainActivity">

  <LinearLayout
    android:orientation="horizontal"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentTop="true"
    android:layout_alignParentLeft="true"
    android:layout_alignParentStart="true"
    android:id="@+id/linearLayout">

    <Button
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_weight="1"
      android:text="开始播放"
      android:onClick="play"
      android:id="@+id/bt_start"/>

    <Button
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="暂停播放"
      android:layout_weight="1"
      android:onClick="pause"
      android:id="@+id/bt_pause"/>

    <Button
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_weight="1"
      android:text="停止播放"
      android:onClick="stop"
      android:id="@+id/bt_stop"/>
  </LinearLayout>

  <SeekBar
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:id="@+id/seekBar"
    android:layout_below="@+id/linearLayout"
    android:layout_alignParentLeft="true"
    android:layout_alignParentStart="true"/>

</RelativeLayout> 

五.注册服务 

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
     package="my.com.mymusicp">
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
  <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
  <application
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:supportsRtl="true"
    android:theme="@style/AppTheme">
    <activity android:name=".MainActivity">
      <intent-filter>
        <action android:name="android.intent.action.MAIN"/>

        <category android:name="android.intent.category.LAUNCHER"/>
      </intent-filter>
    </activity>
    <service android:name=".MyMusicService"/>
  </application>

</manifest>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# Android  # SeekBar  # 播放器  # Android 可拖动的seekbar自定义进度值  # Android 中Seekbar详解及简单实例  # Android自定义SeekBar实现视频播放进度条  # Android控件之SeekBar的用法总结  # Android控件SeekBar仿淘宝滑动验证效果  # Android 动态改变SeekBar进度条颜色与滑块颜色的实例代码  # Android自定义竖直方向SeekBar多色进度条  # android之SeekBar控件用法详解  # Android自定义SeekBar滑动显示数字  # Android关于SeekBar无法点击到最大值问题解决方法记录(推荐)  # 计时器  # 进度条  # 发送消息  # 拖动  # 等功能  # 提供给  # 绑定  # 结束时  # 时长  # 大家多多  # 发消息  # 总长度  # prepare  # catch  # setDataSource  # printStackTrace  # Fade  # onDestroy  # positon  # seekTo 


相关文章: 网站制作公司,橙子建站是合法的吗?  ,石家庄四十八中学官网?  nginx修改上传文件大小限制的方法  h5在线制作网站电脑版下载,h5网页制作软件?  网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?  简历在线制作网站免费版,如何创建个人简历?  兔展官网 在线制作,怎样制作微信请帖?  如何使用Golang table-driven基准测试_多组数据测量函数效率  PHP正则匹配日期和时间(时间戳转换)的实例代码  PHP 500报错的快速解决方法  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  网站制作服务平台,有什么网站可以发布本地服务信息?  名字制作网站免费,所有小说网站的名字?  济南网站制作的价格,历城一职专官方网站?  网站制作价目表怎么做,珍爱网婚介费用多少?  建站之星伪静态规则如何设置?  佛山网站制作系统,佛山企业变更地址网上办理步骤?  建站之星如何修改网站生成路径?  如何通过二级域名建站提升品牌影响力?  TestNG的testng.xml配置文件怎么写  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  如何用花生壳三步快速搭建专属网站?  红河网站制作公司,红河事业单位身份证如何上传?  ,制作一个手机app网站要多少钱?  如何在腾讯云服务器上快速搭建个人网站?  青岛网站建设如何选择本地服务器?  如何选择PHP开源工具快速搭建网站?  如何用y主机助手快速搭建网站?  开心动漫网站制作软件下载,十分开心动画为何停播?  视频网站app制作软件,有什么好的视频聊天网站或者软件?  如何续费美橙建站之星域名及服务?  高端企业智能建站程序:SEO优化与响应式模板定制开发  制作网站公司那家好,网络公司是做什么的?  网站制作费用多少钱,一个网站的运营,需要哪些费用?  实例解析angularjs的filter过滤器  微网站制作教程,我微信里的网站怎么才能复制到浏览器里?  Thinkphp 中 distinct 的用法解析  网站图片在线制作软件,怎么在图片上做链接?  高防服务器租用首荐平台,企业级优惠套餐快速部署  如何通过服务器快速搭建网站?完整步骤解析  网站制作网站,深圳做网站哪家比较好?  南宁网站建设制作定制,南宁网站建设可以定制吗?  湖州网站制作公司有哪些,浙江中蓝新能源公司官网?  天津个人网站制作公司,天津网约车驾驶员从业资格证官网?  建站之星安装后界面空白如何解决?  再谈Python中的字符串与字符编码(推荐)  安徽网站建设与外贸建站服务专业定制方案  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  如何在IIS管理器中快速创建并配置网站?  电影网站制作价格表,那些提供免费电影的网站,他们是怎么盈利的? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。