1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
|
"""
Example on how to use queuing with Media Controller
"""
# pylint: disable=invalid-name
import argparse
import sys
import time
import pychromecast
from .common import add_log_arguments, configure_logging
# Enable deprecation warnings etc.
if not sys.warnoptions:
import warnings
warnings.simplefilter("default")
# Change to the friendly name of your Chromecast
CAST_NAME = "Living Room"
# Change to an audio or video url
MEDIA_URLS = [
"https://www.bensound.com/bensound-music/bensound-jazzyfrenchy.mp3",
"https://audio.guim.co.uk/2020/08/14-65292-200817TIFXR.mp3",
]
parser = argparse.ArgumentParser(
description="Example on how to use the Media Controller with a queue."
)
parser.add_argument(
"--cast", help='Name of cast device (default: "%(default)s")', default=CAST_NAME
)
parser.add_argument(
"--known-host",
help="Add known host (IP), can be used multiple times",
action="append",
)
add_log_arguments(parser)
args = parser.parse_args()
configure_logging(args)
chromecasts, browser = pychromecast.get_listed_chromecasts(
friendly_names=[args.cast], known_hosts=args.known_host
)
if not chromecasts:
print(f'No chromecast with name "{args.cast}" discovered')
sys.exit(1)
cast = chromecasts[0]
# Start socket client's worker thread and wait for initial status update
cast.wait()
print(f'Found chromecast with name "{args.cast}"')
cast.media_controller.play_media(MEDIA_URLS[0], "audio/mp3")
# Wait for Chromecast to start playing
while cast.media_controller.status.player_state != "PLAYING":
time.sleep(0.1)
# Queue next items
for URL in MEDIA_URLS[1:]:
print("Enqueuing...")
cast.media_controller.play_media(URL, "audio/mp3", enqueue=True)
for URL in MEDIA_URLS[1:]:
time.sleep(5)
print("Skipping...")
cast.media_controller.queue_next()
# Shut down discovery
browser.stop_discovery()
|