【问题标题】:custom action notification icons in just audio仅音频中的自定义操作通知图标
【发布时间】:2021-11-07 14:22:58
【问题描述】:

如何为通知图标提供可选功能?

除了图标的正常功能外,我想给图标赋予其他可选功能 例如,在下一次命中之后,执行另一个函数并..

其实我想听听主要动作的变化(下一个、上一个、暂停..)

【问题讨论】:

    标签: flutter just-audio audio-service


    【解决方案1】:

    如果您查看官方的 audio_service 示例,特别是 example/lib/example_multiple_handlers.dart,您会发现它定义了 skipToQueueItem 方法来执行“正常功能”,例如搜索请求的项目:

      @override
      Future<void> skipToQueueItem(int index) async {
        // Then default implementations of skipToNext and skipToPrevious provided by
        // the [QueueHandler] mixin will delegate to this method.
        if (index < 0 || index >= queue.value.length) return;
        // This jumps to the beginning of the queue item at newIndex.
        _player.seek(Duration.zero, index: index);
        // Demonstrate custom events.
        customEvent.add('skip to $index');
      }
    

    如果您想做自定义的事情,只需在此方法的末尾添加您的自定义代码即可。请注意,在示例中,skipToNextskipToPrevious 的回调只是委托给上述方法,以便在上面的这个地方处理跳到曲目。

    其实我是想听听主要动作的变化(下一个、上一个、暂停..)

    方法完全相同。只需覆盖这些回调中的每一个并处理每个回调,以首先执行“正常功能”,然后执行您的自定义代码。

    例如,您可以像这样覆盖skipToNext

    @override
    Future<void> skipToNext() async {
      // Do the normal functions
      await _player.seekToNext();
      // Add your custom code here
    }
    

    每个回调的方法都是相同的,所以您需要做的就是查看文档以查看所有可用回调的列表(例如pause),然后覆盖您需要的每个回调并使用实现它上述方法。首先,执行常规功能,然后执行您的自定义代码。

    【讨论】:

    • 谢谢你的回答,但其实我想听听主要动作的变化(下一个,上一个,暂停..)
    • 你明白了,对吧?如果你用同样的方式覆盖skipToNextskipToPrevious,你可以直接监听那些方法。
    • 我已将答案更新为skipToNext。这又是同样的方法。如果你想做另一个回调,例如pause,这又将是一个相同的方法,所以希望我的回答能给你一个大致的思路,你只需要为你想要在你的应用程序中处理的所有单独的回调实现相同的方法。
    • 非常感谢您抽出宝贵时间,但此代码不适用于通知操作(下一个、上一个)
    • 如果您将 skipToNext 方法添加到示例中,它会按预期工作。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-06-28
    • 1970-01-01
    相关资源
    最近更新 更多