Android选择视频并播放

部署运行你感兴趣的模型镜像
package com.example.myapplication;

import java.lang.System;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.graphics.Bitmap;
import android.media.MediaPlayer;
import android.os.Environment;
import android.graphics.BitmapFactory;
import  android.util.Log;

 import java.io.File;
 import java.io.FileInputStream;
 import java.io.FileOutputStream;
 import java.io.InputStream;
 import java.io.OutputStream;

import android.database.Cursor;
import org.opencv.android.BaseLoaderCallback;
import org.opencv.android.LoaderCallbackInterface;
import org.opencv.android.OpenCVLoader;
import org.opencv.android.Utils;
import org.opencv.calib3d.Calib3d;
import org.opencv.core.Mat;
import org.opencv.core.MatOfPoint2f;
import org.opencv.core.Point;
import org.opencv.core.Size;
import org.opencv.imgproc.Imgproc;

import android.os.Bundle;
import com.google.android.material.floatingactionbutton.FloatingActionButton;
import com.google.android.material.snackbar.Snackbar;
import androidx.appcompat.app.AppCompatActivity;
import androidx.appcompat.widget.Toolbar;
import android.view.View;
import android.view.Menu;
import android.view.MenuItem;
import android.content.Intent;

import android.graphics.BitmapFactory;
import android.net.Uri;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.WindowManager;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.MediaController;
import android.widget.Toast;
import android.widget.VideoView;
import org.opencv.android.OpenCVLoader;
import org.opencv.android.Utils;
import org.opencv.core.CvType;
import org.opencv.core.Mat;
import org.opencv.imgproc.Imgproc;
import java.io.InputStream;





public class MainActivity extends AppCompatActivity
{
    private double max_size = 1024;
    private int PICK_IMAGE_REQUEST = 1;
    private VideoView video;
    private Bitmap selectbp;
    private Bitmap selectbptmp;

    @Override
    protected void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        staticLoadCVLibraries();

        getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,WindowManager.LayoutParams.FLAG_FULLSCREEN);
        video = (VideoView)findViewById(R.id.video);

        Button selectImageBtn = (Button)findViewById(R.id.select_btn);
        selectImageBtn.setOnClickListener(new View.OnClickListener()
        {
            @Override
            public void onClick(View v) {selectImage(); }
        });
    }


    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data)
    {
        if (requestCode == 1)
        {
            if (resultCode == RESULT_OK)
            {
                Uri uri = data.getData();
                video.setVideoURI(uri);
            }
        }

        MediaController mc = new MediaController(MainActivity.this);
        video.setMediaController(mc);
        video.requestFocus();

        try{
            video.start();
        }catch(Exception e){
            e.printStackTrace();
        }

        video.setOnCompletionListener(new MediaPlayer.OnCompletionListener(){
            @Override
            public void onCompletion(MediaPlayer mp)
            {
                Toast.makeText(MainActivity.this, "视频播放完毕", Toast.LENGTH_SHORT).show();
            }
        });

        super.onActivityResult(requestCode, resultCode, data);
    }






    private void selectImage()
    {
        Intent intent = new Intent();
        intent.setType("video/*;image/*");//同时选择视频和图片
        intent.setAction(Intent.ACTION_GET_CONTENT);
        startActivityForResult(Intent.createChooser(intent,"选择图像..."), PICK_IMAGE_REQUEST);
    }



    private void staticLoadCVLibraries()
    {
        boolean load = OpenCVLoader.initDebug();
        if(load)
        {
            Log.i("CV", "Open CV Libraries loaded...");
        }
    }

//    @Override
//    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
//        super.onActivityResult(requestCode, resultCode, data);
//        if(requestCode == PICK_IMAGE_REQUEST && resultCode == RESULT_OK && data != null && data.getData() != null) {
//            Uri uri = data.getData();
//            try {
//                Log.d("image-tag", "start to decode selected image now...");
//                InputStream input = getContentResolver().openInputStream(uri);
//                BitmapFactory.Options options = new BitmapFactory.Options();
//                options.inJustDecodeBounds = true;
//                BitmapFactory.decodeStream(input, null, options);
//                int raw_width = options.outWidth;
//                int raw_height = options.outHeight;
//                int max = Math.max(raw_width, raw_height);
//                int newWidth = raw_width;
//                int newHeight = raw_height;
//                int inSampleSize = 1;
//                if(max > max_size) {
//                    newWidth = raw_width / 2;
//                    newHeight = raw_height / 2;
//                    while((newWidth/inSampleSize) > max_size || (newHeight/inSampleSize) > max_size) {
//                        inSampleSize *=2;
//                    }
//                }
//
//                options.inSampleSize = inSampleSize;
//                options.inJustDecodeBounds = false;
//                options.inPreferredConfig = Bitmap.Config.ARGB_8888;
//                selectbp    = BitmapFactory.decodeStream(getContentResolver().openInputStream(uri), null, options);
//                selectbptmp = BitmapFactory.decodeStream(getContentResolver().openInputStream(uri), null, options);
//                myImageView.setImageBitmap(selectbptmp);
//
//            } catch (Exception e)
//            {
//                e.printStackTrace();
//            }
//        }
//    }



//    private void kaySrc()
//    {
//        Mat src = new Mat();
//        Mat temp = new Mat();
//        Mat dst = new Mat();
//
//        if(selectbp != null)
//        {
//            Utils.bitmapToMat(selectbp, src);
//            Imgproc.cvtColor(src, temp, Imgproc.COLOR_BGRA2BGR);
//            Log.i("CV", "image type:" + (temp.type() == CvType.CV_8UC3));
//            Imgproc.cvtColor(temp, dst, Imgproc.COLOR_BGR2GRAY);
//            Utils.matToBitmap(dst, selectbptmp);
//            myImageView.setImageBitmap(selectbptmp);
//        }
//        else
//        {
//            new AlertDialog.Builder(MainActivity.this)
//                    .setMessage("请先选择图片!")
//                    .setPositiveButton("OK",
//                            new DialogInterface.OnClickListener() {
//                                @Override
//                                public void onClick(DialogInterface dialog, int which) {}
//                            }).show();
//        }
//    }

}

您可能感兴趣的与本文相关的镜像

ACE-Step

ACE-Step

音乐合成
ACE-Step

ACE-Step是由中国团队阶跃星辰(StepFun)与ACE Studio联手打造的开源音乐生成模型。 它拥有3.5B参数量,支持快速高质量生成、强可控性和易于拓展的特点。 最厉害的是,它可以生成多种语言的歌曲,包括但不限于中文、英文、日文等19种语言

<think>好的,用户想在Android Studio中实现选择本地视频文件进行播放的功能。我需要先理清楚这个功能需要哪些步骤,然后结合提供的引用内容给出解决方案。 首先,用户需要一个文件选择器来选取本地视频。根据引用[3],里面提到了Android Studio实现文件管理器,可能需要用到文件选择的功能。不过具体的实现可能需要使用Intent来启动系统的文件选择器。例如,使用Intent.ACTION_GET_CONTENT或者Intent.ACTION_OPEN_DOCUMENT来让用户选择视频文件。 接下来是播放视频的部分。引用[1]和引用[2]都提到了视频播放器的实现。其中引用[2]中的代码示例使用了VideoView和MediaController,这可能是一个关键点。VideoView可以嵌入布局中,然后通过设置MediaController来控制播放、暂停等操作。所以可能需要创建一个VideoView,然后设置其视频路径,添加控制器。 步骤大概是这样的:首先,在布局文件中添加VideoView组件。然后在Activity中获取VideoView的实例,启动文件选择器,用户选择视频后获取文件的URI,将其设置给VideoView,配置MediaController。 另外,处理文件URI可能需要使用ContentResolver来打开文件描述符,或者将URI转换为文件路径,但要注意不同Android版本的文件权限问题。例如,使用Uri.parse()来解析URI,然后VideoView.setVideoURI()方法加载视频。 可能还需要处理一些异常情况,比如文件无法打开或者格式不支持,这时候需要Toast提示用户,如引用[2]中的代码所示。 最后,测试整个流程,确保文件选择器能正确启动,视频能加载播放,控制器功能正常。如果有问题,可能需要检查权限设置,比如是否在AndroidManifest.xml中声明了读取存储的权限。 用户可能还关心如何定制界面或者添加更多功能,比如播放网络视频,但当前需求是本地视频,所以重点放在本地文件选择播放上。需要确保代码结构清晰,各部分的逻辑正确,参考提供的引用中的代码示例进行调整。</think>在Android Studio中实现本地视频文件选择播放功能,可通过以下步骤完成: ### 一、添加权限和布局 1. 在`AndroidManifest.xml`中添加权限: ```xml <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/> ``` 2. 创建播放器布局(`activity_player.xml`): ```xml <RelativeLayout android:id="@+id/container" android:layout_width="match_parent" android:layout_height="match_parent"> <VideoView android:id="@+id/videoView" android:layout_width="match_parent" android:layout_height="match_parent"/> </RelativeLayout> ``` ### 二、实现文件选择功能 ```kotlin class VideoPlayerActivity : AppCompatActivity() { private lateinit var videoView: VideoView private val REQUEST_VIDEO = 100 override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_player) videoView = findViewById(R.id.videoView) openFilePicker() } private fun openFilePicker() { val intent = Intent(Intent.ACTION_OPEN_DOCUMENT).apply { addCategory(Intent.CATEGORY_OPENABLE) type = "video/*" } startActivityForResult(intent, REQUEST_VIDEO) } override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) { super.onActivityResult(requestCode, resultCode, data) if (requestCode == REQUEST_VIDEO && resultCode == RESULT_OK) { data?.data?.let { uri -> playVideo(uri) } } } } ``` ### 三、实现视频播放 ```kotlin private fun playVideo(uri: Uri) { videoView.setVideoURI(uri) // 添加媒体控制器 val mediaController = MediaController(this) mediaController.setAnchorView(videoView) videoView.setMediaController(mediaController) videoView.setOnPreparedListener { videoView.start() } videoView.setOnErrorListener { _, what, extra -> Toast.makeText(this, "播放错误:$what-$extra", Toast.LENGTH_SHORT).show() true } } ``` ### 四、处理URI权限(Android 10+) ```kotlin private fun playVideo(uri: Uri) { contentResolver.takePersistableUriPermission( uri, Intent.FLAG_GRANT_READ_URI_PERMISSION ) // 后续播放代码... } ``` 关键要点说明: 1. 使用`Intent.ACTION_OPEN_DOCUMENT`获取持久化URI访问权限[^2] 2. `VideoView`+`MediaController`组合实现基础播放控制[^1] 3. 需要处理Android不同版本的存储权限策略[^3]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值