youtube_player 3.4.0 youtube_player: ^3.4.0 copied to clipboard
A flutter plugin to play Youtube Videos "inline" without API Key in range of Quality (144p, 240p, 360p, 480p, 720p and 1080p).
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:youtube_player/youtube_player.dart';
import 'video_detail.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
debugShowCheckedModeBanner: false,
theme: ThemeData(
primarySwatch: Colors.red,
),
home: MyHomePage(title: 'Youtube Player Demo'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
static const platform = const MethodChannel("np.com.sarbagyastha.example");
TextEditingController _idController = TextEditingController();
TextEditingController _seekToController = TextEditingController();
double _volume = 1.0;
VideoPlayerController _videoController;
String position = "Get Current Position";
String status = "Get Player Status";
String videoDuration = "Get Video Duration";
String _source = "7QUtEmBT_-w";
bool isMute = false;
@override
void initState() {
getSharedVideoUrl();
super.initState();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
centerTitle: true,
),
body: SingleChildScrollView(
child: Column(
mainAxisAlignment: MainAxisAlignment.start,
children: <Widget>[
YoutubePlayer(
context: context,
source: _source,
quality: YoutubeQuality.HD,
aspectRatio: 16 / 9,
autoPlay: true,
startFullScreen: false,
controlsActiveBackgroundOverlay: true,
controlsTimeOut: Duration(seconds: 4),
playerMode: YoutubePlayerMode.DEFAULT,
callbackController: (controller) {
_videoController = controller;
},
onError: (error) {
print(error);
},
onVideoEnded: () => _showThankYouDialog(),
),
SizedBox(
height: 10.0,
),
Padding(
padding: const EdgeInsets.all(8.0),
child: Column(
crossAxisAlignment: CrossAxisAlignment.stretch,
children: <Widget>[
TextFormField(
controller: _idController,
decoration: InputDecoration(
border: OutlineInputBorder(),
hintText: "Enter youtube \<video id\> or \<link\>"),
),
SizedBox(
height: 10.0,
),
InkWell(
onTap: () {
setState(() {
_source = _idController.text;
});
},
child: Container(
padding: EdgeInsets.symmetric(
vertical: 16.0,
),
color: Colors.red,
child: Text(
"PLAY",
style: TextStyle(fontSize: 18.0, color: Colors.white),
textAlign: TextAlign.center,
),
),
),
SizedBox(
height: 10.0,
),
Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: <Widget>[
IconButton(
icon: Icon(Icons.play_arrow),
onPressed: () => _videoController.value.isPlaying
? null
: _videoController.play(),
),
IconButton(
icon: Icon(Icons.pause),
onPressed: () => _videoController.pause(),
),
IconButton(
icon: Icon(isMute ? Icons.volume_off : Icons.volume_up),
onPressed: () {
_videoController.setVolume(isMute ? 1 : 0);
setState(
() {
isMute = !isMute;
},
);
},
),
],
),
SizedBox(
height: 10.0,
),
TextField(
controller: _seekToController,
keyboardType: TextInputType.number,
decoration: InputDecoration(
border: OutlineInputBorder(),
hintText: "Seek to seconds",
suffixIcon: Padding(
padding: EdgeInsets.all(5.0),
child: OutlineButton(
child: Text("Seek"),
onPressed: () => _videoController.seekTo(Duration(
seconds: int.parse(_seekToController.text)))),
),
),
),
SizedBox(
height: 10.0,
),
Row(
children: <Widget>[
Text(
"Volume",
style: TextStyle(fontWeight: FontWeight.w300),
),
Expanded(
child: Slider(
inactiveColor: Colors.transparent,
value: _volume,
min: 0.0,
max: 1.0,
divisions: 10,
label: '${(_volume * 10).round()}',
onChanged: (value) {
setState(() {
_volume = value;
});
_videoController.setVolume(_volume);
},
),
),
],
),
OutlineButton(
child: Text(position),
onPressed: () => _videoController.position.then(
(currentPosition) {
setState(
() {
position =
currentPosition.inSeconds.toString() +
" th second";
},
);
},
),
),
OutlineButton(
child: Text(videoDuration),
onPressed: () {
setState(
() {
videoDuration = _videoController
.value.duration.inSeconds
.toString() +
" seconds";
},
);
},
),
OutlineButton(
child: Text(status),
onPressed: () {
setState(() {
_videoController.value.isPlaying
? status = "Playing"
: status = "Paused";
});
},
),
RaisedButton(
child: Text("Next Page"),
onPressed: () {
_videoController.pause();
Navigator.of(context).push(
MaterialPageRoute(builder: (context) => VideoDetail()),
);
},
),
],
),
)
],
),
),
);
}
void _showThankYouDialog() {
showDialog(
context: context,
builder: (BuildContext context) {
return AlertDialog(
title: Text("Video Ended"),
content: Text("Thank you for trying the plugin!"),
);
},
);
}
getSharedVideoUrl() async {
try {
var sharedData = await platform.invokeMethod("getSharedYoutubeVideoUrl");
if (sharedData != null && mounted) {
setState(() {
_source = sharedData;
print(_source);
});
}
} on PlatformException catch (e) {
print(e.message);
}
}
}