手机上的存储卡是可以随时插拔的,每次插拔时会像操作系统总发送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. Scala学习九——文件和正则表达式

    一.本章要点 Source.fromFile(...).getLines.toArray输出文件的所有行; Source.fromFile(...).mkString以字符串形式输出文件内容; 将字符 ...

  2. Scala学习八——继承

    一.本章要点 extends,final关键字和Java一样 重写方法时必须使用override 只有主构造器可以调用超类的构造器 可以重写字段 二.扩展类 Scala扩展类和Java一样(使用ext ...

  3. 【原创】大数据基础之Kudu(6)kudu tserver内存占用统计分析

    kudu tserver占用内存过高后会拒绝部分写请求,日志如下: 19/06/01 13:34:12 INFO AsyncKuduClient: Invalidating location 34b1 ...

  4. 移动端真机debug调试神器 vConsole学习(二)之实战

    项目中实际使用 在项目中实际使用的时候发现还是有很多问题的 最初使用方式  <script src="vconsole.min.js"></script> ...

  5. O045、理解 Cinder 架构

    参考https://www.cnblogs.com/CloudMan6/p/5573159.html   从本节开始我们学习OpenStack 的 Block Storage Service ,Cin ...

  6. js之数据类型(对象类型——构造器对象——函数1)

    函数它只定义一次,但可能被多次的执行和调用.JavaScript函数是参数化的,函数的定义会包括形参和实参.形参相当于函数中定义的变量,实参是在运行函数调用时传入的参数. 一.函数定义 函数使用fun ...

  7. Docker 备忘

    C/S架构: 客户端发出命令给服务器端(内含守护进程),守护进程执行命令后将结果传回给客户端.(可以远程访问,可以本地访问) 容器内部操作: 可写层下面都是只读的,操作时需要什么文件会被复制到可写层, ...

  8. JavaWeb【七、JSP状态管理】

    http协议无状态性 当提交请求,服务器返回响应.但当同一用户同一浏览器再次提交请求,服务器并不知道与刚才的请求是同一用户浏览器发起. 保存用户状态的两大机制 Session-保存在服务器端 Cook ...

  9. fastadmin 随笔 刷新表格数据 获取当前登录人信息 服务端导出Excel

    table.bootstrapTable('refresh',{url:'你的url'}); 获取当前登录人信息 $this->auth就能获取当前用户信息,比如$this->auth-& ...

  10. 语义分割之车道线检测Lanenet(tensorflow版)

    Lanenet 一个端到端的网络,包含Lanenet+HNet两个网络模型,其中,Lanenet完成对车道线的实例分割,HNet是一个小网络结构,负责预测变换矩阵H,使用转换矩阵H对同属一条车道线的所 ...