博客
关于我
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/

你可能感兴趣的文章
mysql server has gone away
查看>>
mysql skip-grant-tables_MySQL root用户忘记密码怎么办?修改密码方法:skip-grant-tables
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
MYSQL sql语句针对数据记录时间范围查询的效率对比
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql sysbench测试安装及命令
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>
MySQL Troubleshoting:Waiting on query cache mutex
查看>>
mysql union orderby 无效
查看>>
mysql v$session_Oracle 进程查看v$session
查看>>
mysql where中如何判断不为空
查看>>
MySQL Workbench 使用手册:从入门到精通
查看>>
MySQL Workbench 数据库建模详解:从设计到实践
查看>>
MySQL Workbench 数据建模全解析:从基础到实践
查看>>
mysql workbench6.3.5_MySQL Workbench
查看>>
MySQL Workbench安装教程以及菜单汉化
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>
mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
查看>>