Android提高之MediaPlayer音視頻播放
前面文章已經(jīng)詳細(xì)介紹了Android界面的入門技術(shù),相信大家在看完和跟著練習(xí)之后,會對于常用的Layout和View都會有一定的了解了,接下來就不再強調(diào)介紹界面了,而是針對具體的常見功能而展開。
本文將介紹MediaPlayer的使用。MediaPlayer可以播放音頻和視頻,另外也可以通過VideoView來播放視頻,雖然VideoView比MediaPlayer簡單易用,但定制性不如用MediaPlayer,這需要視情況選擇。MediaPlayer播放音頻比較簡單,但是要播放視頻就需要SurfaceView。SurfaceView比普通的自定義View更有繪圖上的優(yōu)勢,它支持完全的OpenGL ES庫。
先貼出本文程序運行結(jié)果的截圖,上面是播放/停止音頻,可用SeekBar來調(diào)進(jìn)度,下面是播放/停止視頻,也是用SeekBar來調(diào)進(jìn)度:
main.xml的源碼如下:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout android:id="@+id/LinearLayout01" android:layout_width="fill_parent" android:layout_height="fill_parent" xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical"> <SeekBar android:id="@+id/SeekBar01" android:layout_height="wrap_content" android:layout_width="fill_parent"></SeekBar> <LinearLayout android:id="@+id/LinearLayout02" android:layout_width="wrap_content" android:layout_height="wrap_content"> <Button android:id="@+id/Button01" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="播放音頻"></Button> <Button android:id="@+id/Button02" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="停止播放"></Button> </LinearLayout> <SeekBar android:id="@+id/SeekBar02" android:layout_height="wrap_content" android:layout_width="fill_parent"></SeekBar> <SurfaceView android:id="@+id/SurfaceView01" android:layout_width="fill_parent" android:layout_height="250px"></SurfaceView> <LinearLayout android:id="@+id/LinearLayout02" android:layout_width="wrap_content" android:layout_height="wrap_content"> <Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/Button03" android:text="播放視頻"></Button> <Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="停止播放" android:id="@+id/Button04"></Button> </LinearLayout> </LinearLayout>
Java部分源碼有點長,需要大家耐心解讀,詳細(xì)程序如下:
package com.testMedia; import java.io.IOException; import java.util.Timer; import java.util.TimerTask; import android.app.Activity; import android.media.AudioManager; import android.media.MediaPlayer; import android.os.Bundle; import android.view.SurfaceHolder; import android.view.SurfaceView; import android.view.View; import android.widget.Button; import android.widget.SeekBar; import android.widget.Toast; public class testMedia extends Activity { /** Called when the activity is first created. */ private SeekBar skb_audio=null; private Button btn_start_audio = null; private Button btn_stop_audio = null; private SeekBar skb_video=null; private Button btn_start_video = null; private Button btn_stop_video = null; private SurfaceView surfaceView; private SurfaceHolder surfaceHolder; private MediaPlayer m = null; private Timer mTimer; private TimerTask mTimerTask; private boolean isChanging=false;//互斥變量,防止定時器與SeekBar拖動時進(jìn)度沖突 @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); //----------Media控件設(shè)置---------// m=new MediaPlayer(); //播放結(jié)束之后彈出提示 m.setOnCompletionListener(new MediaPlayer.OnCompletionListener(){ @Override public void onCompletion(MediaPlayer arg0) { Toast.makeText(testMedia.this, "結(jié)束", 1000).show(); m.release(); } }); //----------定時器記錄播放進(jìn)度---------// mTimer = new Timer(); mTimerTask = new TimerTask() { @Override public void run() { if(isChanging==true) return; if(m.getVideoHeight()==0) skb_audio.setProgress(m.getCurrentPosition()); else skb_video.setProgress(m.getCurrentPosition()); } }; mTimer.schedule(mTimerTask, 0, 10); btn_start_audio = (Button) this.findViewById(R.id.Button01); btn_stop_audio = (Button) this.findViewById(R.id.Button02); btn_start_audio.setOnClickListener(new ClickEvent()); btn_stop_audio.setOnClickListener(new ClickEvent()); skb_audio=(SeekBar)this.findViewById(R.id.SeekBar01); skb_audio.setOnSeekBarChangeListener(new SeekBarChangeEvent()); btn_start_video = (Button) this.findViewById(R.id.Button03); btn_stop_video = (Button) this.findViewById(R.id.Button04); btn_start_video.setOnClickListener(new ClickEvent()); btn_stop_video.setOnClickListener(new ClickEvent()); skb_video=(SeekBar)this.findViewById(R.id.SeekBar02); skb_video.setOnSeekBarChangeListener(new SeekBarChangeEvent()); surfaceView = (SurfaceView) findViewById(R.id.SurfaceView01); surfaceHolder = surfaceView.getHolder(); surfaceHolder.setFixedSize(100, 100); surfaceHolder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS); } /* * 按鍵事件處理 */ class ClickEvent implements View.OnClickListener{ @Override public void onClick(View v) { if(v==btn_start_audio) { m.reset();//恢復(fù)到未初始化的狀態(tài) m=MediaPlayer.create(testMedia.this, R.raw.big);//讀取音頻 skb_audio.setMax(m.getDuration());//設(shè)置SeekBar的長度 try { m.prepare(); //準(zhǔn)備 } catch (IllegalStateException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } m.start(); //播放 } else if(v==btn_stop_audio || v==btn_stop_video) { m.stop(); } else if(v==btn_start_video) { m.reset();//恢復(fù)到未初始化的狀態(tài) m=MediaPlayer.create(testMedia.this, R.raw.test);//讀取視頻 skb_video.setMax(m.getDuration());//設(shè)置SeekBar的長度 m.setAudioStreamType(AudioManager.STREAM_MUSIC); m.setDisplay(surfaceHolder);//設(shè)置屏幕 try { m.prepare(); } catch (IllegalArgumentException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IllegalStateException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } m.start(); } } } /* * SeekBar進(jìn)度改變事件 */ class SeekBarChangeEvent implements SeekBar.OnSeekBarChangeListener{ @Override public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) { // TODO Auto-generated method stub } @Override public void onStartTrackingTouch(SeekBar seekBar) { isChanging=true; } @Override public void onStopTrackingTouch(SeekBar seekBar) { m.seekTo(seekBar.getProgress()); isChanging=false; } } }
希望本文所述關(guān)于MediaPlayer的使用能對大家有所幫助。
相關(guān)文章
Android嵌套滾動NestedScroll的實現(xiàn)了解一下
嵌套滾動已經(jīng)算一個比較常見的特效了,這篇文章主要介紹了Android嵌套滾動NestedScroll的實現(xiàn)了解一下,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-06-06Android判斷NavigationBar是否顯示的方法(獲取屏幕真實的高度)
有些時候,我們需要知道當(dāng)前手機上是否顯示了NavigationBar,也就是屏幕底部的虛擬按鍵。這篇文章主要介紹了Android判斷NavigationBar是否顯示的方法(獲取屏幕真實的高度),需要的朋友可以參考下本文2017-01-01RecyclerView Adapter輔助類詳解及示例代碼
本文主要介紹RecyclerView Adapter輔助類的知識,這里整理了詳細(xì)資料及簡單示例代碼,幫助大家學(xué)習(xí)這部分的內(nèi)容,有興趣的小伙伴可以參考下2016-09-09Android XmlPullParser 方式解析 Xml 文檔
這篇文章主要介紹了Android XmlPullParser 方式解析 Xml 文檔的相關(guān)資料,需要的朋友可以參考下2017-06-06Android使用LinearLayout設(shè)置邊框
這篇文章主要介紹了Android如何使用LinearLayout設(shè)置邊框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-09-09老生常談ProgressBar、ProgessDialog的用法
下面小編就為大家?guī)硪黄仙U凱rogressBar、ProgessDialog的用法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07android Launcher3設(shè)置默認(rèn)桌面應(yīng)用
這篇文章主要為大家詳細(xì)介紹了android Launcher3設(shè)置默認(rèn)桌面應(yīng)用,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-07-07