先说说要实现的功能:
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系统拍照功能调用后删除系统生成的照片的更多相关文章

  1. Java乔晓松-android中调用系统拍照功能并显示拍照的图片

    android中调用系统拍照功能并显示拍照的图片 如果你是拍照完,利用onActivityResult获取data数据,把data数据转换成Bitmap数据,这样获取到的图片,是拍照的照片的缩略图 代 ...

  2. Android系统拍照源码

    个人对于Android系统拍照的一些总结:一种自定义图片拍照路径 ,另一种直接利用Android拍照后经过处理的缩略图 特别注意第一种方式需要增加SDK读写权限: <uses-permissio ...

  3. Android系统拍照之后回显并且获取文件路径

    /*调用拍照返回*/ case PHOTO_REQUEST_GALLERY: if (data != null) { Uri uri = data.getData(); String photopat ...

  4. 拍照-----------android系统 至关重要的功能

    一 在Android 中,拍照对应的Action 是android.provider.MediaStore.ACTION_IMAGE_CAPTURE. 用于拍照的Activity 需要返回照片图像数据 ...

  5. Android 实例解说加入本地图片和调用系统拍照图片

    在项目的开发过程我们离不开图片.而有时候须要调用本地的图片,有时候须要调用拍照图片.同一时候实现拍照的方法有两种,一种是调用系统拍照功能.还有一种是自己定义拍照功能. 而本博文眼下仅仅解说第一种方法, ...

  6. [置顶] Android系统移植与调试之------->build.prop文件详细赏析

    小知识:什么是build.prop?   /system/build.prop 是一个属性文件,在Android系统中.prop文件很重要,记录了系统的设置和改变,类似於/etc中的文件.这个文件是如 ...

  7. Android系统移植与调试之------->build.prop文件详细赏析

    小知识:什么是build.prop?   /system/build.prop 是一个属性文件,在Android系统中.prop文件很重要,记录了系统的设置和改变,类似於/etc中的文件.这个文件是如 ...

  8. 【Android 系统开发】Android框架 与 源码结构

    一. Android 框架 Android框架层级 : Android 自下 而 上 分为 4层; -- Linux内核层; -- 各种库 和 Android运行环境层; -- 应用框架层; -- 应 ...

  9. Android系统编程入门系列之应用环境及开发环境介绍

        作为移动端操作系统,目前最新的Android 11.0已经发展的比较完善了,现在也到了系统的整理一番的时间,接下来的系列文章将以Android开发者为中心,争取用归纳总结的态度对初级入门者所应 ...

随机推荐

  1. Hibernate框架之双向多对多关系映射

    昨天跟大家分享了Hibernate中单向的一对多.单向多对一.双向一对多的映射关系,今天跟大家分享下在Hibernate中双向的多对多的映射关系 这次我们以项目和员工举个栗子,因为大家可以想象得到,在 ...

  2. Rest.Ler PHP API Server解决方案

    https://github.com/Luracast/Restler 通过composer安装依赖后,整个vendor将近三十兆.这太不爽了.搞PHP的人如果没有洁癖的追求,跟搞Java的咸鱼有神码 ...

  3. PHP和Apache的安装

    http://jingyan.baidu.com/article/154b46315242b328ca8f4101.html

  4. Android开发中Eclispe相关问题及相应解决(持续更新)

    1.Eclipse项目中的Android Private Libraries没有自动生成. 一般而言,在Android开发中,项目中引用到的jar包会放到项目目录中的libs中,引入库会放到Andro ...

  5. 由一条Linux的grep命令说起

    今天在开发的时候,看到同事使用了这样的一条linux命令 grep 'class YourClass' -rwi * |grep -v svn 想到了 grep命令的,几个参数. -r 明确要求搜索子 ...

  6. Java经典实例:比较浮点数

    /** * Created by Frank * 比较浮点数 */ public class FloatCmp { // 公差 private final static Double EPSILON ...

  7. 理解 OpenStack 高可用(HA) (4): Pacemaker 和 OpenStack Resource Agent (RA)

    本系列会分析OpenStack 的高可用性(HA)概念和解决方案: (1)OpenStack 高可用方案概述 (2)Neutron L3 Agent HA - VRRP (虚拟路由冗余协议) (3)N ...

  8. spring MVC @Resource不支持Lazy加载

    今天迁一系统时发现有个bean使用@Resource注入了另外一个bean,这个被注入的bean是将被deprecated的类,而且只有一两个功能使用到,为了先调整进行测试,增加了@Lazy注解,启动 ...

  9. Java基础学习 -- Java(OOP)程序的设计原则

    避免代码复制.解决方案:函数.父类: 封装.尽量private每个类的成员变量,用操作封装数据,减少类与类之间成员变量的直接调用,而是调用method,降低耦合: 可扩展性最大化.尽量使用框架+数据的 ...

  10. 定制Eclipse IDE之界面篇

    为什么要定制IDE?      在工作时候,当公司有了自己的框架,给自己开放人员用,甚至是可以卖的时候,我们可以做成一个产品,而这个产品将包括框架本身.文档.工具.教程等等.工具之中最重要的莫过于开发 ...