Почему NotificationManager работает так медленно во время обновления?

Я публикую прогресс загрузки файла через NotificationManager, но при обновлении его пользовательский интерфейс прогресса зависает.

Я использую NotificationCompat.Builder, который кэшируется в поле класса. Таким образом, прогресс публикации очень прост:

manager.notify(id, uploader.
    setProgress(MAX_PROGRESS, (int) (progress * 100), false).
    build()
);

Обновление гарантированно будет выполнено из основного потока (в обработчике обработчика).

this.request.setCallback(new UploaderDecorator(this.request.getCallback()));

Сама публикация прогресса выглядит следующим образом:

long total = file.length();
long uploaded = 0;
int bytesRead = input.read(buffer, 0, bufferSize);
while (bytesRead > 0) {
    output.write(buffer, 0, bufferSize);
    uploaded += bytesRead;
    callback.onUploadProgress(activeFile, ((float) uploaded / total));
    bytesRead = input.read(buffer, 0, bufferSize);
}

Так почему же он работает так медленно?

1 ответ

Решение

Это обычное поведение. Не следует загружать NotificationManager частыми обновлениями. Вы должны выбрать интервал для обновления, например, дважды в секунду.

Например,

long startTime;
long elapsedTime = 0L;

if (elapsedTime > 500) {
                    new Handler(Looper.getMainLooper()).post(new Runnable() {
                        @Override
                        public void run() {
                            mBuilder.setProgress(100, (int) newValue, false);
                            mNotifyManager.notify(notificationID, mBuilder.build());

                            startTime = System.currentTimeMillis();
                            elapsedTime = 0;
                        }
                    });

                    Log.d("Andrognito", newValue + "Progress");
                }
                else
                    elapsedTime = new Date().getTime() - startTime;

Это отлично работает для меня и не замораживает уведомления тоже.

Другие вопросы по тегам