Releases: PierfrancescoSoffritti/android-youtube-player
10.0.1
- Adds support for video captions, thanks to @ct7ct7ct7. To know more read the documentation.
- Fixes branding issues in sample apps.
Quality of life
This is a major update, upgrading from an older version will break backward compatibility.
The code base has been rewritten in Kotlin and major improvements have been implemented throughout the library.
Most notably, now YouTubePlayerView
:
- Supports custom attributes, to configure it directly from XML. It is now possible to play a video without writing a single line of Java/Kotlin code. For more advanced use cases everything can also be done programmatically, as before.
- Can manage its initialization internally!
YouTubePlayerInitListener
is a thing of the past, it has been removed from the code base. You can now directly add aYouTubePlayerListener
toYouTubePlayerView
. - Can be easily used with the web-based UI instead of the native UI. When using the web-based UI it will be possible to click the "share" and "watch later" buttons that YouTube recently forced to be always visible.
The documentation has been greatly improved, please use it and feel free to contribute :)
Follows a detailed description of the changes.
Breaking changes:
YouTubePlayerInitListener
has been removed.- Every method of
YouTubePlayerListener
now takes aYouTubePlayer
as first argument. - Useless parameters have been removed from
IFramePlayerOptions
, such asautoplay
,origin
,showInfo
andmodestBranding
. They are deprecated on the IFrame player or not working on mobile devices. - The class
androidyoutubeplayer.utils.Callable
has been removed. - The method
setYouTubePlayerMenu
has been removed fromPlayerUIController
. - The content of the
core
module is now under acore
package.
New features:
YouTubePlayerView
supports xml attributes, check out the documentation to learn more.- It is possible to let
YouTubePlayerView
initialize itself by using the attributeenableAutomaticInitialization
, which isture
by default. - It is now possible to easily replace the native UI of the player with the web-based UI. This makes it possible to click the "share" and "watch later" buttons.
- A set of components are now available to help you build custom UIs, such as
YouTubePlayerSeekBar
andFadeViewHelper
, read the documentation to know more.
Improvements:
- The core module has been rewritten in Kotlin. This doesn't break its compatibility with Java, it just improves the code base.
YouTubePlayerView
has a newgetYouTubePlayerWhenReady
method.- The utility
cueOrLoadVideo
has been added, read the documentation to know more. PlayerUIController
now has a fluent interfaceYouTubePlayerMenu
now has a fluent interface- The dependencies of both the
core
andchromecast-sender
modules have been reorganized in order to import only what's needed. - Private resources of the library have been renamed with the "ayt_" prefix.
- The sample apps have been reorganized and improved with new examples.
- Both sample apps are now built on top of library-sample-app-template.
Bugfixes:
9.0.1
Bug fixes
- Fixed a bug caused the
onInitSuccess
callback to be called outside the main thread.
Androidx migration
Breaking changes
The library is now using Androidx instead of the old support libraries. You may have some problems with the new update if you're using the support library Lifecycle classes. The best way to solve this issue is to migrate your app to Androidx.
[core] New features
IFramePlayerOptions: it is now possible to set some of the IFrame Player parameters from Java/Kotlin, previously this was possible only through Javascript. This opens new customization possibilities, for example it's possible to disable the Android UI of the player and enable the Web UI instead.
To read more about this feature refer to the doc.
Thanks to @matthewrkula for implementing this feature.
[core] Bug Fixes
- Background playback is working again, read the doc to learn how to enable it. Thanks to @CajetanP for the bug fix.
- Solved a bug that was hiding custom actions if they were enabled before playing a video.
[core] Sample app
- Added Fragment sample app.
- Added IFramePlayerOptions sample app.
Graduation
This is the biggest update this library ever had. When I first created the library I didn't intend for it to become a long term project and I lacked the experience to set it up properly. Version 8 fixes most of the bad decisions I made and is supposed to set this project up for success in the long term.
Along with these changes a big new feature is now available: Chromecast playback.
If you are updating from an older version you will have to make some changes in your project, mostly renaming packages and some classes.
At the end of this post you can find a simple "guide" for updating from version 7 to 8.
Readme file
The readme of the project has been changed heavily, from now on it will contain the documentation of the library.
Gradle dependency
From version 0 to 7 the Gradle dependency of this library has been served through Jitpack. It is now on jCenter instead.
The YouTube player library is now published under the name core. The Chromecast extension library is published under the name chromecase-sender.
dependencies {
implementation 'com.pierfrancescosoffritti.androidyoutubeplayer:core:8.0.1'
}
dependencies {
implementation 'com.pierfrancescosoffritti.androidyoutubeplayer:core:8.0.1'
implementation 'com.pierfrancescosoffritti.androidyoutubeplayer:chromecast-sender:0.15'
implementation 'org.jetbrains.kotlin:kotlin-stdlib-jdk7:1.2.50'
}
New Features
- Chromecast playback. A new module has been added to the project: chromecast-sender. This is an extension library that you can use to cast YouTube videos to a Google Cast enabled devices directly from your app.
A Chromecast receiver is also provided.
Read the documentation for more information.
Try the sample app here. An example is also available in the core sample app.
Breaking changes
- Changed package name of the whole library. It now is
com.pierfrancescosoffritti.androidyoutubeplayer
. To be consistent with the actual name of the library. - Listeners interfaces have been moved in a listeners package.
PlayerUIController.setCustomFullScreenButtonListener
has been renamed toPlayerUIController.setFullScreenButtonListener
YouTubePlayerStateTracker
as been renamed toYouTubePlayerTracker
.YouTubePlayerTracker.getCurrentState()
renamed toYouTubePlayerTracker.getState()
.- Player constants are now enums.
Minor improvements
- improved Kotlin compatibility.
Bug fixes
- The WebView hosting the player is now detached before is destroyed.
Migrating from version 7 to 8
- Change the Gradle dependency from
implementation 'com.github.PierfrancescoSoffritti:AndroidYouTubePlayer:6.0.0'
toimplementation 'com.pierfrancescosoffritti.androidyoutubeplayer:core:8.0.1'
. You can also removemaven { url "https://jitpack.io" }
from your project-level build.gradle file. - Remove all the imports from your classes, use the IDE to re-import classes from the library from the correct package name.
- Remember to manually update the package of the Views in your XML files. The IDE may miss them.
- Apply the changes in the name I have reported under Breaking changes.
- Convert player constants to enums.
7.0.1
Changes:
- Solved issue #145, when opening a YouTube video by clicking the YouTube button on the player, the video will start playing from where it was stopped.
- Solved issue #144, it's not possibile to add null
YouTubePlayerListener
s toYouTubePlayer
. - Improved compatibility with Kotlin.
- Improved documentation.
- Improved sample app.
7.0.0
-
Breaking changes:
YouTubePlayer.seekTo(int time)
now takes afloat
, to improve consistency with the other APIs.
-
Minor changes:
-
When a
View
is added to the default player UI, usingyouTubePlayerView.getPlayerUIController().addView(View)
, it doesn't always need padding. It is now defined in the container. -
Sample app:
-
Added an example showing how the player state changes and how to track it.
-
Added an example for picture in picture mode.
-
Added nav drawer options to star the library on GitHub and rate on the PlayStore.
-
Links from the main WebView are now opened in the browser.
6.0.0
-
New features:
- Buffering percentage.
It is now possible to know the percentage of the video that has been buffered. You can easily do that adding the methodYouTubeListener.onVideoLoadedFraction(float fraction)
to yourYouTubePlayerListener
.
The default UI shipped with the library is now showing buffering progress in the player's seek bar. If you don't want to see it, you can hide is usingPlayerUIController.showBufferingProgress(boolean show)
.
- Buffering percentage.
-
Minor improvements:
- Improved documentation in
YouTubePlayerListener
.
- Improved documentation in
-
Breaking changes:
- Added method
onVideoLoadedFraction(float fraction)
toYouTubePlayerListener
. - Removed
onMessage(String message)
fromYouTubePlayerListener
. - Removed deprecated methods
mute
andunMute
fromYouTubePlayer
.
- Added method
-
Bug fixes:
- Solved issue #120
5.0.1
YouTubePlayer
'smute()
andunMute()
have been deprecated. UsesetVolume(int volume)
instead.- Bugfix: When
YouTubePlayerView
is registered as aLifecycleObserver
, it pauses the video when the lifecycle stops, instead of when it pauses. This improves support for multi-window apps. - The sample app has been expanded with a live video example.
5.0.0
-
It is now possible to set a completely custom UI on the player.
By calling YouTubePlayerView's methodView inflateCustomPlayerUI(@LayoutRes int customPlayerUILayoutID)
.
This method takes as argument the ID of a layout resource. This layout will completely replace the default UI of the player.
After replacing the UI you won't be able to use the default UI controller (getPlayerUIController()
), it will be necessary to handle the new UI externally, in your own app.
A complete example can be seen here.
You can read more here. -
Removed
getCurrentState()
method from YouTubePlayer.
This method was adding useless noise to the API, therefore it has been removed.
A simple utility class has been added to the library in order to provide the same functionality:YouTubePlayerStateTracker
. You can read more here. -
If YouTubePlayerView is added as a lifecycle observer, it will automatically pause when the Activity/Fragment is paused.
If you want it to keep playing even when the Activity/Fragment is pause, just don't register it as a lifecycle observer. But remember to manually callrelease()
when the Activity/Fragment is destroyed. -
Brand new sample app
-
Sample app published on PlayStore