Android中调用系统的文件浏览器及自制简单的文件浏览器

调用系统自带的文件浏览器
这很简单:

/** 调用文件选择软件来选择文件 **/
private void showFileChooser() {
  intent = new Intent(Intent.ACTION_GET_CONTENT);
  intent.setType("*/*");
  intent.addCategory(Intent.CATEGORY_OPENABLE);
  try {
    startActivityForResult(Intent.createChooser(intent, "请选择一个要上传的文件"),
        FILE_SELECT_CODE);
  } catch (android.content.ActivityNotFoundException ex) {
    // Potentially direct the user to the Market with a Dialog
    Toast.makeText(getActivity(), "请安装文件管理器", Toast.LENGTH_SHORT)
        .show();
  }
}

在catch,我们可以做更多的操作,比如会跳转到一个下载文件管理器的页面或者等等。

对于返回的数据怎么处理呢。我项目中的上传是如下接收:

/** 根据返回选择的文件,来进行上传操作 **/
  @Override
  public void onActivityResult(int requestCode, int resultCode, Intent data) {
    // TODO Auto-generated method stub
    if (resultCode == Activity.RESULT_OK) {
      // Get the Uri of the selected file
      Uri uri = data.getData();
      String url;
      try {
        url = FFileUtils.getPath(getActivity(), uri);
        Log.i("ht", "url" + url);
        String fileName = url.substring(url.lastIndexOf("/") + 1);
        intent = new Intent(getActivity(), UploadServices.class);
        intent.putExtra("fileName", fileName);
        intent.putExtra("url", url);
        intent.putExtra("type ", "");
        intent.putExtra("fuid", "");
        intent.putExtra("type", ""); 

        getActivity().startService(intent); 

      } catch (URISyntaxException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
      }
    }
    super.onActivityResult(requestCode, resultCode, data);
  }


自制文件浏览器:
这里只加一些简单的图形:

来看代码:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:orientation="vertical"
  android:layout_gravity="center_horizontal"
  tools:context=".MainActivity" > 

  <TextView
    android:id="@+id/txt1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" />
  <ImageButton
    android:id="@+id/imageBt1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:src="@drawable/home"/> 

  <ListView
    android:id="@+id/listFile"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" >
  </ListView> 

</LinearLayout>
<?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"
  android:orientation="horizontal" > 

  <ImageView
    android:id="@+id/images"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" /> 

  <TextView
    android:id="@+id/txtview"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" /> 

</LinearLayout>
package com.android.xiong.sdfilelook; 

import java.io.File;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import android.app.Activity;
import android.os.Bundle;
import android.os.Environment;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ImageButton;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.TextView; 

public class MainActivity extends Activity { 

  private ListView listfile;
  //当前文件目录
  private String currentpath;
  private TextView txt1;
  private ImageView images;
  private TextView textview;
  private ImageButton imagebt1; 

  private int[] img = { R.drawable.file, R.drawable.folder, R.drawable.home };
  private File[] files;
  private SimpleAdapter simple; 

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    listfile = (ListView) findViewById(R.id.listFile);
    txt1 = (TextView) findViewById(R.id.txt1);
    imagebt1 = (ImageButton) findViewById(R.id.imageBt1);
    init(Environment.getExternalStorageDirectory());
    listfile.setOnItemClickListener(new OnItemClickListener() { 

      @Override
      public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,
          long arg3) {
        // TODO Auto-generated method stub
        // 获取单击的文件或文件夹的名称
        String folder = ((TextView) arg1.findViewById(R.id.txtview))
            .getText().toString();
        try {
          File filef = new File(currentpath + '/'
              + folder);
          init(filef); 

        } catch (Exception e) {
          e.printStackTrace();
        } 

      }
    });
    //回根目录
    imagebt1.setOnClickListener(new OnClickListener() { 

      @Override
      public void onClick(View v) {
        init(Environment.getExternalStorageDirectory());
      }
    }); 

  }
  // 界面初始化
  public void init(File f) {
    if (Environment.getExternalStorageState().equals(
        Environment.MEDIA_MOUNTED)) {
      // 获取SDcard目录下所有文件名
      files = f.listFiles();
      if (!files.equals(null)) {
        currentpath=f.getPath();
        txt1.setText("当前目录为:"+f.getPath());
        List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
        for (int i = 0; i < files.length; i++) {
          Map<String, Object> maps = new HashMap<String, Object>();
          if (files[i].isFile())
            maps.put("image", img[0]);
          else
            maps.put("image", img[1]);
          maps.put("filenames", files[i].getName());
          list.add(maps);
        }
        simple = new SimpleAdapter(this, list,
            R.layout.fileimageandtext, new String[] { "image",
                "filenames" }, new int[] { R.id.images,
                R.id.txtview });
        listfile.setAdapter(simple); 

      }
    } else {
      System.out.println("该文件为空");
    }
  } 

  @Override
  public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
  } 

} 
(0)

相关推荐

  • Android实现图片浏览器示例

    本文所述为一个基础的Android图片浏览器代码,是仿写Google原版实现的,代码中实现了主要的实现过程和方法,具体的完善还需要自己添加,代码中有很多注释,可帮助新手们快速理解代码,使用了部分图像资源. 主要功能代码如下: package com.android.coding; import android.app.Activity; import android.content.Context; import android.os.Bundle; import android.view.Vi

  • 使用Chrome浏览器调试Android App详解

    个人一直对Chrome情有独钟,Chrome除了更快之外,对开发者的支持更友好.内置强大的Developer Tools,相信Web开发简直爱不释手!而且Chrome Store里提供各种各样的插件,没有你用不到,只有你想不到.现在任何事基本Chrome全部办的到,有时候就在想,如果可以用Chrome调试Android App该多方便,而如今Facebook刚刚开源了一个工具Stetho,从此Chrome调试Android不再是梦. 调试工具 在Android开发中除了一些官方自带的一些调试工具

  • Android编写文件浏览器简单实现

    有时候我们保存文件总会用到文件浏览器功能.那么今天博主带大家做一个. 那么开始,浏览文件,我们就需要写一个文件工具类. import java.io.File; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import android.util.Log; public class FileUtils { /** * 获取当前目录下的所有文件或文

  • JS辨别访问浏览器判断是android还是ios系统

    项目中需要扫描二维码之后自动分辨出是android还是ios系统,针对于不同的系统进行不同的下载. <script type="text/javascript"> /* * 智能机浏览器版本信息: * */ var browser = { versions: function() { var u = navigator.userAgent, app = navigator.appVersion; return {//移动终端浏览器版本信息 trident: u.indexO

  • android 浏览器之多窗口方案详解

    我们Android平台是一个又一个的Activity组成的,每一个Activity有一个或者多个View构成.所以说,当我们想显示一个界面的时候,我们首先想到的是建立一个Activity,然后所有的操作在Activity里面实现,或者是一个Dialog或者Toast.这种方式固然简单,但是在有些情况下,我们要求的只是简单的显示,用Activity显然是多余,这个时候,我们如何处理呢? Android的一个应用在底层也是linux的一个进程,但在上层弱化了进程的概念,抽象出了Activity这样一

  • 微信或手机浏览器在线显示office文件(已测试ios、android)

    最近开发微信企业号,发现微信andriod版内置浏览器在打开文件方面有问题,但是ios版没有问题,原因是ios版使用的是safari浏览器 支持文档直接打开,但是andriod版使用的是腾讯浏览器x5内核,不知道什么原因不支持,可能是集成出现的问题,这里提供解决方法,这种方法也同样适用手机浏览器或者安卓开发.通过此方法可以在微信上开发自己的第三方应用,或者解决自己的项目问题,解决方法及核心代码如下: 1.判断浏览器类型 HttpServletRequest req = ServletAction

  • android webview 简单浏览器实现代码

    文件main.java 复制代码 代码如下: package com.HHBrowser.android;import android.app.Activity;import android.os.Bundle;import android.os.Handler;import android.util.Log;import android.view.View;import android.webkit.WebView;import android.webkit.WebViewClient;imp

  • Android和IOS的浏览器中检测是否安装某个客户端的方法

    我们希望更多的用户用我们的产品,更希望能留住更多的用户.这个时候让用户使用客户端的意义就变得格外重要了. 毕竟客户端是实实在在的占据了用户的桌面,每天或多或少都会看到我们的产品.然后,作为手机端的Web产品,用户通过手机浏览器访问到了我们的页面,我们就希望用户能直接使用或者下载我们的客户端产品了.最后就有了下载Banner一说. IOS 说到IOS,非常兴奋的是,自IOS6开始,我们只需要在html里加上meta标签就可以了.具体的meta标签是:<meta name="apple-itu

  • Android调用默认浏览器打开指定Url的方法实例

    复制代码 代码如下: package com.gzz.whyinzi; import android.net.Uri;import android.os.Bundle;import android.app.Activity;import android.content.Intent;import android.util.Log;import android.view.Menu;import android.view.View; public class MainActivity extends

  • Android调用系统默认浏览器访问的方法

    一.启动android默认浏览器 这样子,android就可以调用起手机默认的浏览器访问. 二.指定相应的浏览器访问 1.指定android自带的浏览器访问 ( "com.android.browser":packagename :"com.android.browser.BrowserActivity":启动主activity) Intent intent= new Intent(); intent.setAction("android.intent.a

随机推荐