热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Android实现文件解压带进度条功能

本文通过实例代码给大家介绍了android实现文件解压带进度条效果,代码简单易懂,非常不错,具有参考借鉴价值,需要的朋友参考下吧

解压的工具类

package com.example.videodemo.zip; 
public class ZipProgressUtil { 
  /*** 
   * 解压通用方法 
   * 
   * @param zipFileString 
   *      文件路径 
   * @param outPathString 
   *      解压路径 
   * @param listener 
   *      加压监听 
   */ 
  public static void UnZipFile(final String zipFileString, final String outPathString, final ZipListener listener) { 
    Thread zipThread = new UnZipMainThread(zipFileString, outPathString, listener); 
    zipThread.start(); 
  } 
  public interface ZipListener { 
    /** 开始解压 */ 
    void zipStart(); 
    /** 解压成功 */ 
    void zipSuccess(); 
    /** 解压进度 */ 
    void zipProgress(int progress); 
    /** 解压失败 */ 
    void zipFail(); 
  } 
} 

解压线程

package com.example.videodemo.zip; 
import java.io.File; 
import java.io.FileInputStream; 
import java.io.FileOutputStream; 
import java.io.IOException; 
import java.util.Enumeration; 
import java.util.zip.ZipEntry; 
import java.util.zip.ZipFile; 
import java.util.zip.ZipInputStream; 
import com.example.videodemo.zip.ZipProgressUtil.ZipListener; 
public class UnZipMainThread extends Thread { 
  String zipFileString; 
  String outPathString; 
  ZipListener listener; 
  public UnZipMainThread(String zipFileString, String outPathString, ZipListener listener) { 
    this.zipFileString = zipFileString; 
    this.outPathString = outPathString; 
    this.listener = listener; 
  } 
  @Override 
  public void run() { 
    super.run(); 
    try { 
      listener.zipStart(); 
      long sumLength = 0; 
      // 获取解压之后文件的大小,用来计算解压的进度 
      long ziplength = getZipTrueSize(zipFileString); 
      System.out.println("====文件的大小==" + ziplength); 
      FileInputStream inputStream = new FileInputStream(zipFileString); 
      ZipInputStream inZip = new ZipInputStream(inputStream); 
      ZipEntry zipEntry; 
      String szName = ""; 
      while ((zipEntry = inZip.getNextEntry()) != null) { 
        szName = zipEntry.getName(); 
        if (zipEntry.isDirectory()) { 
          szName = szName.substring(0, szName.length() - 1); 
          File folder = new File(outPathString + File.separator + szName); 
          folder.mkdirs(); 
        } else { 
          File file = new File(outPathString + File.separator + szName); 
          file.createNewFile(); 
          FileOutputStream out = new FileOutputStream(file); 
          int len; 
          byte[] buffer = new byte[1024]; 
          while ((len = inZip.read(buffer)) != -1) { 
            sumLength += len; 
            int progress = (int) ((sumLength * 100) / ziplength); 
            updateProgress(progress, listener); 
            out.write(buffer, 0, len); 
            out.flush(); 
          } 
          out.close(); 
        } 
      } 
      listener.zipSuccess(); 
      inZip.close(); 
    } catch (Exception e) { 
      listener.zipFail(); 
    } 
  } 
  int lastProgress = 0; 
  private void updateProgress(int progress, ZipListener listener2) { 
    /** 因为会频繁的刷新,这里我只是进度>1%的时候才去显示 */ 
    if (progress > lastProgress) { 
      lastProgress = progress; 
      listener2.zipProgress(progress); 
    } 
  } 
  /** 
   * 获取压缩包解压后的内存大小 
   * 
   * @param filePath 
   *      文件路径 
   * @return 返回内存long类型的值 
   */ 
  public long getZipTrueSize(String filePath) { 
    long size = 0; 
    ZipFile f; 
    try { 
      f = new ZipFile(filePath); 
      Enumeration<&#63; extends ZipEntry> en = f.entries(); 
      while (en.hasMoreElements()) { 
        size += en.nextElement().getSize(); 
      } 
    } catch (IOException e) { 
      e.printStackTrace(); 
    } 
    return size; 
  } 
} 

界面调用方法.我使用的是静态的方法,方便,可以改成非静态的.看个人需求,//注意了,因为解压是放在线程中执行的,所以界面刷新的话,需要使用handler来刷新界面调用还是比较方便的

注意 :调用的方法传入的路径:

        1:是压缩文件的全路径   /storage/reeman/1234.zip

         2:解压文件的路径(非全路径)   /storage/reeman/zip

package com.example.videodemo; 
import com.example.videodemo.zip.ZipProgressUtil; 
import com.example.videodemo.zip.ZipProgressUtil.ZipListener; 
import android.app.Activity; 
import android.os.Bundle; 
import android.widget.ProgressBar; 
public class MainActivity extends Activity { 
  private ProgressBar progressBar1; 
  @Override 
  protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    progressBar1 = (ProgressBar) findViewById(R.id.progressBar1); 
    ZipProgressUtil.UnZipFile("解压文件的路径", "解压之后的路径", new ZipListener() { 
      public void zipSuccess() { 
      } 
      public void zipStart() { 
      } 
      public void zipProgress(int progress) { 
      } 
      public void zipFail() { 
      } 
    }); 
  } 
} 

总结

以上所述是小编给大家介绍的Android实现文件解压带进度条功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


推荐阅读
  • C#设计模式学习笔记:观察者模式解析
    本文将探讨观察者模式的基本概念、应用场景及其在C#中的实现方法。通过借鉴《Head First Design Patterns》和维基百科等资源,详细介绍该模式的工作原理,并提供具体代码示例。 ... [详细]
  • 本文详细介绍了划分树这一数据结构,重点探讨了其在子树和中值计算中的应用及优化方法。 ... [详细]
  • 本文详细探讨了Android Activity中View的绘制流程和动画机制,包括Activity的生命周期、View的测量、布局和绘制过程以及动画对View的影响。通过实验验证,澄清了一些常见的误解,并提供了代码示例和执行结果。 ... [详细]
  • 本文探讨了在构建应用程序时,如何对不同类型的数据进行结构化设计。主要分为三类:全局配置、用户个人设置和用户关系链。每种类型的数据都有其独特的用途和应用场景,合理规划这些数据结构有助于提升用户体验和系统的可维护性。 ... [详细]
  • 在 Android 开发中,通过 Intent 启动 Activity 或 Service 时,可以使用 putExtra 方法传递数据。接收方可以通过 getIntent().getExtras() 获取这些数据。本文将介绍如何使用 RoboGuice 框架简化这一过程,特别是 @InjectExtra 注解的使用。 ... [详细]
  • Linux中的yum安装软件
    yum俗称大黄狗作用:解决安装软件包的依赖关系当安装依赖关系的软件包时,会将依赖的软件包一起安装。本地yum:需要yum源,光驱挂载。yum源:(刚开始查看yum源中的内容就是上图 ... [详细]
  • 鼠标悬停出现提示信息怎么做
    概述–提示:指启示,提起注意或给予提醒和解释。在excel中会经常用到给某个格子增加提醒信息,比如金额提示输入数值或最大长度值等等。设置方式也有多种,简单的,仅为单元格插入批注就可 ... [详细]
  • 本文将详细介绍多个流行的 Android 视频处理开源框架,包括 ijkplayer、FFmpeg、Vitamio、ExoPlayer 等。每个框架都有其独特的优势和应用场景,帮助开发者更高效地进行视频处理和播放。 ... [详细]
  • 气象对比分析
    本文探讨了不同地区和时间段的天气模式,通过详细的图表和数据分析,揭示了气候变化的趋势及其对环境和社会的影响。 ... [详细]
  • 本文探讨了如何利用NFC技术,将存储在Android手机中的患者信息安全高效地传输到台式计算机。重点介绍了适用于医院场景的NFC USB读卡器(如ACR122U)的应用方法。 ... [详细]
  • 探讨 HDU 1536 题目,即 S-Nim 游戏的博弈策略。通过 SG 函数分析游戏胜负的关键,并介绍如何编程实现解决方案。 ... [详细]
  • 本文回顾了2017年的转型和2018年的收获,分享了几家知名互联网公司提供的工作机会及面试体验。 ... [详细]
  • 深入解析动态代理模式:23种设计模式之三
    在设计模式中,动态代理模式是应用最为广泛的一种代理模式。它允许我们在运行时动态创建代理对象,并在调用方法时进行增强处理。本文将详细介绍动态代理的实现机制及其应用场景。 ... [详细]
  • 深入理解ExtJS:从入门到精通
    本文详细介绍了ExtJS的功能及其在大型企业前端开发中的应用。通过实例和详细的文件结构解析,帮助初学者快速掌握ExtJS的核心概念,并提供实用技巧和最佳实践。 ... [详细]
  • Python中HOG图像特征提取与应用
    本文介绍如何在Python中使用HOG(Histogram of Oriented Gradients)算法进行图像特征提取,探讨其在目标检测中的应用,并详细解释实现步骤。 ... [详细]
author-avatar
钟z4z萍
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有