我正在编写一个Android应用程序,它会拍摄一些照片,并希望将它们全部保存在与我的应用程序相关的唯一目录中。
此目录应该可以从标准图库中访问,以便用户以后可以(当应用程序不一定运行时)检查拍摄的图片。
我的问题是,每个不同的手机供应商,具有不同的Android版本,都有不同的图库路径。例如:
Environment.getExternalStorageDirectory() + Environment.DIRECTORY_PICTURES +"/myFolder"
可以Samsung Galaxy Nexus
运行android 4.1.1
,Asus Transformer Pad
正在运行android 4.0.3
,但不会HTC Desire
正在运行android 2.3.5
。
这将导致我的应用程序在尝试在指定路径中保存新目录时崩溃,如下所述:
boolean success = false;
myFolder = new File( Environment.getExternalStorageDirectory() + Environment.DIRECTORY_PICTURES + "/myFolder" );
if( myFolder.exists() ){
//do nothing
}else{
success = dvaFolder.mkdir();
if( success ){
// Do something on success
/*
* folder has been created
*/
} else {
// Do something else on failure
/*
* folder creation failed
*/
throw new RuntimeException("File Error in writing new folder");
}
}
如何编写可在图库中访问的目录 不同的供应商和Android版本?
注意:
Logcat没什么用处,因为它只返回运行时异常。
答案 0 :(得分:1)
我对蓝牙文件夹有同样的问题,我创建了两种方法来搜索手机上的蓝牙文件夹,方法是遍历手机上的整个文件结构。我写的代码是下面的,它有点脏,但它在我的情况下运行得很好
public List<File> folderSearchBT(File src, String folder) {
List<File> result = new ArrayList<File>();
File[] filesAndDirs = src.listFiles();
if (filesAndDirs != null && filesAndDirs.length > 0) {
List<File> filesDirs = Arrays.asList(filesAndDirs);
for (File file : filesDirs) {
result.add(file); // always add, even if directory
if (file.isDirectory()) {
List<File> deeperList = folderSearchBT(file, folder);
result.addAll(deeperList);
}
}
}
return result;
}
在此方法中使用上述方法:
public String searchForGallery() {
String splitchar = "/";
File root = Environment.getExternalStorageDirectory();
List<File> btFolder = null;
String folder = "gallery"; //your foldername to search for..
btFolder = folderSearchBT(root, folder);
if(btFolder.size() < 1)
Log.i("btFolder: ", "Empty");
for (int i = 0; i < btFolder.size(); i++) {
String g = btFolder.get(i).toString();
String[] subf = g.split(splitchar);
String s = subf[subf.length - 1].toUpperCase();
boolean equals = s.equalsIgnoreCase(folder);
if (equals)
return g;
}
return null; //not found
}
通过说代码很脏,我的意思是我可以通过这种方式写它更紧凑和另一个问题:如果有两个名为bluetooth的文件夹,我就卡住了..
我希望我理解你的问题。
答案 1 :(得分:1)
这是用于拍照并保存到外部存储器的工作代码,以及另一种用于保存到设备上的“文件”目录的方法。在我的情况下,我只需要一个图像(something.png),它将在用户拍摄新照片后始终刷新。
用户点击相机按钮时的操作:
ImageView productImageView = (ImageView) findViewById(R.id.imageView1);
static int RESULT_TAKE_PICTURE = 1;
String selectedImagePath;
Bitmap bitmap;
String imageName = "something.png";
public void cameraImageButton_onClick(View view) {
Intent cameraIntent = new Intent(
android.provider.MediaStore.ACTION_IMAGE_CAPTURE);
String path = Environment.getExternalStorageDirectory()
+ File.separator + Environment.DIRECTORY_PICTURES;
File dir = new File(path);
if (!dir.exists()) {
dir.mkdir();
}
dir = new File(path, imageName);
cameraIntent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(dir));
startActivityForResult(cameraIntent, RESULT_TAKE_PICTURE);
}
对活动结果执行的操作:
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == RESULT_TAKE_PICTURE && resultCode == RESULT_OK) {
selectedImagePath = Environment.getExternalStorageDirectory()
+ File.separator + Environment.DIRECTORY_PICTURES
+ File.separator + imageName;
BitmapFactory.Options options = new BitmapFactory.Options();
options.inJustDecodeBounds = true;
BitmapFactory.decodeFile(selectedImagePath, options);
options.inSampleSize = Calculator.calculateInSampleSize(options,
254, 254);
options.inJustDecodeBounds = false;
bitmap = BitmapFactory.decodeFile(selectedImagePath, options);
productImageView.setImageBitmap(bitmap);
saveImage(bitmap, imageName);
}
}
如果有人需要,将图像保存到文件目录中的设备的加值方法:
private void saveImage(Bitmap bitmap, String name) {
String path = getApplicationContext().getFilesDir().toString()
+ File.separator;
File dir = new File(path);
if (!dir.exists()) {
dir.mkdir();
}
path = path + name;
dir = new File(path);
try {
dir.createNewFile();
FileOutputStream fos = new FileOutputStream(dir);
bitmap.compress(Bitmap.CompressFormat.PNG, 100, fos);
fos.close();
fos.flush();
} catch (IOException e) {
e.printStackTrace();
}
}
答案 2 :(得分:0)
您应该检查是否已包含&#34; WRITE_EXTERNAL_STORAGE&#34;您的应用程序中的权限清单,它可能会出现此类错误。 另外,您是否通过打印检查路径是否看起来无效?