Reg*_*bar 5 android firebase firebase-storage
addOnProgressListener覆盖了onProgress函数的问题.
我的问题是,当我尝试上传图像时,TaskSnapshot不会返回已传输的字节.它只是保持在0.这是我的代码片段:
StorageReference myStorageRef = momentsStorageRef.child(momentID + ".jpeg");
UploadTask uploadTask = myStorageRef.putBytes(data, new StorageMetadata.Builder()
.setContentType("image/jpeg")
.build());
uploadTask.addOnProgressListener(new OnProgressListener<UploadTask.TaskSnapshot>() {
@Override
public void onProgress(UploadTask.TaskSnapshot taskSnapshot) {
int bytesTransferred = (int) taskSnapshot.getBytesTransferred();
int totalBytes = (int) taskSnapshot.getTotalByteCount();
int progress = (100 * bytesTransferred) / totalBytes ;
Log.v(TAG, "Bytes transferred: " + taskSnapshot.getBytesTransferred());
Log.v(TAG, "TotalBytes: " + totalBytes);
Log.v(TAG, "Upload is: " + progress + "% done");
mBuilder.setProgress(100, progress, false);
mNotifyManager.notify(APPLICATION_NOTIFICATION_ID, mBuilder.build());
}
})
Run Code Online (Sandbox Code Playgroud)
这是logCat:
05-28 19:21:33.911 27673-27673:字节转移:0
05-28 19:21:33.911 27673-27673:TotalBytes:205846
05-28 19:21:33.911 27673-27673:上传是:0%完成
05 -28 19:21:35.637 27673-27673:字节转移:0
05-28 19:21:35.637 27673-27673:TotalBytes:205846
05-28 19:21:35.637 27673-27673:上传是:0%完成
05- 28 19:21:41.458 27673-27673字节转移:205846
05-28 19:21:41.458 27673-27673 TotalBytes:205846
05-28 19:21:41.458 27673-27673:上传是:100%完成
进度以256KB的块为单位进行测量.由于您的文件小于该文件,因此它适合一个块,因此进度一次从0%跳到100%.
我们有一项开放式任务,可以在较小文件和较低带宽连接的情况下改进进度测量的粒度.
| 归档时间: |
|
| 查看次数: |
1136 次 |
| 最近记录: |