Android DownloadManager下载状态查询(2)

2023-12-22 22:32

本文主要是介绍Android DownloadManager下载状态查询(2),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!



Android DownloadManager下载状态查询(2)

在我写的前一篇文章中,
《Android大数据、断点续传、耗时下载之DownloadManager开发简介(1)》
文章链接地址:http://blog.csdn.net/zhangphil/article/details/48949027 
大致简介了Android DownloadManager如何完成一个下载任务。这篇文章在前一篇文章的基础上,做一些小改动,增加对下载任务状态的查询。
现在给出全部源代码。
MainActivity.Java文件:

[java]  view plain copy
  1. package zhangphil.demo;  
  2.   
  3. import android.app.Activity;  
  4. import android.app.DownloadManager;  
  5. import android.app.DownloadManager.Request;  
  6. import android.content.Context;  
  7. import android.database.Cursor;  
  8. import android.net.Uri;  
  9. import android.os.Bundle;  
  10. import android.os.Environment;  
  11. import android.view.View;  
  12. import android.widget.Button;  
  13. import android.widget.Toast;  
  14.   
  15. public class MainActivity extends Activity {  
  16.   
  17.     private DownloadManager downloadManager;  
  18.     private long Id;  
  19.   
  20.     @Override  
  21.     protected void onCreate(Bundle savedInstanceState) {  
  22.         super.onCreate(savedInstanceState);  
  23.         setContentView(R.layout.activity_main);  
  24.         Button button = (Button) findViewById(R.id.button);  
  25.         button.setOnClickListener(new View.OnClickListener() {  
  26.   
  27.             @Override  
  28.             public void onClick(View v) {  
  29.                 // remove将依据Id号取消相应的下载任务  
  30.                 // 可批量取消,remove(id1,id2,id3,id4,...);  
  31.                 downloadManager.remove(Id);  
  32.             }  
  33.         });  
  34.   
  35.         downloadManager = (DownloadManager) getSystemService(Context.DOWNLOAD_SERVICE);  
  36.   
  37.         // 假设从这一个链接下载一个大文件。  
  38.         Request request = new Request(  
  39.                 Uri.parse("http://apkc.mumayi.com/2015/03/06/92/927937/xingxiangyi_V3.1.3_mumayi_00169.apk"));  
  40.   
  41.         // 仅允许在WIFI连接情况下下载  
  42.         request.setAllowedNetworkTypes(Request.NETWORK_WIFI);  
  43.   
  44.         // 通知栏中将出现的内容  
  45.         request.setTitle("我的下载");  
  46.         request.setDescription("下载一个大文件");  
  47.         // 下载过程和下载完成后通知栏有通知消息。  
  48.         request.setNotificationVisibility(Request.VISIBILITY_VISIBLE | Request.VISIBILITY_VISIBLE_NOTIFY_COMPLETED);  
  49.   
  50.         // 此处可以由开发者自己指定一个文件存放下载文件。  
  51.         // 如果不指定则Android将使用系统默认的  
  52.         // request.setDestinationUri(Uri.fromFile(new File("")));  
  53.   
  54.         // 默认的Android系统下载存储目录  
  55.         request.setDestinationInExternalPublicDir(Environment.DIRECTORY_DOWNLOADS, "my.apk");  
  56.   
  57.         // enqueue 开始启动下载...  
  58.         Id = downloadManager.enqueue(request);  
  59.   
  60.         Button queryButton = (Button) findViewById(R.id.queryButton);  
  61.         queryButton.setOnClickListener(new View.OnClickListener() {  
  62.   
  63.             @Override  
  64.             public void onClick(View v) {  
  65.                 queryStatus();  
  66.             }  
  67.         });  
  68.     }  
  69.   
  70.     // 根据DownloadManager下载的Id,查询DownloadManager某个Id的下载任务状态。  
  71.     private void queryStatus() {  
  72.         DownloadManager.Query query = new DownloadManager.Query();  
  73.         query.setFilterById(Id);  
  74.         Cursor cursor = downloadManager.query(query);  
  75.   
  76.         String statusMsg = "";  
  77.         if (cursor.moveToFirst()) {  
  78.             int status = cursor.getInt(cursor.getColumnIndex(DownloadManager.COLUMN_STATUS));  
  79.             switch (status) {  
  80.             case DownloadManager.STATUS_PAUSED:  
  81.                 statusMsg = "STATUS_PAUSED";  
  82.             case DownloadManager.STATUS_PENDING:  
  83.                 statusMsg = "STATUS_PENDING";  
  84.             case DownloadManager.STATUS_RUNNING:  
  85.                 statusMsg = "STATUS_RUNNING";  
  86.                 break;  
  87.             case DownloadManager.STATUS_SUCCESSFUL:  
  88.                 statusMsg = "STATUS_SUCCESSFUL";  
  89.                 break;  
  90.             case DownloadManager.STATUS_FAILED:  
  91.                 statusMsg = "STATUS_FAILED";  
  92.                 break;  
  93.   
  94.             default:  
  95.                 statusMsg = "未知状态";  
  96.                 break;  
  97.             }  
  98.   
  99.             Toast.makeText(getApplicationContext(), statusMsg, Toast.LENGTH_SHORT).show();  
  100.         }  
  101.     }  
  102. }  


MainActivity.java需要的布局文件activity_main.xml:

[html]  view plain copy
  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     xmlns:tools="http://schemas.android.com/tools"  
  3.     android:id="@+id/LinearLayout1"  
  4.     android:layout_width="match_parent"  
  5.     android:layout_height="match_parent"  
  6.     android:orientation="vertical" >  
  7.   
  8.     <Button  
  9.         android:id="@+id/button"  
  10.         android:layout_width="wrap_content"  
  11.         android:layout_height="wrap_content"  
  12.         android:text="取消下载" />  
  13.   
  14.     <Button  
  15.         android:id="@+id/queryButton"  
  16.         android:layout_width="wrap_content"  
  17.         android:layout_height="wrap_content"  
  18.         android:text="查询下载状态" />  
  19.   
  20. </LinearLayout>  

这篇关于Android DownloadManager下载状态查询(2)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/525705

相关文章

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE