0

0

Android开发之简单文件管理器实现方法

高洛峰

高洛峰

发布时间:2017-01-21 14:27:22

|

1517人浏览过

|

来源于php中文网

原创

本文实例讲述了android开发之简单文件管理器实现方法。分享给大家供大家参考,具体如下:

这里运用Java I/O、ListActivity、Dialog、Bitmap等实现简单文件管理器,可以查看目录文件,修改文件名,删除文件,打开文件。比较简单,直接看代码:

先看布局文件:

layout/main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:orientation="vertical"
 android:layout_width="fill_parent"
 android:layout_height="fill_parent"
 >
<ListView
 android:id="@android:id/list"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 />
</LinearLayout>

文件列表布局:

layout/file.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:orientation="horizontal"
 android:layout_width="fill_parent"
 android:layout_height="fill_parent"
 >
<ImageView
 android:id="@+id/imageView"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
/>
<TextView
 android:id="@+id/textView"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:textSize="14sp">
</TextView>
</LinearLayout>

修改文件名对话框布局文件:

layout/rename_dialog.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
 xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="match_parent">
 <EditText
  android:id="@+id/editText"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
 />
</LinearLayout>

主Activity:

public class MainActivity extends ListActivity {
 private static final String ROOT_PATH = "/";
 //存储文件名称
 private ArrayList<String> names = null;
 //存储文件路径
 private ArrayList<String> paths = null;
 private View view;
 private EditText editText;
 /** Called when the activity is first created. */
 @Override
 public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.main);
  //显示文件列表
  showFileDir(ROOT_PATH);
 }
 private void showFileDir(String path){
  names = new ArrayList<String>();
  paths = new ArrayList<String>();
  File file = new File(path);
  File[] files = file.listFiles();
  //如果当前目录不是根目录
  if (!ROOT_PATH.equals(path)){
   names.add("@1");
   paths.add(ROOT_PATH);
   names.add("@2");
   paths.add(file.getParent());
  }
  //添加所有文件
  for (File f : files){
   names.add(f.getName());
   paths.add(f.getPath());
  }
  this.setListAdapter(new MyAdapter(this,names, paths));
 }
 @Override
 protected void onListItemClick(ListView l, View v, int position, long id) {
  String path = paths.get(position);
  File file = new File(path);
  // 文件存在并可读
  if (file.exists() && file.canRead()){
   if (file.isDirectory()){
    //显示子目录及文件
    showFileDir(path);
   }
   else{
    //处理文件
    fileHandle(file);
   }
  }
  //没有权限
  else{
   Resources res = getResources();
   new AlertDialog.Builder(this).setTitle("Message")
   .setMessage(res.getString(R.string.no_permission))
   .setPositiveButton("OK",new OnClickListener() {
    @Override
    public void onClick(DialogInterface dialog, int which) {
    }
   }).show();
  }
  super.onListItemClick(l, v, position, id);
 }
 //对文件进行增删改
 private void fileHandle(final File file){
  OnClickListener listener = new DialogInterface.OnClickListener() {
   @Override
   public void onClick(DialogInterface dialog, int which) {
    // 打开文件
    if (which == 0){
     openFile(file);
    }
    //修改文件名
    else if(which == 1){
     LayoutInflater factory = LayoutInflater.from(MainActivity.this);
     view = factory.inflate(R.layout.rename_dialog, null);
     editText = (EditText)view.findViewById(R.id.editText);
     editText.setText(file.getName());
     OnClickListener listener2 = new DialogInterface.OnClickListener() {
      @Override
      public void onClick(DialogInterface dialog, int which) {
       // TODO Auto-generated method stub
       String modifyName = editText.getText().toString();
       final String fpath = file.getParentFile().getPath();
       final File newFile = new File(fpath + "/" + modifyName);
       if (newFile.exists()){
        //排除没有修改情况
        if (!modifyName.equals(file.getName())){
         new AlertDialog.Builder(MainActivity.this)
         .setTitle("注意!")
         .setMessage("文件名已存在,是否覆盖?")
         .setPositiveButton("确定", new DialogInterface.OnClickListener() {
          @Override
          public void onClick(DialogInterface dialog, int which) {
           if (file.renameTo(newFile)){
            showFileDir(fpath);
            displayToast("重命名成功!");
           }
           else{
            displayToast("重命名失败!");
           }
          }
         })
         .setNegativeButton("取消", new DialogInterface.OnClickListener() {
          @Override
          public void onClick(DialogInterface dialog, int which) {
          }
         })
         .show();
        }
       }
       else{
        if (file.renameTo(newFile)){
         showFileDir(fpath);
         displayToast("重命名成功!");
        }
        else{
         displayToast("重命名失败!");
        }
       }
      }
     };
     AlertDialog renameDialog = new AlertDialog.Builder(MainActivity.this).create();
     renameDialog.setView(view);
     renameDialog.setButton("确定", listener2);
     renameDialog.setButton2("取消", new DialogInterface.OnClickListener() {
      @Override
      public void onClick(DialogInterface dialog, int which) {
       // TODO Auto-generated method stub
      }
     });
     renameDialog.show();
    }
    //删除文件
    else{
     new AlertDialog.Builder(MainActivity.this)
     .setTitle("注意!")
     .setMessage("确定要删除此文件吗?")
     .setPositiveButton("确定", new DialogInterface.OnClickListener() {
      @Override
      public void onClick(DialogInterface dialog, int which) {
       if(file.delete()){
        //更新文件列表
        showFileDir(file.getParent());
        displayToast("删除成功!");
       }
       else{
        displayToast("删除失败!");
       }
      }
     })
     .setNegativeButton("取消", new DialogInterface.OnClickListener() {
      @Override
      public void onClick(DialogInterface dialog, int which) {
      }
     }).show();
    }
   }
  };
  //选择文件时,弹出增删该操作选项对话框
  String[] menu = {"打开文件","重命名","删除文件"};
  new AlertDialog.Builder(MainActivity.this)
  .setTitle("请选择要进行的操作!")
  .setItems(menu, listener)
  .setPositiveButton("取消", new DialogInterface.OnClickListener() {
   @Override
   public void onClick(DialogInterface dialog, int which) {
   }
  }).show();
 }
 //打开文件
 private void openFile(File file){
  Intent intent = new Intent();
  intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
  intent.setAction(android.content.Intent.ACTION_VIEW);
  String type = getMIMEType(file);
  intent.setDataAndType(Uri.fromFile(file), type);
  startActivity(intent);
 }
 //获取文件mimetype
 private String getMIMEType(File file){
  String type = "";
  String name = file.getName();
  //文件扩展名
  String end = name.substring(name.lastIndexOf(".") + 1, name.length()).toLowerCase();
  if (end.equals("m4a") || end.equals("mp3") || end.equals("wav")){
   type = "audio";
  }
  else if(end.equals("mp4") || end.equals("3gp")) {
   type = "video";
  }
  else if (end.equals("jpg") || end.equals("png") || end.equals("jpeg") || end.equals("bmp") || end.equals("gif")){
   type = "image";
  }
  else {
   //如果无法直接打开,跳出列表由用户选择
   type = "*";
  }
  type += "/*";
  return type;
 }
 private void displayToast(String message){
  Toast.makeText(MainActivity.this, message, Toast.LENGTH_SHORT).show();
 }
}

 

自定义适配器:

public class MyAdapter extends BaseAdapter{
 private LayoutInflater inflater;
 private Bitmap directory,file;
 //存储文件名称
 private ArrayList<String> names = null;
 //存储文件路径
 private ArrayList<String> paths = null;
 //参数初始化
 public MyAdapter(Context context,ArrayList<String> na,ArrayList<String> pa){
  names = na;
  paths = pa;
  directory = BitmapFactory.decodeResource(context.getResources(),R.drawable.d);
  file = BitmapFactory.decodeResource(context.getResources(),R.drawable.f);
  //缩小图片
  directory = small(directory,0.16f);
  file = small(file,0.1f);
  inflater = LayoutInflater.from(context);
 }
 @Override
 public int getCount() {
  // TODO Auto-generated method stub
  return names.size();
 }
 @Override
 public Object getItem(int position) {
  // TODO Auto-generated method stub
  return names.get(position);
 }
 @Override
 public long getItemId(int position) {
  // TODO Auto-generated method stub
  return position;
 }
 @Override
 public View getView(int position, View convertView, ViewGroup parent) {
  // TODO Auto-generated method stub
  ViewHolder holder;
  if (null == convertView){
   convertView = inflater.inflate(R.layout.file, null);
   holder = new ViewHolder();
   holder.text = (TextView)convertView.findViewById(R.id.textView);
   holder.image = (ImageView)convertView.findViewById(R.id.imageView);
   convertView.setTag(holder);
  }
  else {
   holder = (ViewHolder)convertView.getTag();
  }
  File f = new File(paths.get(position).toString());
  if (names.get(position).equals("@1")){
   holder.text.setText("/");
   holder.image.setImageBitmap(directory);
  }
  else if (names.get(position).equals("@2")){
   holder.text.setText("..");
   holder.image.setImageBitmap(directory);
  }
  else{
   holder.text.setText(f.getName());
   if (f.isDirectory()){
    holder.image.setImageBitmap(directory);
   }
   else if (f.isFile()){
    holder.image.setImageBitmap(file);
   }
   else{
    System.out.println(f.getName());
   }
  }
  return convertView;
 }
 private class ViewHolder{
  private TextView text;
  private ImageView image;
 }
 private Bitmap small(Bitmap map,float num){
  Matrix matrix = new Matrix();
  matrix.postScale(num, num);
  return Bitmap.createBitmap(map,0,0,map.getWidth(),map.getHeight(),matrix,true);
 }
}

  

多奥淘宝客程序API免费版 F8.0
多奥淘宝客程序API免费版 F8.0

多奥淘宝客程序免费版拥有淘宝客站点的基本功能,手动更新少,管理简单等优点,适合刚接触网站的淘客们,或者是兼职做淘客们。同样拥有VIP版的模板引擎技 术、强大的文件缓存机制,但没有VIP版的伪原创跟自定义URL等多项创新的搜索引擎优化技术,除此之外也是一款高效的API数据系统实现无人值守全自动 化运行的淘宝客网站程序。4月3日淘宝联盟重新开放淘宝API申请,新用户也可使用了

下载

因为要对文件进行操作,所以在描述文件中授权:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
  package="com.test.filemanager"
  android:versionCode="1"
  android:versionName="1.0">
 <uses-sdk android:minSdkVersion="10" />
 <strong> <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>
 <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/></strong>
 <application android:icon="@drawable/icon" android:label="@string/app_name">
  <activity android:name=".MainActivity"
     android:label="@string/app_name">
   <intent-filter>
    <action android:name="android.intent.action.MAIN" />
    <category android:name="android.intent.category.LAUNCHER" />
   </intent-filter>
  </activity>
 </application>
</manifest>

运行结果如下:

查看目录文件

Android开发之简单文件管理器实现方法

文件重命名:

Android开发之简单文件管理器实现方法

删除文件:

Android开发之简单文件管理器实现方法

打开文件:

Android开发之简单文件管理器实现方法

希望本文所述对大家Android程序设计有所帮助。

更多Android开发之简单文件管理器实现方法相关文章请关注PHP中文网!

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

705

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

233

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

117

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

22

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

61

2026.02.13

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

30

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

15

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

669

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

58

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
【web前端】Node.js快速入门
【web前端】Node.js快速入门

共16课时 | 2.1万人学习

ThinkPHP6.x 微实战--十天技能课堂
ThinkPHP6.x 微实战--十天技能课堂

共26课时 | 1.8万人学习

Vue.js 微实战--十天技能课堂
Vue.js 微实战--十天技能课堂

共18课时 | 1.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号