ContentResolver openInputStream загружает файл в фоновом режиме - PullRequest
0 голосов
/ 15 ноября 2018

Итак, я пытаюсь скачать огромный файл.Поэтому, естественно, мой первый шаг - открыть поток

RNFetchBlob.RCTContext.getContentResolver().openInputStream(Uri.parse(fromUri));

Моя проблема в том, что вместо того, чтобы работать быстро и просто открывать поток, он фактически загружает объект в фоновом режиме.Откуда мне знать?Ну, эта команда блокируется примерно на 5 минут, а затем, когда я читаю из потока, она мгновенная.

Могу ли я запретить загрузку в фоновом режиме?Я хочу информировать пользователя о прогрессе, а не просто ждать.

Редактировать: чтобы прояснить, я использую URI для ресурса:

Ответы [ 2 ]

0 голосов
/ 15 ноября 2018

Для длительных загрузок HTTP вы можете использовать DownloadManager и показать прогресс загрузки, например, как в этом вопросе Victor Laerte :

    String urlDownload = <YOUR_URL>;
    DownloadManager.Request request = new DownloadManager.Request(Uri.parse(urlDownload));

    request.setDescription("Testando");
    request.setTitle("Download");
    request.allowScanningByMediaScanner();
    request.setNotificationVisibility(DownloadManager.Request.VISIBILITY_VISIBLE_NOTIFY_COMPLETED);
    request.setDestinationInExternalPublicDir(Environment.DIRECTORY_DOWNLOADS,"teste.zip");

    final DownloadManager manager = (DownloadManager) getSystemService(Context.DOWNLOAD_SERVICE);

    final long downloadId = manager.enqueue(request);

    final ProgressBar mProgressBar = (ProgressBar) findViewById(R.id.progressBar1);

    new Thread(new Runnable() {

        @Override
        public void run() {

            boolean downloading = true;

            while (downloading) {

                DownloadManager.Query q = new DownloadManager.Query();
                q.setFilterById(downloadId);

                Cursor cursor = manager.query(q);
                cursor.moveToFirst();
                int bytes_downloaded = cursor.getInt(cursor
                        .getColumnIndex(DownloadManager.COLUMN_BYTES_DOWNLOADED_SO_FAR));
                int bytes_total = cursor.getInt(cursor.getColumnIndex(DownloadManager.COLUMN_TOTAL_SIZE_BYTES));

                if (cursor.getInt(cursor.getColumnIndex(DownloadManager.COLUMN_STATUS)) == DownloadManager.STATUS_SUCCESSFUL) {
                    downloading = false;
                }

                final int dl_progress = (int) ((bytes_downloaded * 100l) / bytes_total);

                runOnUiThread(new Runnable() {

                    @Override
                    public void run() {

                        mProgressBar.setProgress((int) dl_progress);

                    }
                });

                Log.d(Constants.MAIN_VIEW_ACTIVITY, statusMessage(cursor));
                cursor.close();
            }

        }
    }).start();
0 голосов
/ 15 ноября 2018

Это неправильный метод для чтения файла по сети, вам нужно использовать сетевые методы.

HttpURLConnection request = 
    (HttpURLConnection)(new URL(Uri.parse(fromUri)).openConnection());
// Connect to the server, expect a delay and draw a progress bar
request.connect();
// This will read HTTP headers with content length, expect another delay
// Must be called before request.getContentLength()
request.getInputStream();
// Get the size of your file, to draw your progress bar properly
long total = request.getContentLength();
// Now you can finally start reading the data
InputStream input = request.getInputStream();
...