手机上的存储卡是可以随时插拔的,每次插拔时会像操作系统总发送Action广播事件。

使用StatFs文件系统来获取MicroSD存储卡的剩余容量,在使用前先判断是否插入了存储卡,如果不存在则不于计算

运行截图:

程序结构

package com.example.asus.gary_024;

import android.os.Environment;
import android.os.StatFs;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.ProgressBar;
import android.widget.TextView; import java.io.File;
import java.text.DecimalFormat; public class MainActivity extends AppCompatActivity {
private Button myButton;
private ProgressBar myProgressBar;
private TextView myTextView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
myButton = (Button)findViewById(R.id.mybutton);
myProgressBar = (ProgressBar)findViewById(R.id.myprogressBar);
myTextView = (TextView)findViewById(R.id.mytextView); myButton.setOnClickListener(new Button.OnClickListener()
{ @Override
public void onClick(View v) {
showSize();
}
});
} private void showSize(){
//将TextView及ProgressBar设置空及为0
myTextView.setText("");
myProgressBar.setProgress(0); //判断储存卡是否插入
if(Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED))
{
//将取得SD CARD文件路径一般是/sdcard
File path = Environment.getExternalStorageDirectory();
//通过StatFs看文件系统空间使用状况
StatFs statFs = new StatFs(path.getPath());
//Block数量
long blockSize = statFs.getBlockSize();
//总Block数量
long totalBlocks = statFs.getBlockCount();
//已使用的Block数量
long availableBlocks = statFs.getAvailableBlocks();
String[] total = fileSize(totalBlocks*blockSize);
String[] available=fileSize(availableBlocks*blockSize);
//使用getMax取得在main.xml里设置的ProgressBar最大值
int ss = Integer.parseInt(available[0])*myProgressBar.getMax()/Integer.parseInt(total[0]); myProgressBar.setProgress(ss);
String text = "总共"+total[0]+total[1]+"\n";
text+="可用"+available[0]+available[1];
myTextView.setText(text);
}else if(Environment.getExternalStorageState().equals(
Environment.MEDIA_REMOVED)){
String text = "SD CARD已删除";
myTextView.setText(text);
}
}
//返回为字符串数组[0]的大小为[1]\单位为KB或MB
private String[] fileSize(long size)
{
String str = "";
size /=1024;
if(size>=1024)
{
str = "KB";
size/=1024;
if(size>=1024)
{
str = "MB";
size/=1024;
}
}
DecimalFormat formatter = new DecimalFormat();
//每3个数字分隔,如1,000
formatter.setGroupingSize(3);
String result[] = new String[2];
result[0] = formatter.format(size);
result[1]=str;
return result;
} }

MainActivity

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context="com.example.asus.gary_024.MainActivity"> <TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Gary_获得手机存储卡的容量"
android:textSize="40px" /> <Button
android:id="@+id/mybutton"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="存储卡容量" /> <TextView
android:id="@+id/mytextView"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textSize="40px" /> <ProgressBar
android:id="@+id/myprogressBar"
style="?android:attr/progressBarStyleHorizontal"
android:max="100"
android:layout_width="match_parent"
android:layout_height="wrap_content" /> </LinearLayout>

activity_main.xml

一、界面布局

  一个Button按钮,一个TextView文本框和一个ProgressBar Widget控件

  点击Button按钮,在TextView文本框上显示手机卡的容量和手机卡剩余容量的大小,在ProgressBar Widget控件中能更好的显示容量,使显示效果一目了然

二、实现程序功能

1、添加Button按钮的单机事件响应机制,当点击Button按钮监听事件setOnClickListener时,调用showSize()显示存储卡的剩余容量

  protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
myButton = (Button)findViewById(R.id.mybutton);
myProgressBar = (ProgressBar)findViewById(R.id.myprogressBar);
myTextView = (TextView)findViewById(R.id.mytextView); myButton.setOnClickListener(new Button.OnClickListener()
{ @Override
public void onClick(View v) {
showSize();
}
});
}

2、定义showSize()方法来显示存储卡的容量大小,具体实现流程如下

  分别设置TextView和ProgressBarw为空值

  获取SD CARD文件路径

  通过StatFs来查看文件系统控件使用情况

  分别获取总的Block数量和已使用的Block数量

  通过getMax获取在activity_main.xml中设置ProgressBar的最大值

  显示容量信息

  如果没有SD卡则输出"SD CARD已删除"提示

  private void showSize(){
//将TextView及ProgressBar设置空及为0
myTextView.setText("");
myProgressBar.setProgress(0); //判断储存卡是否插入
if(Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED))
{
//将取得SD CARD文件路径一般是/sdcard
File path = Environment.getExternalStorageDirectory();
//通过StatFs看文件系统空间使用状况
StatFs statFs = new StatFs(path.getPath());
//Block数量
long blockSize = statFs.getBlockSize();
//总Block数量
long totalBlocks = statFs.getBlockCount();
//已使用的Block数量
long availableBlocks = statFs.getAvailableBlocks();
String[] total = fileSize(totalBlocks*blockSize);
String[] available=fileSize(availableBlocks*blockSize);
//使用getMax取得在main.xml里设置的ProgressBar最大值
int ss = Integer.parseInt(available[0])*myProgressBar.getMax()/Integer.parseInt(total[0]); myProgressBar.setProgress(ss);
String text = "总共"+total[0]+total[1]+"\n";
text+="可用"+available[0]+available[1];
myTextView.setText(text);
}else if(Environment.getExternalStorageState().equals(
Environment.MEDIA_REMOVED)){
String text = "SD CARD已删除";
myTextView.setText(text);
}

3、在获取文件大小默认是字节,可以调用fileSize()来进行进制大小转换

  //返回为字符串数组[0]的大小为[1]\单位为KB或MB
private String[] fileSize(long size)
{
String str = "";
size /=1024;
if(size>=1024)
{
str = "KB";
size/=1024;
if(size>=1024)
{
str = "MB";
size/=1024;
}
}
DecimalFormat formatter = new DecimalFormat();
//每3个数字分隔,如1,000
formatter.setGroupingSize(3);
String result[] = new String[2];
result[0] = formatter.format(size);
result[1]=str;
return result;
}

备注:

在使用Android模拟器时,可以使用FAT32格式的磁盘镜像作为SD卡的模拟,具体实现过程如下:

Step1: 进入Android SDK目录文件下的tools子目录,运行如下命令

mksdcard -1 sdcard 512M/your_path_for_img/sdcard.img
入这样就可以创建了一个512MB的SD卡镜像文件
 
Step2: 在运行模拟器狮指定模拟存储卡路径,注意需要使用完整路径
 
emulator -sdcard/your_path_for_img/sdcard.img
 
在此时模拟器中就可以使用"/sdcard"这个路径来指向模拟的SD卡了。
 
在使用mksdcard命令时需要注意如下6点。
 
1)mycard命令可以使用3种尺寸:字节、KB和MB。如果只使用数字,表示字节。后面跟K,如262144K,表示262144KB,也可写为256M
 
2)mycard建立的虚拟文件最小为8MB,也就是说,模拟器只支持大于8MB的虚拟文件
 
3)-l命令行参数表示虚拟磁盘的卷标,可以没有该参数
 
4)虚拟文件的拓展名可以是任意的,如mycard.abc
 
5)mksdcard命令不会自动创建不存在的目录,因此,在执行上面的命令之前,要先在当前目录种创建一个card目录
 
6)mksdcard命令就是按实际大小生成的sdcard虚拟文件。也就是说,生成256MB的虚拟文件的尺寸就是256MB,如果要生成较大的虚拟文件,要看看自己的硬盘控件是否足够
 
执行完上面的命令后,执行下面的命令可以启动Android模拟器。
 
emulator -avd avd1 -sdcard card/mycard img

Android_(自动化)获取手机存储卡的容量的更多相关文章

  1. python+adb实现自动化获取手机信息

    首先我们先看一下使用adb查看Android手机信息的指令 #获取手机名称NAME = 'adb shell getprop ro.product.model'#获取手机版本VERSION = 'ad ...

  2. Android_(传感器)获取手机中的传感器

    传感器是一种检测装置,能够感受被测量的信息,并能将检测和感受到的信息按一定规律变换成电信号或其它所需形式的信息输出 Android操作系统中内置了很多的传感器(物理装置),能够探测.感受外界的信号.物 ...

  3. Android获取全部存储卡挂载路径

    近期因项目需求.须要在存储卡查找文件,经測试发现部分手机挂载路径查找不到,这里分享一个有效的方法. /** * 获取全部存储卡挂载路径 * @return */ public static List& ...

  4. iOS 整理笔记 获取手机信息(UIDevice、NSBundle、NSLocale)

    /*    iOS的APP的应用开发的过程中,有时为了bug跟踪或者获取用反馈的需要自动收集用户设备.系统信息.应用信息等等,这些信息方便开发者诊断问题,当然这些信息是用户的非隐私信息,是通过开发ap ...

  5. 利用RxJava获取手机已安装的App的图片、应用名称和版本号

    先上效果图: 获取手机已安装的App列表利用Android系统API就可以办到,这里为什么要引入RxJava?现在我们假设一下有下面几个需求: 1.我们不需要所有的App,只需要用户安装的第三方App ...

  6. iOS获取手机型号,类似iphone 7这种 含swift和OC

    获取手机设备信息,如name.model.version等,但如果想获取具体的手机型号,如iphone5.5s这种,就需要如下这种 swift: func phonetype () -> Str ...

  7. UI Automator Viewer获取手机镜像时报错

    使用UI Automator Viewer获取手机镜像时报错,具体信息如下: Error while obtaining UI hierarchy XML file: com.android.ddml ...

  8. Android-AsyncTask异步任务(获取手机联系人)

    本篇随笔将讲解一下Android的多线程的知识,以及如何通过AsyncTask机制来实现线程之间的通信. 一.Android当中的多线程 在Android当中,当一个应用程序的组件启动的时候,并且没有 ...

  9. Android 获取手机Mac地址,手机名称

    /** * 获取手机mac地址<br/> * 错误返回12个0 */ public static String getMacAddress(Context context) { // 获取 ...

随机推荐

  1. charles 抓包 (一)

    在web.app开发中经常需要通过抓包来定位页面.接口返回数据的问题.在mac系统中,charles是一款功能丰富的抓包软件.可以实现app的数据抓包. 工具:charles 附送charles的破解 ...

  2. Scala学习五——类

    一.本章要点 类中的字段自动带有getter方法和setter方法 你可以用定制的getter/setter方法替换掉字段的定义,而不必修改使用类的客户端——这就是所谓的”统一访问原则“ 用@Bean ...

  3. 服务端相关知识学习(四)之Zookeeper启动过程

    在上一篇,我们了解了zookeeper最基本的配置,也从中了解一些配置的作用,那么这篇文章中,我们将介绍Zookeeper的启动过程,我们在了解启动过程的时候还要回过头看看上一篇中各个配置参数在启动时 ...

  4. python numpy 的用法——diag函数

    当 np.diag(array) 中 array是一个1维数组时,结果形成一个以一维数组为对角线元素的矩阵 array是一个二维矩阵时,结果输出矩阵的对角线元素

  5. 判断一个数是否为回文数(js)

    //判断是否为回文数:若n=1234321,则称n为一回文数 let readline = require("readline-sync"); let newNum = 0; co ...

  6. java三大框架——Struts + Hibernate + Spring

    Struts主要负责表示层的显示 Spring利用它的IOC和AOP来处理控制业务(负责对数据库的操作) Hibernate主要是数据持久化到数据库 再用jsp的servlet做网页开发的时候有个 w ...

  7. Oracle层次查询start with connect by

    博客参考:https://www.cnblogs.com/jerryxing/articles/2339352.html start with connect by 层次查询(Hierarchical ...

  8. string类的总结

    一.string类头文件:#include <string>;using namespace std; 二.string类方法: 1.获取string的字符串长度:size(),size返 ...

  9. 并发编程:协程TCP、非阻塞IO、多路复用、

    一.线程池实现阻塞IO 二.非阻塞IO模型 三.多路复用,降低CPU占用 四.模拟异步IO 一.线程池实现阻塞IO 线程阻塞IO 客户端 import socket c = socket.socket ...

  10. python面向编程:类继承、继承案例、单继承下属性查找、super方法

    一.类的继承 二.基于继承解决类与类的代码冗余问题 三.在单继承背景下属性的查找 四.super的方法 一.类的继承 1.什么是继承? 在程序中继承是一种新建子类的方法的方式,新创建的类成为子类\派生 ...