This is a custom progress bar component for Roku that uses only Roku native components. It provides a simple and easy-to-use way to display progress information in your Roku channel.
To use this progress bar component in your Roku channel, you'll need to follow these steps:
-
Download the
ProgressBar.brs
andProgressBar.xml
files from this repository. -
Copy these files to your Roku project directory.
-
In your Roku SceneGraph XML file, add the following line to import the progress bar component:
<ProgressBar id="progressBar" width="1000" height="10" translation="[500, 500]" />
- In your Roku BrightScript code, get the instance of progressBar and give progress value
progressBar = m.top.findNode("progressBar")
progressBar.progress = 0.5
You can customize the appearance and behavior of the progress bar with interfaces exposed for this purposes. Or, you can have additional modifications by directly accessing the progressBar.xml file. This file contains the scene graph definition for the progress bar component, which you can modify to change its appearance, behavior, and functionality.
Interfaces available for customization are
<field id="progressBarBackgroundColor" value="#FFFF00" alias="backgroundRect.color" />
<field id="progressBarColor" value="#FF0000" alias="progressRect.color" />
<field id="scrubberColor" value="#FFFFFF" alias="scrubber.blendColor" />
The rectangles in this progressBar can be replaced with posters. This will help us achieve rounded corners for the bars.- But, for simplicity I'm not doing that here.
If you find a bug or would like to contribute to this project, please submit an issue or a pull request. I would be more than happy to see if someone actually using my code.
Feel free to use it anywhere you want.
If you have any questions or comments about this project, please contact me at gokulplkl@gmail.com