文件件监听器,android系统拍照功能调用后删除系统生成的照片
先说说要实现的功能:
android调用系统拍照功能实时预览删除上传保存(用户不能再本地文件夹中看到拍的照片)
再说说遇到的问题:
1、调用系统拍照在系统自带的拍照文件夹中生成一张随机命名图片,此图片不好删除
2、在onActivityResult方法中的data下面拿到的照片是缩略图
3、你不能指定自己所照的目录为系统自带目录,这样系统会在其他地方生成一个新的目录
PS:经测试我手里拿到两台平板,一台有这种有问题1的情况,另外一台不会。
花费一天时间终于找到解决方案
起初的思路
1、获取到系统拍照的文件名实时删除系统生成的照片
2、获取到onActivityResult返回的data,从data中找到系统所拍照片的bitmap,出现了新的问题,data为空,原因是拍照时指定了新的目录
更换了新的目录,data可以有值,但是Uriuri=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(); } } }