Android Environment

来源:互联网 发布:薄荷瘦身软件下载 编辑:程序博客网 时间:2024/06/05 06:49
如果我们想要读取或者向SD卡写入,这时就必须先要判断一个SD卡的状态,否则有可能出错。
那么SD卡状态为什么时才能读取呢,经过我的各种情况的实践,大致如下:
SD状态
现象描述
/mnt/sdcard目录是否存在
canRead返回
canWrite返回
在/mnt/sdcard创建文件
在/mnt/sdcard创建文件夹
MEDIA_MOUNTED
SD卡正常挂载
TRUE
TRUE
TRUE
TRUE
TRUE
MEDIA_REMOVED
无介质
TRUE
FALSE
FALSE
false:  原因Permission denied
FALSE
MEDIA_UNMOUNTED
有介质,未挂载,在系统中删除
TRUE
FALSE
FALSE
false:  原因Permission denied
FALSE
MEDIA_BAD_REMOVAL
介质在挂载前被移除,直接取出SD卡
TRUE
FALSE
FALSE
false:  原因Permission denied
FALSE
MEDIA_CHECKING
正在磁盘检查,刚装上SD卡时
TRUE
FALSE
FALSE
false:  原因Permission denied
FALSE
MEDIA_SHARED
SD卡存在但没有挂载,并且通过USB大容量存储共享,操作打开USB存储
TRUE
FALSE
FALSE
false:  原因Permission denied
FALSE
MEDIA_MOUNTED_READ_ONLY
sd卡存在并且已挂载,但是挂载方式为只读
-
-
无法模拟,SD卡不允许修改权限
MEDIA_NOFS
介质存在但是为空白或用在不支持的文件系统
-
-
无法模拟,SD卡格式化后再加载会自动生成系统文件
MEDIA_UNMOUNTABLE
存在SD卡但是不能挂载,例如发生在介质损坏
-
-
无法模拟


通过上表可以看出,只有在SD卡状态为MEDIA_MOUNTED时/mnt/sdcard目录才是可读可写,并且可以创建目录及文件。
所以我们读取SD卡时一般会这么写:
?
 
01
02
03
04
05
06
String state;
String path;
state = Environment.getExternalStorageState();
if(state.equals(Environment.MEDIA_MOUNTED)){
path = Environment.getExternalStorageDirectory().getAbsolutePath();


读写SD卡记得加这两个权限:

?

 

01

02

<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>

   <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

 

1 在AndroidManifest文件中加入sdcard操作权限
  * <!--在SDCard中创建与删除文件权限 -->
  * <uses-permissioandroid:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/> 
  * <!--往SDCard写入数据权限 --> 
  * <uses-permissionandroid:name="android.permission.WRITE_EXTERNAL_STORAGE"/> 
* 2 确认sdcard的存在
  * android.os.Environment.getExternalStorageState().equals(android.os.Environment.MEDIA_MOUNTED)
* 3 获取扩展存储设备的文件目录
  * android.os.Environment.getExternalStorageDirectory();

 

/////////////////////////////////////////////////

http://www.vogella.com/articles/Android/article.html#resources_android

http://www.coreservlets.com/android-tutorial/




1、讲述 Environment 类 
Environment 是一个提供访问环境变量的类。

 
Environment 包含常量: 


MEDIA_BAD_REMOVAL 
解释:返回getExternalStorageState() ,表明SDCard 被卸载前己被移除 


MEDIA_CHECKING 
解释:返回getExternalStorageState() ,表明对象正在磁盘检查。 


MEDIA_MOUNTED 
解释:返回getExternalStorageState() ,表明对象是否存在并具有读/写权限 


MEDIA_MOUNTED_READ_ONLY 
解释:返回getExternalStorageState() ,表明对象权限为只读 


MEDIA_NOFS 
解释:返回getExternalStorageState() ,表明对象为空白或正在使用不受支持的文件系统。

 
MEDIA_REMOVED 
解释:返回getExternalStorageState() ,如果不存在 SDCard 返回 


MEDIA_SHARED 
解释:返回getExternalStorageState() ,如果 SDCard 未安装 ,并通过 USB 大容量存储共享 返回 

MEDIA_UNMOUNTABLE 
解释:返回getExternalStorageState() ,返回 SDCard 不可被安装 如果 SDCard 是存在但不可以被安装 


MEDIA_UNMOUNTED 
解释:返回getExternalStorageState() ,返回 SDCard 已卸掉如果 SDCard   是存在但是没有被安装 


Environment 常用方法: 
方法:getDataDirectory() 
解释:返回 File ,获取 Android 数据目录。 


方法:getDownloadCacheDirectory() 
解释:返回 File ,获取 Android 下载/缓存内容目录。

 
方法:getExternalStorageDirectory() 
解释:返回 File ,获取外部存储目录即 SDCard 


方法:getExternalStoragePublicDirectory(String type) 
解释:返回 File ,取一个高端的公用的外部存储器目录来摆放某些类型的文件 


方法:getExternalStorageState() 
解释:返回 File ,获取外部存储设备的当前状态 


方法:getRootDirectory() 
解释:返回 File ,获取 Android 的根目录 


2、讲述 StatFs 类 
StatFs 一个模拟linux的df命令的一个类,获得SD卡和手机内存的使用情况 


StatFs 常用方法: 


getAvailableBlocks() 
解释:返回 Int ,获取当前可用的存储空间 


getBlockCount() 
解释:返回 Int ,获取该区域可用的文件系统数 


getBlockSize() 
解释:返回 Int ,大小,以字节为单位,一个文件系统 


getFreeBlocks() 
解释:返回 Int ,该块区域剩余的空间 


restat(String path) 
解释:执行一个由该对象所引用的文件系统 

 

 

 

 

 

 

   

Constants

String

  MEDIA_BAD_REMOVAL

在没有挂载前存储媒体已经被移除。

String

 MEDIA_CHECKING

正在检查存储媒体。

String

MEDIA_MOUNTED

存储媒体已经挂载,并且挂载点可读/写。

String

MEDIA_MOUNTED_READ_ONLY

存储媒体已经挂载,挂载点只读。

String

MEDIA_NOFS

存储媒体是空白或是不支持的文件系统。

String

MEDIA_REMOVED

存储媒体被移除。

String

MEDIA_SHARED

存储媒体正在通过USB共享。

String

MEDIA_UNMOUNTABLE

存储媒体无法挂载。

String

MEDIA_UNMOUNTED

存储媒体没有挂载。

 

 

 

Fields

public static String 

DIRECTORY_ALARMS

系统提醒铃声存放的标准目录。

public static String

DIRECTORY_DCIM

相机拍摄照片和视频的标准目录。

public static String

DIRECTORY_DOWNLOADS

下载的标准目录。

public static String

DIRECTORY_MOVIES

电影存放的标准目录。

public static String

DIRECTORY_MUSIC

音乐存放的标准目录。

public static String

DIRECTORY_NOTIFICATIONS

系统通知铃声存放的标准目录。

public static String

DIRECTORY_PICTURES

图片存放的标准目录。

public static String

DIRECTORY_PODCASTS

系统广播存放的标准目录。

public static String

DIRECTORY_RINGTONES

系统铃声存放的标准目录。

 

 

 

 

Public Methods

static         File

getDataDirectory()

获得android data的目录。

static File

getDownloadCacheDirectory()

获得下载缓存目录。

static File

getExternalStorageDirectory()

或者外部存储媒体目录。

static File

getExternalStoragePublicDirectory(String type)

Get a top-level public external storage directory for placing files of a particular type.

static String

getExternalStorageState()

获得当前外部储存媒体的状态。

static File

getRootDirectory()

获得android的跟目录。

 

 

 

public static File getExternalStoragePublicDirectory (String type)

Since: API Level 8

Get a top-level public external storage directory for placing files of a particular type. This is where the user will typically place and manage their own files, so you should be careful about what you put here to ensure you don't erase their files or get in the way of their own organization.

Here is an example of typical code to manipulate a picture on the public external storage:

 

 

Java代码  收藏代码
  1. void createExternalStoragePublicPicture() {  
  2.     // Create a path where we will place our picture in the user's  
  3.     // public pictures directory.  Note that you should be careful about  
  4.     // what you place here, since the user often manages these files.  For  
  5.     // pictures and other media owned by the application, consider  
  6.     // Context.getExternalMediaDir().  
  7.     File path = Environment.getExternalStoragePublicDirectory(  
  8.             Environment.DIRECTORY_PICTURES);  
  9.     File file = new File(path, "DemoPicture.jpg");  
  10.   
  11.     try {  
  12.         // Make sure the Pictures directory exists.  
  13.         path.mkdirs();  
  14.   
  15.         // Very simple code to copy a picture from the application's  
  16.         // resource into the external file.  Note that this code does  
  17.         // no error checking, and assumes the picture is small (does not  
  18.         // try to copy it in chunks).  Note that if external storage is  
  19.         // not currently mounted this will silently fail.  
  20.         InputStream is = getResources().openRawResource(R.drawable.balloons);  
  21.         OutputStream os = new FileOutputStream(file);  
  22.         byte[] data = new byte[is.available()];  
  23.         is.read(data);  
  24.         os.write(data);  
  25.         is.close();  
  26.         os.close();  
  27.   
  28.         // Tell the media scanner about the new file so that it is // 这一步非常重要!!  
  29.         // immediately available to the user.  
  30.         MediaScannerConnection.scanFile(this,  
  31.                 new String[] { file.toString() }, null,  
  32.                 new MediaScannerConnection.OnScanCompletedListener() {  
  33.             public void onScanCompleted(String path, Uri uri) {  
  34.                 Log.i("ExternalStorage""Scanned " + path + ":");  
  35.                 Log.i("ExternalStorage""-> uri=" + uri);  
  36.             }  
  37.         });  
  38.     } catch (IOException e) {  
  39.         // Unable to create file, likely because external storage is  
  40.         // not currently mounted.  
  41.         Log.w("ExternalStorage""Error writing " + file, e);  
  42.     }  
  43. }  
  44.   
  45. void deleteExternalStoragePublicPicture() {  
  46.     // Create a path where we will place our picture in the user's  
  47.     // public pictures directory and delete the file.  If external  
  48.     // storage is not currently mounted this will fail.  
  49.     File path = Environment.getExternalStoragePublicDirectory(  
  50.             Environment.DIRECTORY_PICTURES);  
  51.     File file = new File(path, "DemoPicture.jpg");  
  52.     file.delete();  
  53. }  
  54.   
  55. boolean hasExternalStoragePublicPicture() {  
  56.     // Create a path where we will place our picture in the user's  
  57.     // public pictures directory and check if the file exists.  If  
  58.     // external storage is not currently mounted this will think the  
  59.     // picture doesn't exist.  
  60.     File path = Environment.getExternalStoragePublicDirectory(  
  61.             Environment.DIRECTORY_PICTURES);  
  62.     File file = new File(path, "DemoPicture.jpg");  
  63.     return file.exists();  
  64. }  

 

Parameters
typeThe type of storage directory to return. Should be one ofDIRECTORY_MUSIC,DIRECTORY_PODCASTS,DIRECTORY_RINGTONES,DIRECTORY_ALARMS,DIRECTORY_NOTIFICATIONS,DIRECTORY_PICTURES,DIRECTORY_MOVIES,DIRECTORY_DOWNLOADS, orDIRECTORY_DCIM. May not be null.
Returns
  • Returns the File path for the directory. Note that this directory may not yet exist, so you must make sure it exists before using it such as withFile.mkdirs().








0 0
原创粉丝点击