Android 迷你播放器

简介:
今天我们要讲述一个具有控制界面的音乐播放器
1:UI布局layout/main.xml
<?xml version= "1.0" encoding= "utf-8"?>
<LinearLayout xmlns:android= "http://schemas.android.com/apk/res/android"
        android:orientation="vertical"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        >
  <TextView
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="迷你音乐播放器"
  />
  
  <LinearLayout
    android:orientation="horizontal"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
  >
    <ImageButton
      android:id="@+id/play"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:src="@drawable/play"
    />
    <ImageButton
      android:id="@+id/pause"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:src="@drawable/pause"
    />  
    <ImageButton
      android:id="@+id/stop"
      android:layout_height="wrap_content"
      android:layout_width="wrap_content"
      android:src="@drawable/stop"
    />
  </LinearLayout>
</LinearLayout>
2:实现功能核心代码MediaActivity.java
package com.android.test;

import android.app.Activity;
import android.app.AlertDialog;
import android.media.MediaPlayer;
import android.media.MediaPlayer.OnCompletionListener;
import android.os.Bundle;
import android.view.View;
import android.widget.ImageButton;
import android.widget.ProgressBar;

public  class MediaActivity  extends Activity  implements OnCompletionListener {
    
   private ImageButton play, pause, stop;
   //声明MediaPlayer实例
   private MediaPlayer mp;  
         public  void onCreate(Bundle savedInstanceState) {
                 super.onCreate(savedInstanceState);
                 //设置当前页面布局
                setContentView(R.layout.main);         
                 //通过findViewById方法获得按钮实例
                play = (ImageButton)findViewById(R.id.play);
                pause = (ImageButton)findViewById(R.id.pause);
                stop = (ImageButton)findViewById(R.id.stop);
         
                 //为按钮添加单击时间监听器
                play.setOnClickListener( new View.OnClickListener() {

       public  void onClick(View v) {
         //开始
        play();
      }                
                });
                
                pause.setOnClickListener( new View.OnClickListener() {

       public  void onClick(View v) {
         //暂停
        pause();
      }
                });
                
                stop.setOnClickListener( new View.OnClickListener() {

       public  void onClick(View v) {
         //停止
        stop();
      }              
                });
                 //准备
                setup();
        }
        
         public  void onDestory() {
           super.onDestroy();
           if(stop.isEnabled()) {
            stop();
          }
        }

         //准备
   private  void setup() {
     //加载播放文件
    loadClip();
     //使播放按钮生效
    play.setEnabled( true);
     //使暂停按钮失效
    pause.setEnabled( false);
     //使停止按钮失效
    stop.setEnabled( false);
  }

   private  void loadClip() {
     try{
       //实例化MediaPlayer
      mp = MediaPlayer.create( this, R.raw.test);
       //设置监听器
      mp.setOnCompletionListener( this);
    }  catch(Throwable t) {
      error(t);
    }
  }
  
   private  void error(Throwable t) {
    AlertDialog.Builder builder =  new AlertDialog.Builder( this);
    builder.setTitle( "报错啦!").setMessage(t.toString()).setPositiveButton( "确定"null).show();
  }

   public  void stop() {
     //停止
    mp.stop();
     //使暂停按钮失效
    pause.setEnabled( false);
     //使停止按钮失效
    stop.setEnabled( false);
    
     try {
       //准备
      mp.prepare();
       //定位到开始
      mp.seekTo(0);
       //使播放按钮生效
      play.setEnabled( true);
    }  catch (Throwable t) {
      error(t);
    }
  }

   public  void pause() {
     //暂停
    mp.pause();
     //使播放按钮生效
    play.setEnabled( true);
     //使暂停按钮失效
    pause.setEnabled( false);
     //使停止按钮生效
    stop.setEnabled( true);
  }

   public  void play() {
     //播放
    mp.start();
     //使播放按钮失效
    play.setEnabled( false);
     //使暂停按钮生效
    pause.setEnabled( true);
     //使停止按钮生效
    stop.setEnabled( true);
  }

   public  void onCompletion(MediaPlayer mp) {
     //停止
    stop();
  }
}
3:运行程序如图









本文转自 Art_Hero 51CTO博客,原文链接:http://blog.51cto.com/curran/523085,如需转载请自行联系原作者
目录
相关文章
|
7月前
|
缓存 网络协议 开发工具
庖丁解牛之-Android平台RTSP|RTMP播放器设计
我们在做Android平台RTSP或者RTMP播放器开发的时候,需要注意的点非常多,以下,以大牛直播SDK(官方)的接口为例,大概介绍下相关接口设计:
109 0
|
7月前
|
前端开发 开发工具 Android开发
Android播放器之SurfaceView与GLSurfaceView
Surface的官方介绍:Handle onto a raw buffer that is being managed by the screen compositor,Surface是一个raw buffer的句柄,通过它在raw buffer上进行绘制,可以通过Surface获得一个Canvas。
119 0
|
7月前
|
开发工具 Android开发 iOS开发
Android、iOS平台RTMP/RTSP播放器实现实时音量调节
介绍移动端RTMP、RTSP播放器实时音量调节之前,我们之前也写过,为什么windows播放端加这样的接口,windows端播放器在多窗口大屏显示的场景下尤其需要,尽管我们老早就有了实时静音接口,相对实时静音来说,播放端实时音量调节粒度更细,从[0, 100],用户体验更好。
128 1
|
4月前
|
XML 存储 Java
Android 开发音频录播中媒体录制器MediaRecorder和媒体播放器MediaPlayer的讲解及实战(超详细 附源码)
Android 开发音频录播中媒体录制器MediaRecorder和媒体播放器MediaPlayer的讲解及实战(超详细 附源码)
42 0
|
7月前
|
编解码 网络协议 Android开发
Android平台RTMP|RTSP直播播放器功能进阶探讨
很多开发者在跟我聊天的时候,经常问我,为什么一个RTMP或RTSP播放器,你们需要设计那么多的接口,真的有必要吗?带着这样的疑惑,我们今天聊聊Android平台RTMP、RTSP播放器常规功能,如软硬解码设置、实时音量调节、实时快照、实时录像、视频view翻转和旋转、画面填充模式设定、解码后YUV、RGB数据回调等:
104 0
|
7月前
|
数据处理 开发工具 Android开发
Android平台RTMP/RTSP播放器开发系列之解码和绘制
本文主要抛砖引玉,粗略介绍下Android平台RTMP/RTSP播放器中解码和绘制相关的部分(Github)。
|
7月前
|
Android开发 开发者
Android播放器实现视频窗口实时放大缩小功能
很多开发者希望Android播放端实现视频窗口的放大缩小功能,为此,我们做了个简单的demo,通过播放端回调RGB数据,直接在上层view操作处理即可,Github:https://github.com/daniulive/SmarterStreaming
182 0
|
9月前
|
编解码 Ubuntu Java
Android流媒体开发之路三:基于NDK开发Android平台RTSP播放器
Android流媒体开发之路三:基于NDK开发Android平台RTSP播放器
197 0
|
12月前
|
缓存 编解码 网络协议
从零开发一款Android RTMP播放器
当时在做一款游戏SDK,SDK主要提供了游戏画面声音采集、音视频编解码、直播推流、直播拉流播放等,SDK为游戏提供直播功能,播放也是采用了现成的ijkplayer播放器。但是SDK推广的时候遇到了问题,游戏厂家嫌弃SDK体积大(其实总共也就3Mb左右),我们需要一款体积小,性能高的播放器,由于开发成本的原因一直没有时间做,后面换工作期间,花了一个月时间把这款播放器开发出来,并开源了出来。oarplayer 是基于MediaCodec与srs-librtmp,完全不依赖ffmpeg,纯C语言实现的播放器。本文主要介绍这款播放器的实现思路。
187 0
|
Android开发
android实现万能播放器思路,flutter层实现调用
要实现一个Android万能播放器,可以播放MP4视频、Alpha格式以及Flutter通过通道调用,并使用外部纹理来实现整体流程,需要分为以下几个步骤
android实现万能播放器思路,flutter层实现调用