先说说要实现的功能:
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/