- Cast videos, music and pictures to:
- Chromecast devices
- Any device with web browser (other PC or smartphone)
- Media player app (eg. MPV, VLC)
- Supports external and built-in subtitles (along with custom fansubs)
- Chromecast remote controller (control playback from gnome top bar)
- Play on other device using integrated web player and change content without refreshing web page
- Transcode videos to supported format on the fly
- Optional VAAPI video encoding for low cpu usage
- Stream music with visualizations (requires fast cpu)
- Nautilus right click menu integration
Playercast app turns your media player on any other Linux device (e.g. HTPC, Raspberry Pi) into a media receiver that works similarly to Chromecast.
Expand extension functionality through Add-ons (experimental):
- Links Add-on - cast media from web pages
- Desktop Add-on - desktop streaming (early development stage - testers are welcome)
For latest release and changelog check out releases page.
Installation from source code is described in the wiki.
After enabling the extension, remember to install all requirements and npm dependencies.
Here is a list of required programs that Cast to TV depends on:
Please make sure you have all of the above installed.
- nautilus-python (for nautilus integration)
- cast-to-tv-config (manual Chromecast IP config tool - use when having problems with devices detection)
Nautilus extension is included in Cast to TV (since version 9).
Alternatively you can manually install nautilus-cast on which the included extension is based (please note that they are not the same).
You can optionally use hardware VAAPI encoding. This of course requires working VAAPI drivers. More info and how to install VAAPI here.
Having enabled universe repo run:
sudo apt install npm nodejs ffmpeg
Ubuntu is shipping wrong npm version for some reason.
Update it and clear bash cache:
sudo npm install -g npm
hash -r
Nautilus integration (optional):
sudo apt install python-nautilus python3-gi
Having enabled rpm fusion repos run:
sudo dnf install npm nodejs ffmpeg
Nautilus integration (optional):
sudo dnf install nautilus-python pygobject3 python3-gobject
sudo pacman -S npm nodejs ffmpeg
Nautilus integration (optional):
sudo pacman -S python-nautilus python-gobject2 python-gobject
Before using extension you also must install some additional npm packages.
You should also repeat this step when updating the extension to the new version, otherwise you may not have newly added or updated dependencies.
In version 9 and later this can be done from extension preferences.
Go to Cast Settings -> Modules
and click Install npm modules
button.
You must have npm
and nodejs
installed prior to this step.
Run below code in terminal:
cd ~/.local/share/gnome-shell/extensions/cast-to-tv@rafostar.github.com
npm install
Detailed instructions related to configuration and using the extension are in the wiki.
You can also find some usage examples and firewall config there.
Check out FAQ, before asking questions.
Preferred translation method is to use Cast to TV Crowdin web page.
Crowdin does not require any additional tools and translating can be done through web browser. You can login using GitHub account or create a new one. Only I can add new languages to this project, so if your language is not available, please contact me first (you can leave comment here).
Alternatively you can still use Makefile and tools like Poedit to generate translations:
make potfile
- generates updated POT file.
make mergepo
- merges changes from POT file into all PO files.
make compilemo
- compiles translation files.
After compiling restart gnome-shell for changes to be applied.
Special thanks go to Simon Kusterer (xat) for developing chromecast-player and Sam Potts for making Plyr, an awesome HTML5 video player.
Many thanks to Rendy Anthony for helping me make Nautilus integration based on his nautilus-cast extension.
Many thanks to everyone involved in translating this extension either through GitHub or Crowdin.
If you like my work please support it by buying me a cup of coffee :-)