文件件监听器,android系统拍照功能调用后删除系统生成的照片
先说说要实现的功能:
android调用系统拍照功能实时 预览 删除 上传 保存 (用户不能再本地文件夹中看到拍的照片)
再说说遇到的问题:
1、调用系统拍照在系统自带的拍照文件夹中生成一张随机命名图片,此图片不好删除
2、在onActivityResult方法中的data下面拿到的照片是缩略图
3、你不能指定自己所照的目录为系统自带目录,这样系统会在其他地方生成一个新的目录
PS:经测试我手里拿到两台平板,一台有这种有问题1的情况,另外一台不会。
花费一天时间终于找到解决方案
起初的思路
1、获取到系统拍照的文件名实时删除系统生成的照片
2、获取到onActivityResult返回的data , 从data中找到系统所拍照片的bitmap,出现了新的问题,data为空,原因是拍照时指定了新的目录
更换了新的目录,data可以有值,但是Uri uri = data.getData();时,uri死活取不到值,估计是不同厂商对拍照路径的处理不同,经过一番探索最终在getExtras();
取到了所拍照片的bitmap,从而获取到了照片的uri,此时一切看起来看么顺利。可是平台对我开了一个玩笑,居然生成了两个文件,不管如何处理,系统自带的目录下总是会生成一个随机命名的文件。获取不到文件名,谈何删除文件
新的思路:
想了许久发现了一个新的思路,既然获取不到文件名,那我就对文件夹进行处理。
解决方案:对文件夹进行监听,可是android工程并没有像web工程那样的监听器,所以利用了线程监听了系统文件夹目录,当产生新的文件时就删除新增加的文件,至此所要达到的效果就实现了
下面给出了文件监听器的原理和代码
原理:利用线程每隔一段时间遍历文件夹是否和之前的文件夹一致,如果一致则没变化,如果不一致则对变化的文件进行删除
代码:
import java.io.File;
import java.util.ArrayList;
import java.util.List; public class ListenFiles implements Runnable { private File dir; List<String> list = new ArrayList<String>(); public ListenFiles(File fileDir){
this.dir = fileDir; File[] files = dir.listFiles(); for (int i = 0; i < files.length; i++) {
list.add(files[i].getName());
}
} public boolean listenFiles(File file) { for (int i = 0; i < list.size(); i++) {
if (file.getName().equals(list.get(i))) {
return true;
}
}
return false;// 存在新文件返回假
} @Override
public void run() {
File[] Nowfiles = dir.listFiles();
for (int j = 0; j < Nowfiles.length; j++) {
boolean flag = listenFiles(Nowfiles[j]);
if (flag == false) {
Nowfiles[j].delete();
}
}
try {
Thread.sleep(3000);
run();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
ListenFiles lf = new ListenFiles(new File("E:/老项目"));
new Thread(lf).start();
System.out.println("监视文件中......"); } }
这样就完成了对文件夹的监听
同时给出本人走不通的思路的代码吧,能用这种方式删除系统自己生产照片的可以交流下
这是拍照完成之后的回调方法:
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data); if (requestCode == REQUEST_CODE_CAPTURE_CAMEIA) {
Bitmap bitmap = null;
if(data!=null){
Uri uri = data.getData();
if(uri != null){
bitmap = BitmapFactory.decodeFile(uri.getPath());
}else{
if(bitmap == null){
Bundle bundle = data.getExtras();
bitmap = (Bitmap) bundle.get("data");
uri = Uri.parse(MediaStore.Images.Media.insertImage(getContentResolver(), bitmap, null,null));
SinoLifeLog.logDbInfo("uri.getPath()=========" + uri.getPath());
}
}
File file = new File("");
file.lastModified();
Cursor cursor = this.getContentResolver().query(MediaStore.Images.Thumbnails.EXTERNAL_CONTENT_URI, null,null, null, null);
int totalCount = cursor.getCount();
cursor.moveToFirst();
for(int i=0; i<totalCount; i++){
int index = cursor.getColumnIndexOrThrow(MediaStore.Images.Thumbnails.DATA);
String src = cursor.getString(index);
SinoLifeLog.logDbInfo("src=========" + src);
}
// if (cursor.moveToFirst()) {
// String filePath = cursor.getString(cursor.getColumnIndex("_data"));// 获取绝对路径
// String filename = cursor.getString(cursor.getColumnIndex("_display_name"));// 获取绝对路径
// String fileTime = cursor.getString(cursor.getColumnIndex("date_added"));// 获取绝对路径
// SinoLifeLog.logDbInfo("filePath=========" + filePath);
// }
cursor.close(); }
// if(data.getData() != null){
// uri = data.getData();
// }else{
// }
// SinoLifeLog.logDbInfo(String.valueOf(uri));
// bitmap = MediaStore.Images.Media.getBitmap(this.getContentResolver(), uri); // 文件不存在
// File file = new File(pathTmpFile);
// if (file.exists() == false) {
// ToastUtil.toast(context, "取消拍照");
// return;
// } // Bitmap bitmap = BitmapUtil.getimage(pathTmpFile); // String filePathName = MainApplication.potoSavePath + File.separator + photoName;
String filePathName = MainApplication.potoSavePath + File.separator; SinoLifeLog.logDbInfo(filePathName); try { //把pathTmpFile中的图片压缩放入filePathName
photoBitMap = BitmapUtil.compressAndSaveImage(bitmap, filePathName);
if (photoBitMap != null) { showPhotoDialog(filePathName); // file.delete();
// bitmap.recycle();
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
博客地址:http://qiaoyihang.iteye.com/
文件件监听器,android系统拍照功能调用后删除系统生成的照片的更多相关文章
- Java乔晓松-android中调用系统拍照功能并显示拍照的图片
android中调用系统拍照功能并显示拍照的图片 如果你是拍照完,利用onActivityResult获取data数据,把data数据转换成Bitmap数据,这样获取到的图片,是拍照的照片的缩略图 代 ...
- Android系统拍照源码
个人对于Android系统拍照的一些总结:一种自定义图片拍照路径 ,另一种直接利用Android拍照后经过处理的缩略图 特别注意第一种方式需要增加SDK读写权限: <uses-permissio ...
- Android系统拍照之后回显并且获取文件路径
/*调用拍照返回*/ case PHOTO_REQUEST_GALLERY: if (data != null) { Uri uri = data.getData(); String photopat ...
- 拍照-----------android系统 至关重要的功能
一 在Android 中,拍照对应的Action 是android.provider.MediaStore.ACTION_IMAGE_CAPTURE. 用于拍照的Activity 需要返回照片图像数据 ...
- Android 实例解说加入本地图片和调用系统拍照图片
在项目的开发过程我们离不开图片.而有时候须要调用本地的图片,有时候须要调用拍照图片.同一时候实现拍照的方法有两种,一种是调用系统拍照功能.还有一种是自己定义拍照功能. 而本博文眼下仅仅解说第一种方法, ...
- [置顶] Android系统移植与调试之------->build.prop文件详细赏析
小知识:什么是build.prop? /system/build.prop 是一个属性文件,在Android系统中.prop文件很重要,记录了系统的设置和改变,类似於/etc中的文件.这个文件是如 ...
- Android系统移植与调试之------->build.prop文件详细赏析
小知识:什么是build.prop? /system/build.prop 是一个属性文件,在Android系统中.prop文件很重要,记录了系统的设置和改变,类似於/etc中的文件.这个文件是如 ...
- 【Android 系统开发】Android框架 与 源码结构
一. Android 框架 Android框架层级 : Android 自下 而 上 分为 4层; -- Linux内核层; -- 各种库 和 Android运行环境层; -- 应用框架层; -- 应 ...
- Android系统编程入门系列之应用环境及开发环境介绍
作为移动端操作系统,目前最新的Android 11.0已经发展的比较完善了,现在也到了系统的整理一番的时间,接下来的系列文章将以Android开发者为中心,争取用归纳总结的态度对初级入门者所应 ...
随机推荐
- Redis系列四之复制
一.复制基本配置与演示 为了避免单点故障,Redis提供了复制功能,可以实现自动同步的过程. 1.配置 同步后的数据分为两类:一类是主数据库(master),一类是从数据库(slave).主数据库可以 ...
- Microsoft.Practices.Unity入门
Unity是微软Patterns & Practices团队所开发的一个轻量级的,并且可扩展的依赖注入(Dependency Injection)容器,它支持常用的三种依赖注入方式:构造器注入 ...
- iOS6.0下获取通讯录用户列表
自iOS6.0后获取通讯录列表需要询问用户,经过用户同意后才可以获取通讯录用户列表.而且ABAddressBookRef的初始化工作也由ABAddressBookCreate函数转变为ABAddres ...
- 数据操作语言DML与运算符
数据操作语言DML(添加,修改,删除) 1.添加数据 insert into insert into 表名 (字段列表) values (值列表),值列表要和字段列表按顺序匹配. insert int ...
- Mithril – 构建杰出 Web 应用的 JS MVC 框架
Mithril 是一个客户端的 Javascript MVC 框架.它是一个工具,使应用程序代码分为数据层,UI 层和粘合层.提供了一个模板引擎与一个虚拟的 DOM diff 实现,用于高性能渲染,支 ...
- 【追寻javascript高手之路05】理解事件流
前言 新的一天又开始了,我们对今天对未来抱有很大期待,所以开始我们今天的学习吧,在此之前来点题外话,还是爱好问题. 周三的面试虽然失败,但是也是很有启迪的,比如之前我就从来没有想过爱好问题,我发现我的 ...
- SharePoint 2013 为用户组自定义EventReceiver
前 言 在SharePoint的开发中,EventReceiver是很重要的一个部分,但是,常常遇到有些需要事件的时候,却没有相应的模板,因为EventReceiver创建时的模板只有那几个,除此之外 ...
- Castle DynamicProxy
Introduction¶ Castle DynamicProxy is a library for generating lightweight .NET proxies on the fly at ...
- 自定义有监听器的ScrollView
public class ObservableScrollView extends ScrollView { public ObservableScrollView(Context context) ...
- Hibernate3注解[转]
Hibernate3注解 收藏 1.@Entity(name="EntityName") 必须,name为可选,对应数据库中一的个表 2.@Table(name="&qu ...