#cast #chromecast #google

rust_cast

Library that allows you to communicate with Google Cast enabled devices (e.g. Chromecast).

20 releases (13 breaking)

Uses new Rust 2021

0.17.0 Mar 20, 2022
0.16.0 Jan 10, 2021
0.15.1 Feb 25, 2020
0.14.0 Oct 15, 2018
0.8.1 Jul 29, 2016

#8 in Multimedia

Download history 395/week @ 2022-03-16 467/week @ 2022-03-23 579/week @ 2022-03-30 398/week @ 2022-04-06 339/week @ 2022-04-13 838/week @ 2022-04-20 857/week @ 2022-04-27 574/week @ 2022-05-04 614/week @ 2022-05-11 418/week @ 2022-05-18 414/week @ 2022-05-25 447/week @ 2022-06-01 270/week @ 2022-06-08 188/week @ 2022-06-15 251/week @ 2022-06-22 236/week @ 2022-06-29

976 downloads per month

MIT license

165KB
3.5K SLoC

Docs Build Status

Usage

Build

Proto files are taken from Chromium Open Screen GitHub mirror.

By default cargo build won't try to generate Rust code from the files located at protobuf/*, if you want to do that use GENERATE_PROTO environment variable during build and make sure you have protoc binary in $PATH:

$ GENERATE_PROTO=true cargo build

Run example

Generic features

First, you need to figure out the address of the device to connect to. For example, you can use avahi with the following command:

$ avahi-browse -a --resolve
// Get some info about the Google Cast enabled device (e.g. Chromecast). 
$ cargo run --example rust_caster -- -a 192.168.0.100 -i

Number of apps run: 1
App#0: Default Media Receiver (CC1AD845)
Volume level: 1
Muted: false

// Run specific app on the Chromecast.
$ cargo run --example rust_caster -- -a 192.168.0.100 -r youtube

// Stop specific active app.
$ cargo run --example rust_caster -- -a 192.168.0.100 -s youtube

// Stop currently active app.
$ cargo run --example rust_caster -- -a 192.168.0.100 --stop-current

The following app has been stopped: Default Media Receiver (CC1AD845)

Media features

// Stream a video.
$ cargo run --example rust_caster -- -a 192.168.0.100 -m http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4

// Stream a video of specific format with buffering.
$ cargo run --example rust_caster -- -a 192.168.0.100 -m http://xxx.webm --media-type video/webm --media-stream-type buffered

// Stream video from YouTube (doesn't work with the latest YouTube app, fix is welcome).
$ cargo run --example rust_caster -- -a 192.168.0.100 -m 7LcUOEP7Brc --media-app youtube

// Display an image.
$ cargo run --example rust_caster -- -a 192.168.0.100 -m https://azasypkin.github.io/style-my-image/images/mozilla.jpg

// Change volume level.
$ cargo run --example rust_caster -- -a 192.168.0.100 --media-volume 0.5

// Mute/unmute media.
$ cargo run --example rust_caster -- -a 192.168.0.100 --media-mute [--media-unmute]

// Pause media.
$ cargo run --example rust_caster -- -a 192.168.0.100 --media-app youtube --media-pause

// Resume/play media.
$ cargo run --example rust_caster -- -a 192.168.0.100 --media-app youtube --media-play

// Seek media.
$ cargo run --example rust_caster -- -a 192.168.0.100 --media-app youtube --media-seek 100

For all possible values of --media-type see Supported Media for Google Cast.

DNS TXT Record description

  • md - Model Name (e.g. "Chromecast");
  • id - UUID without hyphens of the particular device (e.g. xx12x3x456xx789xx01xx234x56789x0);
  • fn - Friendly Name of the device (e.g. "Living Room");
  • rs - Unknown (recent share???) (e.g. "Youtube TV");
  • bs - Uknonwn (e.g. "XX1XXX2X3456");
  • st - Unknown (e.g. "1");
  • ca - Unknown (e.g. "1234");
  • ic - Icon path (e.g. "/setup/icon.png");
  • ve - Version (e.g. "04").

Model names

  • Chromecast - Regular chromecast, supports video/audio;
  • Chromecast Audio - Chromecast Audio device, supports only audio.

Useful links and sources of inspiration

Dependencies

~3.5–4.5MB
~96K SLoC