#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.стоп(); игра = ! играем; }*/ }); },