xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" > <ProgressBar
android:id="@+id/pb_progress"
style="?android:attr/progressBarStyleHorizontal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="10dp" /> <TextView
android:id="@+id/tv_result"
android:layout_width="match_parent"
android:layout_height="wrap_content" /> <Button
android:id="@+id/btn_start_download"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="10dp"
android:text="下载" /> </LinearLayout>

java:

 import com.yolanda.nohttp.Headers;
import com.yolanda.nohttp.NoHttp;
import com.yolanda.nohttp.download.DownloadListener;
import com.yolanda.nohttp.download.DownloadRequest;
import com.yolanda.nohttp.error.ArgumentError;
import com.yolanda.nohttp.error.ClientError;
import com.yolanda.nohttp.error.NetworkError;
import com.yolanda.nohttp.error.ServerError;
import com.yolanda.nohttp.error.StorageReadWriteError;
import com.yolanda.nohttp.error.StorageSpaceNotEnoughError;
import com.yolanda.nohttp.error.TimeoutError;
import com.yolanda.nohttp.error.URLError;
import com.yolanda.nohttp.error.UnKnownHostError;
import com.yolanda.nohttp5.R;
import com.yolanda.nohttp5.config.AppConfig;
import com.yolanda.nohttp5.nohttp.CallServer;
import com.yolanda.nohttp5.util.Toast; import android.app.Activity;
import android.os.Bundle;
import android.os.Environment;
import android.view.View;
import android.widget.ProgressBar;
import android.widget.TextView; public class DownloadActivity extends Activity implements View.OnClickListener, DownloadListener { private final static String PROGRESS_KEY = "download_progress";
/**
* 下载按钮、暂停、开始等.
*/
private TextView mBtnStart;
/**
* 下载状态.
*/
private TextView mTvResult;
/**
* 下载进度条.
*/
private ProgressBar mProgressBar;
/***
* 下载地址.
*/
private String url = "http://m.apk.67mo.com/apk/999129_21769077_1443483983292.apk";
/**
* 下载请求.
*/
private DownloadRequest downloadRequest; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_download); mProgressBar = (ProgressBar) findViewById(R.id.pb_progress);
mBtnStart = (TextView) findViewById(R.id.btn_start_download);
mTvResult = (TextView) findViewById(R.id.tv_result);
mBtnStart.setOnClickListener(this); // url 下载地址
// fileFolder 保存的文件夹
// fileName 文件名
// isRange 是否断点续传下载
// isDeleteOld 如果发现文件已经存在是否删除后重新下载
String path = Environment.getExternalStorageDirectory().getAbsolutePath();
downloadRequest = NoHttp.createDownloadRequest(url, path, "nohttp.apk", true, false); // 检查已经下载了一半的文件是什么状态
int status = downloadRequest.checkBeforeStatus();
if (status == DownloadRequest.STATUS_FINISH) {// 文件已经下载完成
mTvResult.setText("下载完成");
mBtnStart.setText("已经下载完成");
// ... 提示用户安装apk
} else if (status == DownloadRequest.STATUS_RESTART) {// 代表文件不存在,需要从头下载
mTvResult.setText("");
mBtnStart.setText("下载");
} else if (status == DownloadRequest.STATUS_RESUME) {// 代表文件已经下载了一半了
int progress = AppConfig.getInstance().getInt(PROGRESS_KEY, );
mProgressBar.setProgress(progress);
mTvResult.setText("已经下载了 " + progress + "%");
mBtnStart.setText("继续下载");
}
} @Override
public void onClick(View v) {
if (downloadRequest.isStarted()) {
// 暂停下载
downloadRequest.cancel(true);
} else {
// what 区分下载
// downloadRequest 下载请求对象
// downloadListener 下载监听
CallServer.getDownloadInstance().add(, downloadRequest, this);
}
} /**
* @param what 代表哪一个下载
* @param isResume 是不是断点续续传开始下载的
* @param beforeLenght 断点开始的地方的文件大小
* @param headers 本地请求的时候的响应头
* @param allCount 本次需要下载多少
*/
@Override
public void onStart(int what, boolean isResume, long beforeLenght, Headers headers, long allCount) {
int progress = AppConfig.getInstance().getInt(PROGRESS_KEY, );
mTvResult.setText("已下载: " + progress + "%");
mBtnStart.setText("暂停");
} @Override
public void onProgress(int what, int progress, long fileCount) {
AppConfig.getInstance().putInt(PROGRESS_KEY, progress);
mProgressBar.setProgress(progress);
mTvResult.setText("已经下载了 " + progress + "%");
} @Override
public void onDownloadError(int what, Exception exception) {
mBtnStart.setText("再次尝试"); String message = "下载出错了:";
if (exception instanceof ClientError) {
message += "客户端错误";
} else if (exception instanceof ServerError) {
message += "服务器发生内部错误";
} else if (exception instanceof NetworkError) {
message += "网络不可用,请检查网络";
} else if (exception instanceof StorageReadWriteError) {
message += "存储卡错误,请检查存储卡";
} else if (exception instanceof StorageSpaceNotEnoughError) {
message += "存储位置空间不足";
} else if (exception instanceof TimeoutError) {
message += "下载超时";
} else if (exception instanceof UnKnownHostError) {
message += "服务器找不到";
} else if (exception instanceof URLError) {
message += "url地址错误";
} else if (exception instanceof ArgumentError) {
message += "下载参数错误";
} else {
message += "未知错误";
}
mTvResult.setText(message);
} @Override
public void onFinish(int what, String filePath) {
Toast.show("下载完成");
mTvResult.setText("下载完成,文件保存在:" + filePath);
} @Override
public void onCancel(int what) {
mTvResult.setText("下载暂停");
mBtnStart.setText("继续下载");
} }

NoHttp封装--05 文件下载的更多相关文章

  1. NoHttp封装--03 缓存

    1.Default模式,也是没有设置缓存模式时的默认模式 这个模式实现http协议中的内容,比如响应码是304时,当然还会结合E-Tag和LastModify等头. StringRequest req ...

  2. NoHttp封装--03 cookie

    NoHttp请求自动维持Cookie:   1.支持Session.Cookie.临时Cookie的位置.   2.支持App重启.关机开机后继续持久化维持.   3.提供了接口,允许开发者监听Coo ...

  3. NoHttp封装--02 自定义请求

    bean实体类请求: 1.bean import java.io.Serializable; import com.alibaba.fastjson.annotation.JSONField; pub ...

  4. NoHttp封装--01

    NoHttpActivity public class NoHttpActivity extends Activity implements View.OnClickListener { privat ...

  5. NoHttp封装--08 用一个实体类接收所有接口数据

    1.用户信息获取--bean实体类形式返回数据 ①服务器端: 代码: protected void onHandler(HttpServletRequest request, HttpServletR ...

  6. NoHttp封装--07 自定义异步任务框架

    MainActivity: public class MainActivity extends Activity implements View.OnClickListener { .... @Ove ...

  7. NoHttp封装--06 NoHttp之队列、队列优先级

    public class Main { /** * 程序入口 */ public void start() { // 第一种,先进先出的队列 // YolandaLinkedQueue queue = ...

  8. 一些免费收费api收藏

    转载:http://blog.csdn.net/sdjianfei/article/details/53157334 一 .api 1.http://apistore.baidu.com/astore ...

  9. 移动端开发者福利-免费收费api收藏

    一 .api 1.https://www.juhe.cn/ 跟百度api集市差不多,超级赞,做好认证就行了,我有20+认证能用的免费api 2.http://apistore.baidu.com/as ...

随机推荐

  1. 分布式任务调度系统xxl-job源码探究(二、服务中心)

    接下来看下服务端代码 服务端源码 服务端通过管理quartz定时任务组件,分发任务 先从入口看起,由web.xml进入,可以看出,自己编写的代码从applicationcontext-xxl-job- ...

  2. js中break、continue和return的一般用法总结

    break break :终止break的整个循环体,包括内部所有循环.但对循环体外部的循环不影响. for(let i = 0;i<2;i++){ for(let j = 0;j<2;j ...

  3. jenkins 集成钉钉机器人通知

    公司使用钉钉做为公司内部的通讯工具,所以想通过Jenkins发布完成以后通过钉钉来通知大家,研究发现钉钉提供机器人,所以我把机器人集成进来通知相关人员. 1.创建通知人群组,添加机器人(钉钉默认自带了 ...

  4. vue.js多页面开发环境搭建

    利用 vue-cli 搭建的项目大都是单页面应用项目,对于简单的项目,单页面就能满足要求.但对于有多个子项目的应用,如果创建多个单页面,显示有点重复,特别是 node_modules 会有多份相同的. ...

  5. Hadoop项目实战-用户行为分析之应用概述(三)

    1.概述 本课程的视频教程地址:<项目工程准备> 本节给大家分享的主题如下图所示: 下面我开始为大家分享今天的第三节的内容——<项目工程准备>,接下来开始分享今天的内容. 2. ...

  6. 图文教程 | 开启远程访问mysql数据库权限

     !!!考虑到安全性,不建议使用 所以将指定用户的host改为:% 即可 执行:(以root用户为例) use mysql; update user set host = "%" ...

  7. SQL 必知必会·笔记<15>创建和操纵表

    创建表的两种办法: 使用DBMS 提供的交互式创建和管理数据库表的工具: 直接用SQL 语句创建. 表创建基础 创建表示例: CREATE TABLE Products ( prod_id ) NOT ...

  8. Android中不能在子线程中更新View视图的原因

    这是一条规律,很多coder知道,但原因是什么呢? 如下: When a process is created for your application, its main thread is ded ...

  9. 《剑指offer》内容总结

    (1)剑指Offer——Trie树(字典树) Trie树 Trie树,即字典树,又称单词查找树或键树,是一种树形结构,是一种哈希树的变种.典型应用是统计和排序大量的字符串(但不仅限于字符串),所以经常 ...

  10. API 接口返回值

    API 接口返回值 https://blog.csdn.net/baple/article/details/52925772