zoukankan      html  css  js  c++  java
  • Android USB大容量存储时SD卡状态监听(转)

    对SD卡状态监听,到现在为止我知道的有两种方式:

    1.注册StorageEventListener来监听sd卡状态

    StorageEventListener中有onStorageStateChanged()方法,当sd卡状态改变时,此方法会调用,对各状态的判断一般会用到Environment类,此类中包含的有关sd卡状态的常量有:

    MEDIA_BAD_REMOVAL:表明SDCard 被卸载前己被移除

    MEDIA_CHECKING:表明对象正在磁盘检查

    MEDIA_MOUNTED:表明sd对象是存在并具有读/写权限

    MEDIA_MOUNTED_READ_ONLY:表明对象权限为只读

    MEDIA_NOFS:表明对象为空白或正在使用不受支持的文件系统

    MEDIA_REMOVED:如果不存在 SDCard 返回

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

    MEDIA_UNMOUNTABLE:返回 SDCard 不可被安装 如果 SDCard 是存在但不可以被安装

    MEDIA_UNMOUNTED:返回 SDCard 已卸掉如果 SDCard 是存在但是没有被安装

    如:

    1. public void onStorageStateChanged(String path, String oldState, String newState) {             
    2.             if (newState.equals(Environment.MEDIA_SHARED)) {  
    3.                 //大容量存储时相关操作  
    4.             } else if (newState.equals(Environment.MEDIA_CHECKING)) {  
    5.                 //检查sd卡时操作  
    6.             } else if (newState.equals(Environment.MEDIA_MOUNTED)) {  
    7.                 //sd在手机上可用时操作  
    8.             }...  
    9. }  

    StorageEventListener中还有onUsbMassStorageConnectionChanged()用来监听大容量存储是否连接,我对这个方法不太了解,原来以为用来监听usb线是否拔出的,可实际在linux上好像没什么问题,但在windows上却无法用来监听usb拔出状态,也不知道是驱动有问题还是我用错了,期待高手解答。

    2.通过接收Intent来监听sd卡状态
    sd卡状态改变时,MountServices会发送Intent,可以通过接收Intent来得到sd卡状态,Intent中关于sd卡状态的action有:
    MEDIA_BAD_REMOVAL_ACTION:sd卡已经从sd卡插槽拔出,但是挂载点还没解除
    MEDIA_EJECT_ACTION:用户想要移除sd卡
    MEDIA_MOUNTED_ACTION:sd卡被插入,且已经挂载
    MEDIA_REMOVED_ACTION:sd卡被移除
    MEDIA_SHARED_ACTION:sd卡作为 USB 大容量存储被共享,挂载被解除
    MEDIA_UNMOUNTED_ACTION:sd卡存在,但还没有挂载
    MEDIA_SCANNER_STARTED_ACTION:开始扫描
    MEDIA_SCANNER_FINISHED_ACTION:扫描完成

    如果只是获取当前sd卡状态,不需要对其监听,可以用方法Environment.getExternalStorageState()获得当前sd卡状态。

  • 相关阅读:
    【SpringFramework】Spring 事务控制
    Mini 学生管理器
    方法的重写override,重载overload。
    方法封装,属性调用以及设置。
    判断hdfs文件是否存在
    模拟(删除/远程拷贝)当前一周的日志文件
    2.上传hdfs系统:将logs目录下的日志文件每隔十分钟上传一次 要求:上传后的文件名修为:2017111513xx.log_copy
    使用定时器:在logs目录,每两分钟产生一个文件
    五个节点的hadoop集群--主要配置文件
    hadoop集群配置文件与功能对应解析
  • 原文地址:https://www.cnblogs.com/garygou/p/3695226.html
Copyright © 2011-2022 走看看