博客
关于我
Android实现视屏与Base64互转
阅读量:256 次
发布时间:2019-03-01

本文共 1719 字,大约阅读时间需要 5 分钟。

1.视屏转Base64字符串

* 视屏转Base64字符串     * @param     * @return     */    private String fileBase64String(Uri url){           try {               InputStream fis = getContentResolver().openInputStream(url);;//转换成输入流            ByteArrayOutputStream baos = new ByteArrayOutputStream();            byte[] buffer = new byte[1024];            int count = 0;            while((count = fis.read(buffer)) >= 0){                   baos.write(buffer, 0, count);//读取输入流并写入输出字节流中            }            fis.close();//关闭文件输入流            return Base64.encodeToString(baos.toByteArray(),Base64.DEFAULT);        } catch (Exception e) {               Log.e(TAG, "错误--> " + e);            return null;        }    }

2.base64字符串转视屏

/**     * base64字符串转视屏     * videoFilePath  输出视频文件路径带文件名     */    public static void base64ToVideo(String base64) {           try {               //base解密            byte[] videoByte = Base64.decode(base64.getBytes(),Base64.DEFAULT);            File videoFile = new File(Environment.getExternalStorageDirectory()                    + "/Convert.mp4");            if (videoFile.exists()){                   videoFile.delete();            }            try {                   //创建文件                videoFile.createNewFile();            } catch (IOException e) {                   e.printStackTrace();                Log.e("creatXMLFileException",e.getMessage());            }            //输入视频文件            FileOutputStream fos = new FileOutputStream(videoFile);            fos.write(videoByte, 0, videoByte.length);            fos.flush();            fos.close();            Log.d(TAG,"视屏保存的地址--" + videoFile);        } catch (IOException e) {               Log.e(TAG,"base64转换为视频异常",e);        }    }

3.记得动态获取权限

转载地址:http://vsfa.baihongyu.com/

你可能感兴趣的文章
Navicat导入海量Excel数据到数据库(简易介绍)
查看>>
Navicat工具Oracle数据库复制 or 备用、恢复功能(评论都在谈论需要教)
查看>>
Navicat工具中建立数据库索引
查看>>
navicat工具查看MySQL数据库_表占用容量_占用空间是多少MB---Linux工作笔记048
查看>>
navicat怎么导出和导入数据表
查看>>
Navicat怎样同步两个数据库中的表
查看>>
Navicat怎样筛选数据
查看>>
Navicat报错connection is being used
查看>>
Navicat报错:1045-Access denied for user root@localhost(using passwordYES)
查看>>
Navicat控制mysql用户权限
查看>>
navicat操作mysql中某一张表后, 读表时一直显示正在载入,卡死不动,无法操作
查看>>
Navicat连接mysql 2003 - Can't connect to MySQL server on ' '(10038)
查看>>
Navicat连接mysql数据库中出现的所有问题解决方案(全)
查看>>
Navicat连接Oracle出现Oracle library is not loaded的解决方法
查看>>
Navicat连接Oracle数据库以及Oracle library is not loaded的解决方法
查看>>
Navicat连接sqlserver提示:未发现数据源名并且未指定默认驱动程序
查看>>
navicat连接远程mysql数据库
查看>>
Navicat通过存储过程批量插入mysql数据
查看>>
Navicat(数据库可视化操作软件)安装、配置、测试
查看>>
navigationController
查看>>