Bien, estoy descargando archivos (imágenes). Deseo enviar un mensaje con un URI local para la imagen cuando se complete la descarga. Pero el 20% del tiempo me estoy haciendo esto:DownloadManager envía STATUS_SUCCESSFUL para la descarga fallida
6-01 18:46:39.900: INFO/DownloadManager(412): Initiating request for download 605
06-01 18:46:39.910: WARN/DownloadManager(412): Aborting request for download 605: Trying to resume a download that can't be resumed
06-01 18:46:39.910: INFO/ololo(2826): Okay, I'll broadcast.
06-01 18:46:39.990: WARN/ImageView(2826): Unable to open content: content://downloads/my_downloads/605
java.io.FileNotFoundException: No filename found.
at android.database.DatabaseUtils.readExceptionWithFileNotFoundExceptionFromParcel(DatabaseUtils.java:145)...
06-01 18:46:39.990: INFO/System.out(2826): resolveUri failed on bad bitmap uri: content://downloads/my_downloads/605
06-01 18:46:39.990: INFO/ololo(2826): content://downloads/my_downloads/605 was set for [email protected]
Este es el código
Long downloadId = downloadIds.get(this);
if(downloadId == intent.getLongExtra(DownloadManager.EXTRA_DOWNLOAD_ID, -1)) {
DownloadManager.Query query = new DownloadManager.Query();
query.setFilterById(downloadId);
Cursor cursor = downloadManager.query(query);
if(cursor.moveToFirst()) {
switch (cursor.getInt(cursor.getColumnIndex(DownloadManager.COLUMN_STATUS))) {
case DownloadManager.STATUS_SUCCESSFUL : {
Log.i("ololo", "Okay, I'll broadcast.");
// Broadcasting
break;
}
case DownloadManager.STATUS_FAILED : {
Log.i("ololo", "Bad, I won't broadcast.");
int reason = cursor.getInt(cursor.getColumnIndex(DownloadManager.COLUMN_REASON));
if(reason == DownloadManager.ERROR_CANNOT_RESUME || reason == DownloadManager.ERROR_UNKNOWN) {
// Rerun download
}
break;
}
default:
break;
}
}
}
Hola, estoy teniendo el mismo problema. ¿Lo has resuelto de alguna manera o has entendido lo que está mal? –
@TalKanel El problema está sucediendo SOLO con dispositivos Samsung (Galaxy Tab 10.1 o algo más, en 3.2, o 2.3.3, o 4.0, esto no importa, nunca le pasó a ningún HTC). Creo que existe su propia _buggy_ realización del 'DownloadManager'. Entonces mi jefe de equipo escribió su propia realización y funciona bien. – efpies
es una lástima, tengo que usarlo en las tabletas Samsung P7510 y P5110 (GALAXY TAB 10.1 ONE y DOS), y necesito que funcione en las versiones de SO específicas que mencionaste ... así que supongo que tengo que implementar mi propia solución. –