zoukankan      html  css  js  c++  java
  • 文件件监听器,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/

  • 相关阅读:
    做接口测试最重要的知识点
    HTTP和HTTPS区别
    UVA, 686 Goldbach's Conjecture (II)
    UVA, 543 Goldbach's Conjecture
    UVA, 580 Critical Mass
    UVA, 900 Brick Wall Patterns
    UVA, 11000 Bee
    UVA, 10079 Pizza Cutting
    C++ 向量<vector>的学习
    jenkins入门
  • 原文地址:https://www.cnblogs.com/qiaoyihang/p/6166178.html
Copyright © 2011-2022 走看看