This project contains a sample Android application showcasing the usage of Bambuser's Player SDK.
It can be significantly configured and lets you listen for player-emitted events and perform player-specific functions.
These are a few screenshots of the Player SDK in action.
This library targets Android 34, and the minimal support API is 26 (Android 8+) We are using firebase-bom version 32.7.1
First, add a new maven repository to your dependency resolution management:
repositories {
google()
mavenCentral()
// other repositories you might have...
maven {
url "https://repo.repsy.io/mvn/bambuser/default"
}
}
Then add the dependency into your app/build.gradle
:
implementation "com.bambuser:player-sdk:(insert the latest version)"
An LVS player is a dedicated Android Activity that can be initialized in the following way:
LVSPlayer.startActivity(
context = Your Android context,
showId = The ID of the show to watch,
configuration = Configuration(...), // Configuration that enable/disable features and UI elements in the player
eventObserver = EventObserver(...), // Optional interface that receives the player events
)
The player's attributes can be configured by providing a Configuration
object when the LVSPlayer
is created.
The supported properties are:
Property | Type | functionality |
---|---|---|
isEUServer |
Boolean | Define if the show that is to be viewed is stored on an EU server or not |
showHighlightedProducts |
Boolean | Toggle the visibility of products during a show |
showChat |
Boolean | Toggle the visibility of the chat during a show |
showProductsOnEndCurtain |
Boolean | Toggle the visibility of products on the end of the show curtain |
enablePictureInPicture |
Boolean | Allow the player to be opened in Picture in Picture (PiP) mode |
enableProductDetailsPage |
Boolean | Allow a Product Details Page (PDP) to be opened when a product highlight is clicked If disabled, an OnProductHighlightClicked-Event will still be sent when a product is clicked |
showShoppingCart |
Boolean | Toggle the visibility of an icon that opens the current shopping cart |
showLikes |
Boolean | Toggle the feature to send and view likes during a show |
preferredLocale |
String | Define which locale should be used when fetching localized strings, defaults to en-US |
showNumberOfViewers |
Boolean | Toggle the visibility of the viewer count in the top bar |
conversionTrackingTTLDays |
Int | Changes the expiration time for Conversion Tracking and consequently the duration of the time that purchases are being tracked, defaults to 30 |
If an EventObserver
is provided when the LVSPlayer
is created, the following events can be observed:
Event | Emitted when | Parameters |
---|---|---|
OnPlay |
The show starts playing | showId: String - Id of show title: String - The title of the show isLive: Boolean - Is the show live |
OnPaused |
The show is paused by the viewer | - |
OnSeek |
The viewer seeks during a show | - |
OnProductHighlightClicked |
A product is clicked | product: Product - A model representing the product that was clicked |
OnSeekToProductHighlightClicked |
The seek button on a product card is clicked | product: Product - A model representing the product that was clicked |
OnAddToCalendar |
The add to calendar button on the pre-live curtain is clicked, if the show has a scheduled start time | date: Long - The shows scheduled start time durationInMilliseconds: Int - Duration of the show in milliseconds url: String? - The show url showId: String - The show Id title: String - The title of the show description: String? - The description of the show |
OnShare |
The share button is clicked | url - Url of show |
OnReplay |
The replay button on the ended-show curtain is clicked | - |
OnCartClicked |
The cart button is clicked | - |
OnMessageSent |
A chat message is sent through the player | - |
OnTermsAndConditionsLinkClicked |
The user clicks on the link to view the terms and conditions for the chat | link: String - The link that was clicked |
OnChatMessageLinkClicked |
The user clicks on a link in a chat message | link: String - The link that was clicked |
OnProductDescriptionLinkClicked |
The user clicks on the product description link | link: String - The link that was clicked |
OnSendLike |
The user sends a like using the heart button, multiple likes within a short time span will be lumped together into the same event | count: Int - The amount of likes that where sent |
OnMessageReceived |
A new message was received from the backend | - |
OnMinimizeClicked |
The user clicks on the minimize button. This will make the player enter PiP mode if it is enabled. Otherwise the player will be closed | - |
PDPEvent.OnBuyClicked |
The user clicks on the buy button inside of the PDP | product: Product - A model representing the product to be opened colorVariantId: String? - Color variant id of the product sizeVariantId: String? - Size variant id of the product |
PDPEvent.OnOpenClicked |
The user clicks on the open button inside of the light PDP | product: Product - A model representing the product to be opened |
OnError |
The player encounters an error | lvsPlayerError: LVSPlayerError - The error that occurred |
OnClose |
The player was closed | - |
PlayerCartCheckoutTapped |
The user clicks the checkout button in the cart | - |
PlayerCartItemUpdated |
The player cart is updated | item: CartProduct - A model representing the product in the cart isRemoved: Boolean - Is the product removed from the cart |
Currently, whenever an
OnError
event is emitted, theLVSPlayer
activity is destroyed. This behavior is likely going to change in future releases.
An alternative way to observe the LVSPlayerEvents
is to listen directly to a LVSPlayerEvent
-flow from the LVSPlayer
. This can be reached in the following way:
val lvsPlayerEventsFlow = LVSPlayer.observeEvents(playerId)
The LVSPlayer
can be used to perform actions on an initialized player.
A playerId
must be provided to indicate which player the action should be performed on.
val action = LVSPlayerInputAction.Play(playerId)
LVSPlayer.performAction(action)
The following actions are currently available:
Action | Result | Parameters |
---|---|---|
Minimize |
If the player is not in PiP mode; it enters PiP mode | playerId: String - The id of the player where the action will be performed |
Maximize |
If the player is in PiP mode; it leaves PiP mode and returns to normal mode | playerId: String - The id of the player where the action will be performed |
Close |
The player is closed down and the activity ended | playerId: String - The id of the player where the action will be performed |
Play |
The player attempts to start playing it's current show | playerId: String - The id of the player where the action will be performed |
Pause |
The player attempts to pause playing it's current show | playerId: String - The id of the player where the action will be performed |
Replay |
The player attempts to restart it's current show | playerId: String - The id of the player where the action will be performed |
SendLike |
A like is sent to the current show | playerId: String - The id of the player where the action will be performed count: Int = 1 - The amount of likes to send any value given will be coerced between 1 and 100 duration: Double = 100.0 - The duration of the likes to send, any value given will be coerced between 1.0 and 1000.0 |
ToggleChatVisibility |
The visibility of the chat is toggled | playerId: String - The id of the player where the action will be performed |
The LVSPlayer
can be used to perform actions with data collected during a show.
LVSPlayer.trackPurchase(context, isEUServer, orderId, orderValue, orderProductIds, currency, orderCountry)
The following actions are currently available:
Action | Result | Parameters |
---|---|---|
trackPurchase |
Perform conversion tracking | context - Application context isEUServer - Is the server restricted to EU orderId - The id of the order orderValue: Double - Total amount of the order orderProductIds: List<String> - Product id's of sold products currency: String - Currency used in transaction orderCountry: String? = null - Country in which the transaction was made |
clearTrackingData |
Clear conversion tracking data | context - Application context isEUServer - Is the server restricted to EU |
playerCartSyncItem |
Sync cart changes with the player | context - Application context isEUServer - Is the server restricted to EU cartProduct: CartProduct - The product being synced isRemove: Boolean - Is the product removed from the cart |
playerCartInit |
Init player cart with cart products | context - Application context isEUServer - Is the server restricted to EU cartProducts: List<CartProduct> - The initial cart products |
provideProductDetails |
Provide function for returning full product details | onProductDetailsRequested - Function in which you can provide us with more information for full PDP |
You might find issues when using custom worker factories in your Android application after initializing the LVSPlayer
. If that is your case, merge your factories with our LVSWorkerFactory
with the help of the DelegatingWorkerFactory
. See the example below:
val factory = DelegatingWorkerFactory()
.apply {
addFactory(yourCustomFactory) // Add your factories
addFactory(LVSWorkerFactory()) // This is our own worker factory
}
val conf = Configuration.Builder()
.setWorkerFactory(factory)
// Other configurations you might have...
.build()
WorkManager.initialize(yourContext, conf)
The app
folder contains a demo app, which can be used as an example of how to set up and configure an LVSPlayer
.
- Closing PiP does not stop the player instance, and the audio keeps playing until you close the app. Bambuser would recommend to not use PiP until this issue is resolved