Чтобы предотвратить одновременное воспроизведение 2 радиостанций. Воспроизведение только 1 радиопередачи

#flutter #dart #radio-button #radio

Вопрос:

Когда я перейду на страницу радио, я смогу запустить его автоматически. Радио продолжает играть при переключении между страницами. Когда мы снова переходим на страницу радио, снова запускается то же радио, то есть 2 радио играют одновременно. Если радио играет, когда я вернусь на страницу радио, давайте не будем заводить новое радио, но продолжим воспроизведение радио. Так что я не хочу никаких перемен. Как я могу это сделать?

код здесь:

 import 'package:flutter/material.dart';
import 'package:flutter_radio/flutter_radio.dart';
class RadioSayfasi extends StatefulWidget {
  @override
  _RadioSayfasiState createState() => _RadioSayfasiState();
}

class _RadioSayfasiState extends State<RadioSayfasi> {
  String url= "https://fm898.online/mystream.mp3";

  bool isPlaying= false;
  bool isVisible= true;

  @override
  void initState() {
    // TODO: implement initState
    super.initState();
    audioStart();
  }

  Future <void> audioStart() async {
    await FlutterRadio.audioStart();
    print("Radio Başladı");
    FlutterRadio.play(url: url);
    isPlaying = !isPlaying;
    isVisible = !isVisible;
    
  }
  Future<bool>_onBackPressed(){
    FlutterRadio.stop();
    Navigator.pop(
        context, MaterialPageRoute(builder: (_) => Profil()));
  }
  @override
  Widget build(BuildContext context) {
    return WillPopScope(
      onWillPop: _onBackPressed,
      child: new MaterialApp(
          title: 'IndieXL Online Radio',
          debugShowCheckedModeBanner: false,
          home: new Scaffold(
            appBar: new AppBar(
              title: const Text('FM Radio'),
              backgroundColor: Colors.blueGrey.shade900,
              centerTitle: true,
            ),
            body: Container(
              color: Colors.blueGrey.shade900,
              child: new Column(
                children: <Widget>[
                  Expanded(
                    flex: 7,
                    child: Icon(
                      Icons.radio, size: 250,
                      color: Colors.white,
                    ),
                  ),
                  Expanded(
                    flex: 2,
                    child: Padding(
                      padding: const EdgeInsets.only(right: 40),
                      child: Align(
                        alignment: FractionalOffset.center,
                        child: IconButton(icon: isPlaying? Icon(
                          Icons.pause_circle_outline,
                          size: 80,
                          color: Colors.white,
                        )
                            : Icon(
                          Icons.play_circle_outline,
                          color: Colors.white,
                          size: 80,
                        ),
                          onPressed: (){
                            setState(() {
                              FlutterRadio.playOrPause(url: url);
                              isPlaying = !isPlaying;
                              isVisible = !isVisible;
                              print("tıkladı");
                            });
                          },
                        ),
                      ),
                    ),
                  ),
                  SizedBox(height: 50,)
                ],
              ),
            ),
          )),
    );
  }

}
 

Ответ №1:

Я думаю, что у вас есть два варианта

1. Используйте статическую версию, чтобы сохранить значение, если радио воспроизводится, и проверьте его в функции audioStart, чтобы избежать повторного воспроизведения.

2: Используйте поставщика, аналогично, чтобы сохранить значение во всем мире

Также вы можете попробовать добавить эти изменения

  String url= "https://fm898.online/mystream.mp3";

  static bool isPlaying= false;
  bool isVisible= true;

  @override
  void initState() {
    // TODO: implement initState
    super.initState();
    audioStart();
  }

  Future <void> audioStart() async {
    await FlutterRadio.audioStart();
    print("Radio Başladı");
   
    if(!isPlaying){
       FlutterRadio.play(url: url);
       isPlaying = !isPlaying;
    }
    isVisible = !isVisible;
    
  }
 

Комментарии:

1. спасибо вам за ответ . Есть ли видео или ресурс, который я могу использовать в качестве примера?

2. Спасибо, что это сработало для меня. Но когда я хочу остановиться, я не могу. Я так старался, не понимаю почему.

3. Пожалуйста, добавьте код для FlutterRadio, я пытался найти пакет в https://pub.dev но я ничего не нашел, без кода я не могу вам помочь

4. Когда я хочу остановить воспроизведение нового радио, я не могу этого предотвратить. Так что радио не останавливается

5. код здесь: onPressed: (){ setState (() { FlutterRadio.playOrPause(url: url); игра = ! Разыгрывается; isVisible = !разыгрывается; /* если(разыгрывается){ FlutterRadio.стоп(); игра = ! играем; }*/ }); },