進行状況バーを設定して、アップロードまたはダウンロードタスクの進行状況を表示できます。
サンプルコード
次のサンプルコードは、asyncPutObjectを使用してオブジェクトを非同期でアップロードするときにプログレスバーを使用する方法の例を示しています。
// ローカルファイルをアップロードするリクエストを作成します。
// バケットの名前、オブジェクトのフルパス、およびローカルファイルのフルパスを指定します。 この例では、バケットの名前はexamplebucket、オブジェクトのフルパスはexampledir/exampleobject.txt、ローカルファイルのフルパスは /storage/emulated/0/oss/examplefile.txtです。
// オブジェクトのフルパスにバケット名を含めないでください。
PutObjectRequest put = new PutObjectRequest("examplebucket", "exampledir/exampleobject.txt", "/storage/emulated/0/oss/examplefile.txt");
// 進行状況バーを表示するようにコールバック関数を設定します。
put.setProgressCallback(new OSSProgressCallback<PutObjectRequest>() {
@オーバーライド
public void onProgress(PutObjectRequest request, long currentSize, long totalSize) {
// currentSizeは、オブジェクトのアップロードされた部分のサイズを指定します。 単位:バイト
// totalSizeは、アップロードするオブジェクトの合計サイズを指定します。 単位:バイト
Log.d("PutObject", "currentSize: " + currentSize + "totalSize: " + totalSize);
}
});
// 非同期モードでローカルファイルをアップロードします。
OSSAsyncTask task = oss.asyncPutObject(put, new OSSCompletedCallback<PutObjectRequest, PutObjectResult>() {
@オーバーライド
public void onSuccess(PutObjectRequestリクエスト, PutObjectResult結果) {
Log.d("PutObject", "UploadSuccess");
Log.d("ETag", result.getETag());
Log.d("RequestId", result.getRequestId());
}
@オーバーライド
public void onFailure(PutObjectRequest request, ClientException clientExcepion, ServiceException serviceException) {
// リクエスト例外を処理します。
if (clientExcepion != null) {
// ネットワーク例外などのクライアント例外を処理します。
clientExcepion.printStackTrace();
}
if (serviceException != null) {
// サービス例外を処理します。
Log.e("ErrorCode", serviceException.getErrorCode());
Log.e("RequestId", serviceException.getRequestId());
Log.e("HostId", serviceException.getHostId());
Log.e("RawMessage", serviceException.getRawMessage());
}
}
});
// task.ca ncel(); // ダウンロードタスクをキャンセルできます。
// task.waitUntilFinished(); // アップロードタスクが完了するまで待ちます。
サンプルコード
オブジェクトのアップロードに使用するプログレスバーの完全なサンプルコードについては、GitHubをご参照ください。