我尝试使用DownloadManager执行下载文件.除LG设备外一切正常.这是我的代码:
private void downloadFile(FileInfo fileInfo) { private DownloadManager manager = (DownloadManager) MyApp.getSingleton(). getApplicationContext().getSystemService(Context.DOWNLOAD_SERVICE); DownloadManager.Request request = new DownloadManager.Request(Uri.parse("https://" + MyPreference.getInstance().getBaseUrl() + "/api/v3/files/" + fileId + "/get")); request.setDescription(MyApp.getSingleton().getApplicationContext().getString(R.string.downloading)); request.setTitle(fileInfo.getmName()); request.addRequestHeader("Authorization", "Bearer " + MyPreference.getInstance().getAuthToken()); request.setNotificationVisibility(DownloadManager.Request.VISIBILITY_VISIBLE_NOTIFY_COMPLETED); File dir = new File(FileUtil.getInstance().getDownloadedFilesDir()); if(!dir.exists()){ dir.mkdirs(); } request.setDestinationUri(Uri.fromFile(new File(FileUtil.getInstance().getDownloadedFilesDir() + File.separator + fileInfo.getmName()))); downloadId = manager.enqueue(request); new Thread(() -> { boolean downloading = true; while (downloading) { DownloadManager.Query q = new DownloadManager.Query(); q.setFilterById(downloadId); Cursor cursor = manager.query(q); cursor.moveToFirst(); int bytes_downloaded = 0; long bytes_total = 0; try { bytes_downloaded = cursor.getInt(cursor .getColumnIndex(DownloadManager.COLUMN_BYTES_DOWNLOADED_SO_FAR)); bytes_total = cursor.getInt(cursor.getColumnIndexOrThrow(DownloadManager.COLUMN_TOTAL_SIZE_BYTES)); } catch (CursorIndexOutOfBoundsException e) { e.printStackTrace(); cursor.close(); break; } catch (IllegalArgumentException e){ e.printStackTrace(); cursor.close(); break; } if (cursor.getInt(cursor.getColumnIndex(DownloadManager.COLUMN_STATUS)) == DownloadManager.STATUS_FAILED) { downloading = false; cursor.close(); onDownloadFail(); break; } else if (cursor.getInt(cursor.getColumnIndex(DownloadManager.COLUMN_STATUS)) == DownloadManager.STATUS_SUCCESSFUL) { downloading = false; cursor.close(); break; } if (bytes_total > 0) { final int dl_progress = (int) ((bytes_downloaded * 100L) / bytes_total); onProgress(dl_progress); } cursor.close(); try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } } }).start(); }
在LG设备上
bytes_total = cursor.getInt(cursor.getColumnIndexOrThrow(DownloadManager.COLUMN_TOTAL_SIZE_BYTES));
返回-1.下载通知出现在通知栏中,并在几毫秒后立即消失.没有人例外,没有人进入这个代码部分
if (cursor.getInt(cursor.getColumnIndex(DownloadManager.COLUMN_STATUS)) == DownloadManager.STATUS_FAILED) { downloading = false; cursor.close(); onDownloadFail(); break; } else if (cursor.getInt(cursor.getColumnIndex(DownloadManager.COLUMN_STATUS)) == DownloadManager.STATUS_SUCCESSFUL) { downloading = false; cursor.close(); break; }
根本不值一提.因此内部while()循环工作永远.在设备LG D802和LG G3 S上测试.两种设备都表现出相同的行为.