Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> Android開發 >> 中級開發 >> DownloadManager下載管理類2.3新增API介紹

DownloadManager下載管理類2.3新增API介紹

編輯:中級開發

從Android 2.3開始新增了一個下載管理類,在SDK的文檔中我們查找android.app.DownloadManager可以看到。下載管理類可以長期處理多個HTTP下載任務,客戶端只需要給出請求的Uri和存放目標文件的位置即可,下載管理使用了一個AIDL服務器所以可以放心的在後台執行,同時實例化的方法需要使用getSystemService(Context.DOWNLOAD_SERVICE) ,Android123再次提醒使用API Level為9的用戶可以輕松的通過新增的這個API實現android平台上的文件下載操作。

 DownloadManager類提供了以下幾種方法來處理,

  long  enqueue(DownloadManager.Request request)   //存入隊列一個新的下載項

 ParcelFileDescriptor  openDownloadedFile(long id)  //打開一個下載後的文件用於讀取,參數中的long型id是一個provider中的一條記錄。

Cursor  query(DownloadManager.Query query)  //查詢一個下載,返回一個Cursor

int  remove(long... ids)  //取消下載同時移除這些條從下載管理中。

  我們可以看到提供的方法都比較簡單,給我們操作的最終封裝成為一個provider數據庫的方式進行添加、查詢和移除,但是對於查詢和添加任務的細節,我們要看看DownloadManager.Request類和DownloadManager.Query 類了。

  一、DownloadManager.Request類的成員和定義

DownloadManager.Request  addRequestHeader(String header, String value)  // 添加一個Http請求報頭,對於這兩個參數,Android開發網給大家舉個小例子,比如說User-Agent值可以為android123或Windows XP等等了,主要是給服務器提供標識。
DownloadManager.Request  setAllowedNetworkTypes(int flags)  //設置允許使用的網絡類型,這一步android 2.3做的很好,目前有兩種定義分別為NETWORK_MOBILE和NETWORK_WIFI我們可以選擇使用移動網絡或Wifi方式來下載。
DownloadManager.Request  setAllowedOverRoaming(boolean allowed)  //對於下載,考慮到流量費用,這裡是否允許使用漫游。
DownloadManager.Request  setDescription(CharSequence description)  //設置一個描述信息,主要是最終顯示的notification提示,可以隨便寫個自己區別
DownloadManager.Request  setDestinationInExternalFilesDir(Context context, String dirType, String subPath)  //設置目標存儲在外部目錄,一般位置可以用 getExternalFilesDir()方法獲取。
DownloadManager.Request  setDestinationInExternalPublicDir(String dirType, String subPath)  //設置外部存儲的公共目錄,一般通過getExternalStoragePublicDirectory()方法獲取。
DownloadManager.Request  setDestinationUri(Uri uri)  //設置需要下載目標的Uri,可以是http、FTP等等了。
DownloadManager.Request  setMimeType(String mimeType)  //設置mime類型,這裡看服務器配置,一般國家化的都為utf-8編碼。
DownloadManager.Request  setShowRunningNotification(boolean show)  //是否顯示下載進度的提示
DownloadManager.Request  setTitle(CharSequence title)  //設置notification的標題
DownloadManager.Request  setVisibleInDownloadsUi(boolean isVisible)  //設置下載管理類在處理過程中的界面是否顯示

  當然了Google還提供了一個簡單的方法來實例化本類,這個構造方法為DownloadManager.Request(Uri uri) ,我們直接填寫一個Uri即可,上面的設置使用默認情況。

 二、DownloadManager.Query類

  對於當前下載內容的狀態,我們可以使用DownloadManager.Query類來獲取,本類比較簡單,僅僅提供了兩個方法。

  DownloadManager.Query  setFilterById(long... ids)  //根據id來過濾查找。
  DownloadManager.Query  setFilterByStatus(int flags) //根據任務的狀態來查找。

  詳細的狀態在android.app.DownloadManager類中有定義,目前android 2.3中的定義為:

int STATUS_FAILED 失敗
int STATUS_PAUSED 暫停
int STATUS_PENDING 等待將開始
int STATUS_RUNNING 正在處理中
int STATUS_SUCCESSFUL 已經下載成功

 最後android開發網提醒大家要說的是因為DownloadManager類提供的query方法返回一個Cursor對象,這些狀態保存在這個游標的COLUMN_STATUS 字段中。

  1. 下載的狀態完成均是以廣播的形式通知大家,目前API Level為9定義了下面三種Intent的action

  ACTION_DOWNLOAD_COMPLETE下載完成的動作。
  ACTION_NOTIFICATION_CLICKED 當用戶單擊notification中下載管理的某項時觸發。
  ACTION_VIEW_DOWNLOADS 查看下載項

  2. 對於一個尚未完成的項,在Cursor中我們查找COLUMN_REASON字段,可能有以下定義:

int ERROR_CANNOT_RESUME 不能夠繼續,由於一些其他原因。
int ERROR_DEVICE_NOT_FOUND 外部存儲設備沒有找到,比如SD卡沒有插入。
int ERROR_FILE_ALREADY_EXISTS 要下載的文件已經存在了,android123提示下載管理類是不會覆蓋已經存在的文件,所以如果需要重新下載,請先刪除以前的文件。

int ERROR_FILE_ERROR 可能由於SD卡原因導致了文件錯誤。
int ERROR_HTTP_DATA_ERROR 在Http傳輸過程中出現了問題。
int ERROR_INSUFFICIENT_SPACE 由於SD卡空間不足造成的 

int ERROR_TOO_MANY_REDIRECTS 這個Http有太多的重定向,導致無法正常下載
int ERROR_UNHANDLED_HTTP_CODE 無法獲取http出錯的原因,比如說遠程服務器沒有響應。
int ERROR_UNKNOWN 未知的錯誤類型.

 3. 有關暫停的一些狀態,同樣COLUMN_REASON字段的值可能是以下定義

int PAUSED_QUEUED_FOR_WIFI 由於移動網絡數據問題,等待WiFi連接能用後再重新進入下載隊列。
int PAUSED_UNKNOWN 未知原因導致了任務下載的暫停.
int PAUSED_WAITING_FOR_NETWORK 可能由於沒有網絡連接而無法下載,等待有可用的網絡連接恢復。.
int PAUSED_WAITING_TO_RETRY 由於重重原因導致下載暫停,等待重試。

  有關android 2.3中新增的下載管理DownloadManager的介紹基本上已經完全講完,如果你對Cursor、Provider這些基礎概念了解的話,可以看到這個下載管理類可以幫我們減少很多不必要的代碼編寫。

  1. 上一頁:
  2. 下一頁:
熱門文章
閱讀排行版
Copyright © Android教程網 All Rights Reserved