Skip to main content

Cast All The Things allows you to send videos from many, many online sources to your Chromecast.

Project description

https://img.shields.io/pypi/v/catt.svg https://img.shields.io/travis/skorokithakis/catt.svg https://badges.gitter.im/Join%20Chat.svg

Cast All The Things allows you to send videos from many, many online sources (YouTube, Vimeo, and a few hundred others) to your Chromecast. It also allows you to cast local files or render websites.

Installation

You can install Cast All The Things with pip:

pip install catt

catt is only compatible with Python 3. If you need a Python 2-compatible version, please install 0.5.6, the last py2-compatible release.

Usage

To use Cast All The Things, just specify a URL:

catt cast "https://www.youtube.com/watch?v=dQw4w9WgXcQ"

catt supports any service that youtube-dl supports, which includes most online video hosting services.

catt can also cast local files (if they’re in a format the Chromecast supports natively):

catt cast ./myvideo.mp4

You can also control your Chromecast through catt commands, for example with catt pause. Try running catt --help to see the full list of commands.

If you have subtitles and the name is similar to the name of the local file, catt will add them automatically. You can, of course, specify any other subtitle if you want. Although Chromecast only supports WEBVTT, TTML and Line 21 subtitles, catt conveniently converts SRTs to WEBVTT for you on the fly. Here is how to use it:

catt cast -s ./mysubtitle.srt /myvideo.mp4

catt can also tell your Chromecast to display any website:

catt cast_site https://en.wikipedia.org/wiki/Rickrolling

Please note that the Chromecast has a slow CPU but a reasonably recent version of Google Chrome. The display resolution is 1280x720.

Configuration file

CATT can utilize a config-file stored at ~/.config/catt/catt.cfg (%APPDATA%\catt\catt.cfg on Windows).

The format is as following:

[options]
device = chromecast_one

[aliases]
one = chromecast_one
two = chromecast_two

In the [options] section, device denotes the default device that will be selected, when you have not selected a device via the cli.

You can write your choice of default device to catt.cfg by doing:

catt -d <name_of_chromecast> write_config

In the [aliases] section, you can specify aliases for the names of your chromecasts. You can then select a device just by doing:

catt -d <alias> <command>

Currently, in order to take advantage of this functionality, you need to manually edit catt.cfg

Contributing

If you want to contribute a feature to catt, please open an issue (or comment on an existing one) first, to make sure it’s something that the maintainers are interested in. Afterwards, just clone the repository and hack away!

To run catt in development, you can use the following command:

python -m catt.cli --help

Before committing, please make sure you install pre-commit and install its hooks:

pip install pre-commit
pre-commit install

That’s all, now you can commit and the hooks will run. Black (which is used to format the code) requires Python 3.6 to run, but please make the effort, as our CI will yell at you if the code is not formatted, and nobody wants that.

Thanks!

Info

  • Free software: BSD license

Features

  • Casts videos to Chromecast

  • From many, many online sources

  • Casts local files (videos, photos and music)

  • Casts any website to Chromecast

Thanks

Catt would not be possible without these great projects:

  • pychromecast - Library for Python 3 to communicate with the Google Chromecast

  • youtube-dl - Command-line program to download videos from YouTube.com and other video sites

  • casttube - YouTube Chromecast API

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

catt-0.10.2.tar.gz (26.1 kB view details)

Uploaded Source

Built Distribution

catt-0.10.2-py2.py3-none-any.whl (24.8 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file catt-0.10.2.tar.gz.

File metadata

  • Download URL: catt-0.10.2.tar.gz
  • Upload date:
  • Size: 26.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.34.0 CPython/3.7.3

File hashes

Hashes for catt-0.10.2.tar.gz
Algorithm Hash digest
SHA256 39b8b6d37b74da79882143ccbe3b1be840d6f185d433f2d81e1fe0b5b750ca58
MD5 e3c5d3578aa95c23ba07ba5ec58e19bd
BLAKE2b-256 9b96ffc87dd6f3a90e8bc8272924dfd09602f8ea9404c93d0f2e3e63c604d706

See more details on using hashes here.

File details

Details for the file catt-0.10.2-py2.py3-none-any.whl.

File metadata

  • Download URL: catt-0.10.2-py2.py3-none-any.whl
  • Upload date:
  • Size: 24.8 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.34.0 CPython/3.7.3

File hashes

Hashes for catt-0.10.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 6506a178f9ad369ad9ccad83d15756278d17746f198e6ac04729f66dd30a84a7
MD5 91bf6920f7d0072e7aab03bebd42646c
BLAKE2b-256 458ca6c0df9f5772bb7c18a945e1222fbf9aa1ee5a9ee2c1df5e319a10e43f36

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page