Nano Hash - криптовалюты, майнинг, программирование

Невозможно отобразить сообщение Toast изнутри onTick CountDownTimer (работает внутри службы)

Я пытаюсь отобразить сообщение Toast из функции onTick() класса CountDownTimer. Этот класс работает внутри службы.

Простое выполнение Toast.maketext("tag", "toast message") - вылетает приложение.

Итак, я попробовал обработчик. С обработчиком приложение не падает, но я также не вижу всплывающего сообщения. Любая помощь в том, что не так, будет полезной.

Я уверен, что мой таймер обратного отсчета работает правильно и вызывается onTick - я добавил операторы LogCat, чтобы подтвердить это.

public class MyServicelockCountdownTimer extends CountDownTimer {

    public FBServicelockCountdownTimer(long millisInFuture,
            long countDownInterval) {
        super(millisInFuture, countDownInterval);
    }

    @Override
    public void onFinish() {
    }

    @Override
    public void onTick(long millisUntilFinished) {
                    handler.post(new Runnable() {
                        @Override
                        public void run() {
                            Toast.makeText(
                                    getApplicationContext(),
                                    "This is toast message from inside onTick of the CountDownTimer inside the Service",
                                    Toast.LENGTH_LONG).show();
                        }
                    });

                } else {

                }
            } catch (NameNotFoundException e) {
                e.printStackTrace();
            }
        }
    }
}

  • Я предполагаю, что ваш обработчик создан прикрепленным к основному циклу потока? 22.02.2014
  • Вы привязали свой сервис к своей деятельности? developer.android.com/guide/components/ 22.02.2014
  • проверьте этот поток stackoverflow .com/questions/11319340/ 22.02.2014

Ответы:


1

Попробуйте использовать this из своей деятельности вместо использования getApplicationContext():

Toast.makeText(
    YourActivity.this,
    "This is toast message from inside onTick of the CountDownTimer inside the Service",
    Toast.LENGTH_LONG).show();
22.02.2014
  • Это внутри службы, а не активности 22.02.2014
  • попробуйте эту ссылку, может быть, она может вам помочь [jjoe64 .com/2011/09/show-toast-notification-from-service.html] 22.02.2014
  • ссылка не рабочая 24.02.2014

  • 2

    Попробуйте использовать метод getMainLooper() класса Looper, который -

    Возвращает основной цикл приложения, который находится в основном потоке приложения. // из документов Android.

    И вам также следует рассмотреть возможность привязки Activites к службам для обработки обновлений пользовательского интерфейса.

    Проверьте эту ссылку, чтобы получить дополнительные сведения.

    22.02.2014

    3
    public abstract void onReceive (Context context, Intent intent)
    

    в onReceive вы будете контекст

    Вызовите getApplicationContext() для контекста, предоставленного вам в onReceive(), точно так же, как если бы вы вызывали getApplicationContext() для действия.

    22.02.2014
  • у меня нет onReceive 26.02.2014
  • Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

    Как я автоматизирую тестирование с помощью Jest
    Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..