Android播放多媒体文件

       播放音频和视频的逻辑是一样的,下面我就单一的对播放视频的方法进行简单的论述。我也一个刚刚入门的Android的开发者,我将一步步的把我的历程写在我的博客上。

        视频的播放和音频的播放复杂度相差不大,主要是通过VideoView类来进行实现的。

        其中有几个常用的方法:

  1. setVideoPath()设置播放的视频文件的位置;
  2. 开始()开始或继续播放视频;
  3. 暂停()暂停播放视频;
  4. 恢复()将视频重新开始播放;
  5. IsPlaying模块()判断当前是否正在播放视频;
  6. getDuration()获取载入的视频文件的时长;
  7. seekTo()从指定的位置开始播放视频。 

下面我们就进入实例的体验:

1.在新建的项目的XML中设置我们的布局:

三个按钮分别是:播放,暂停,重新播放,其次是一个Video View,视频就在这里播放。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.example.codoon.myapplication.MainActivity">
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
        <Button
            android:id="@+id/play"
            android:layout_height="wrap_content"
            android:layout_width="0dp"
            android:layout_weight="1"
            android:text="Play"/>
        <Button
            android:id="@+id/pause"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:layout_width="0dp"
            android:text="Pause"/>
        <Button
            android:id="@+id/stop"
            android:layout_width="0dp"
            android:layout_weight="1"
            android:layout_height="wrap_content"
            android:text="Stop"/>
    </LinearLayout>
    <VideoView
        android:id="@+id/video_view"
        android:layout_height="wrap_content"
        android:layout_width="match_parent"
        />
</LinearLayout>

2.我直接上代码

代码和音频的播放几乎一样,只是将音频播放器,转换成了视频播放器。

package com.example.codoon.myapplication;

import android.Manifest;
import android.content.pm.PackageManager;
import android.support.annotation.NonNull;
import android.support.v4.app.ActivityCompat;
import android.support.v4.content.ContextCompat;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;
import android.widget.VideoView;

public class MainActivity extends AppCompatActivity implements View.OnClickListener{
    private VideoView videoView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        videoView = findViewById(R.id.video_view);
        Button play = findViewById(R.id.play);
        Button pause = findViewById(R.id.pause);
        Button stop = findViewById(R.id.stop);
        play.setOnClickListener(this);
        pause.setOnClickListener(this);
        stop.setOnClickListener(this);
        
        if (ContextCompat.checkSelfPermission(MainActivity.this,
                Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED){
            ActivityCompat.requestPermissions(MainActivity.this,new String[]{
                    Manifest.permission.WRITE_EXTERNAL_STORAGE
            },1);
        }  else {
            initVideoPath();
        }
    }
    //指定文件的路径,此处如果找不到具体的路径,可以下载一个ES文件浏览器
    private void initVideoPath(){
        String file_path = "/storage/emulated/0/DCIM/Camera/VID_20180610_212931.mp4";
        videoView.setVideoPath(file_path);
    }

    @Override
    public void onRequestPermissionsResult(int requestCode,
                                           @NonNull String[] permissions, @NonNull int[] grantResults) {
        switch (requestCode){
            case 1:
                if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED){
                    initVideoPath();
                }else {
                    Toast.makeText(this,"拒绝权限,您将无法使用!",Toast.LENGTH_SHORT).show();
                    finish();
                }
                break;
                default:
        }
    }

    @Override
    public void onClick(View v) {
        switch (v.getId()){
            case R.id.play:
                if (!videoView.isPlaying()){
                    videoView.start(); //开始播放
                }
                break;
            case R.id.pause:
                if(videoView.isPlaying()){
                    videoView.pause();  //暂停播放
                }
                break;
            case R.id.stop:
                if (videoView.isPlaying()){
                    videoView.resume();  //重新播放
                }
                break;
        }
    }
    //释放并清理播放器
    @Override
    protected void onDestroy() {
        super.onDestroy();
        if (videoView != null){
            videoView.suspend();
        }
    }
}

 

package com.demo.pr5; import java.io.File; import java.util.Vector; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.view.KeyEvent; import android.view.View; import android.view.ViewGroup; import android.widget.AdapterView; import android.widget.BaseAdapter; import android.widget.Button; import android.widget.EditText; import android.widget.ImageView; import android.widget.ListView; import android.widget.TextView; import android.widget.Toast; import android.widget.AdapterView.OnItemClickListener; public class MyFileActivity extends Activity { // 支持的媒体格式 private final String[]FILE_MapTable = { ".3gp",".mov",".avi", ".rmvb", ".wmv", ".mp3", ".mp4" }; private Vector<String> items = null; // items:存放显示的名称 private Vector<String> paths = null; // paths:存放文件路径 private Vector<String> sizes = null; // sizes:文件大小 private String rootPath = "/mnt/sdcard"; //起始文件夹 private EditText pathEditText; // 路径 private Button queryButton; //查询按钮 private ListView fileListView;//文件列表 @Override protected void onCreate(Bundle icicle) { super.onCreate(icicle); this.setTitle("多媒体文件浏览"); setContentView(R.layout.myfile); //从myfile.xml找到对应的元素 pathEditText = (EditText) findViewById(R.id.path_edit); queryButton = (Button) findViewById(R.id.qry_button); fileListView= (ListView) findViewById(R.id.file_listview); //查询按钮事件 queryButton.setOnClickListener( new Button.OnClickListener() { public void onClick(View arg0) { File file = new File(pathEditText.getText().toString()); if (file.exists()) { if (file.isFile()) { //如果是媒体文件直接打开播放 openFile(pathEditText.getText().toString()); } else { //如果是目录打开目录下文件 getFileDir(pathEditText.getText().toString()); } } else { Toast.makeText(MyFileActivity.this, "找不到该位置,请确定位置是否正确!", Toast.LENGTH_SHORT).show(); } } }); //设置ListItem被点击时要做的动作 fileListView.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(AdapterView<?> arg0, View arg1, int position, long arg3) { fileOrDir(paths.get(position)); } }); //打开默认文件夹 getFileDir(rootPath); } /** * 重写返回键功能:返回上一级文件夹 */ @Override public boolean onKeyDown(int keyCode, KeyEvent event) { // 是否触发按键为back键 if (keyCode == KeyEvent.KEYCODE_BACK) { pathEditText = (EditText) findViewById(R.id.path_edit); File file = new File(pathEditText.getText().toString()); if (rootPath.equals(pathEditText.getText().toString().trim())) { return super.onKeyDown(keyCode, event); } else { getFileDir(file.getParent()); return true; } //如果不是back键正常响应 } else { return super.onKeyDown(keyCode, event); } } /** * 处理文件或者目录的方法 */ private void fileOrDir(String path) { File file = new File(path); if (file.isDirectory()) { getFileDir(file.getPath()); } else { openFile(path); } } /** * 取得文件结构的方法 */ private void getFileDir(String filePath) { /* 设置目前所在路径 */ pathEditText.setText(filePath); items = new Vector<String>(); paths = new Vector<String>(); sizes = new Vector<String>(); File f = new File(filePath); File[] files = f.listFiles(); if (files != null) { /* 将所有文件添加ArrayList中 */ for (int i = 0; i < files.length; i++) { if (files[i].isDirectory()) { items.add(files[i].getName()); paths.add(files[i].getPath()); sizes.add(""); } } for (int i = 0; i < files.length; i++) { if (files[i].isFile()) { String fileName = files[i].getName(); int index = fileName.lastIndexOf("."); if (index > 0) { String endName = fileName.substring(index, fileName.length()).toLowerCase(); String type = null; for (int x = 0; x < FILE_MapTable.length; x++) { // 支持的格式,才会在文件浏览器中显示 if (endName.equals(FILE_MapTable[x])) { type = FILE_MapTable[x]; break; } } if (type != null) { items.add(files[i].getName()); paths.add(files[i].getPath()); sizes.add(files[i].length()+""); } } } } } /* 使用自定义的FileListAdapter来将数据传入ListView */ fileListView.setAdapter(new FileListAdapter(this, items)); } /** * 打开媒体文件 * @param f */ private void openFile(String path) { //打开媒体播放器 Intent intent = new Intent(MyFileActivity.this, MediaPlayerActivity.class); intent.putExtra("path",path); startActivity(intent); finish(); } /** *ListView列表适配器 */ class FileListAdapter extends BaseAdapter { private Vector<String> items = null; // items:存放显示的名称 private MyFileActivity myFile; public FileListAdapter(MyFileActivity myFile, Vector<String> items) { this.items=items; this.myFile=myFile; } @Override public int getCount() { // TODO Auto-generated method stub return items.size(); } @Override public Object getItem(int position) { // TODO Auto-generated method stub return items.elementAt(position); } @Override public long getItemId(int position) { // TODO Auto-generated method stub return items.size(); } @Override public View getView(int position, View convertView, ViewGroup parent) { // TODO Auto-generated method stub if(convertView==null) { //加载列表项布局file_item.xml convertView = myFile.getLayoutInflater() .inflate(R.layout.file_item, null); } //文件名称 TextView name = (TextView) convertView.findViewById(R.id.name); //媒体文件类型 ImageView music=(ImageView)convertView.findViewById(R.id.music); //文件夹类型 ImageView folder=(ImageView)convertView.findViewById(R.id.folder); name.setText(items.elementAt(position)); if(sizes.elementAt(position).equals("")) { //隐藏媒体图标,显示文件夹图标 music.setVisibility(View.GONE); folder.setVisibility(View.VISIBLE); }else { //隐藏文件夹图标,显示媒体图标 folder.setVisibility(View.GONE); music.setVisibility(View.VISIBLE); } return convertView; } } }
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值