Compare commits

..

No commits in common. "60ab02b4bac56084bdccfcd242926d68b137ba76" and "e794b336ee3a9ffe745d3c80a74f2db35241a8cc" have entirely different histories.

2 changed files with 13 additions and 42 deletions

View file

@ -2,7 +2,6 @@
import sys import sys
import threading import threading
import time import time
import os
from typing import Callable from typing import Callable
import pychromecast import pychromecast
@ -14,7 +13,7 @@ from vlc import Instance
from Channel import SVT from Channel import SVT
from ChannelProvider import ChannelProvider from ChannelProvider import ChannelProvider
from Utils import (get_all_svt_categories, make_bitmap_from_file, from Utils import (get_all_svt_categories, make_bitmap_from_file,
make_sized_button, BASEPATH) make_sized_button)
WIDTH = int(720 / 2) WIDTH = int(720 / 2)
HEIGHT = int(1440 / 2) HEIGHT = int(1440 / 2)
@ -44,9 +43,6 @@ class Cast(wx.Frame):
url = kw['url'] url = kw['url']
del kw['url'] del kw['url']
super().__init__(*args, **kw) super().__init__(*args, **kw)
if not os.path.isdir(BASEPATH):
os.mkdir(BASEPATH)
self.m_selected_chromecast = None self.m_selected_chromecast = None
self.SetSizeHints(WIDTH, HEIGHT, maxW=WIDTH) self.SetSizeHints(WIDTH, HEIGHT, maxW=WIDTH)
self.m_style = self.GetWindowStyle() self.m_style = self.GetWindowStyle()
@ -54,6 +50,7 @@ class Cast(wx.Frame):
args=(), args=(),
kwargs={}) kwargs={})
self.m_vlc = Instance() self.m_vlc = Instance()
self.m_vlc_medialist = self.m_vlc.media_list_new()
self.m_vlc_listplayer = self.m_vlc.media_list_player_new() self.m_vlc_listplayer = self.m_vlc.media_list_player_new()
self.m_chromecast_thr.start() self.m_chromecast_thr.start()
self.m_sizer: wx.Sizer = wx.BoxSizer(wx.VERTICAL) self.m_sizer: wx.Sizer = wx.BoxSizer(wx.VERTICAL)
@ -122,7 +119,8 @@ class Cast(wx.Frame):
inner_sizer.Add(stop_button, FLAGS) inner_sizer.Add(stop_button, FLAGS)
inner_sizer.Add(back_button, FLAGS) inner_sizer.Add(back_button, FLAGS)
if self.has_usable_chromecasts(): if not self.m_chromecast_thr.is_alive(
) and not self.m_selected_chromecast:
btm = make_bitmap_from_file( btm = make_bitmap_from_file(
'{}/assets/Cast.png'.format(self.asset_path), wx.Size(24, 24)) '{}/assets/Cast.png'.format(self.asset_path), wx.Size(24, 24))
cast_button = wx.BitmapButton(self.m_panel, cast_button = wx.BitmapButton(self.m_panel,
@ -190,19 +188,6 @@ class Cast(wx.Frame):
return providers return providers
def has_usable_chromecasts(self) -> bool:
if self.m_chromecast_thr.is_alive():
return False
if self.m_selected_chromecast:
return False
result = False
for cast in self.m_chromecasts:
if cast.cast_type != 'audio':
result = True
break
return result
def show_channel_list(self, _, provider_index) -> None: def show_channel_list(self, _, provider_index) -> None:
self.m_selected_provider_index = provider_index self.m_selected_provider_index = provider_index
self.m_selected_provider = self.m_providers[provider_index] self.m_selected_provider = self.m_providers[provider_index]
@ -358,10 +343,8 @@ class Cast(wx.Frame):
:param uri str: the link to the video stream :param uri str: the link to the video stream
""" """
media = self.m_vlc.media_new(uri) media = self.m_vlc.media_new(uri)
medialist = self.m_vlc.media_list_new() self.m_vlc_medialist.add_media(media)
self.m_vlc_listplayer.set_media_list(self.m_vlc_medialist)
medialist.add_media(media)
self.m_vlc_listplayer.set_media_list(medialist)
self.m_sizer.Clear(delete_windows=True) self.m_sizer.Clear(delete_windows=True)
self.m_sizer = wx.BoxSizer(wx.VERTICAL) self.m_sizer = wx.BoxSizer(wx.VERTICAL)
@ -387,17 +370,11 @@ class Cast(wx.Frame):
self.m_sizer.Add(cancel_btn) self.m_sizer.Add(cancel_btn)
for cast in self.m_chromecasts: for cast in self.m_chromecasts:
if cast.cast_type == 'audio': friendly_name = cast.device.friendly_name
continue
friendly_name = "Unknown Chromecast"
try:
friendly_name = cast.device.friendly_name
except AttributeError:
friendly_name = cast.cast_info.friendly_name
btn = wx.Button(self.m_panel, btn = wx.Button(self.m_panel,
id=-1, id=-1,
label=friendly_name, label=friendly_name,
size=(WIDTH, BTN_HEIGHT)) size=(WIDTH, BTN_HEIGHT))
btn.Bind( btn.Bind(
wx.EVT_BUTTON, wx.EVT_BUTTON,
lambda event, chromecast=cast, muri=uri, cindex=channel_index: lambda event, chromecast=cast, muri=uri, cindex=channel_index:

View file

@ -106,14 +106,8 @@ class SVT(Channel):
entries = get_svt_category(self.m_id) entries = get_svt_category(self.m_id)
for entry in entries: for entry in entries:
elem = entry["item"] elem = entry["item"]
imgformat = "wide"
if not "wide" in elem["images"].keys():
if "cleanWide" in elem["images"].keys():
imgformat = "cleanWide"
else:
continue
url = elem["urls"]["svtplay"] url = elem["urls"]["svtplay"]
video_id = hash_string(url) video_id = hash_string(url.split('/')[1])
svt_id = elem["videoSvtId"] svt_id = elem["videoSvtId"]
resolved_link = self.resolve_link(svt_id) resolved_link = self.resolve_link(svt_id)
if not resolved_link: if not resolved_link:
@ -122,8 +116,8 @@ class SVT(Channel):
description = str(entry["description"]) description = str(entry["description"])
published_parsed = datetime.now() published_parsed = datetime.now()
thumbnail_link = get_svt_thumb_from_id_changed( thumbnail_link = get_svt_thumb_from_id_changed(
elem['images'][imgformat]["id"], elem['images']["wide"]["id"],
elem['images'][imgformat]["changed"], elem['images']["wide"]["changed"],
size=self.m_screen_width) size=self.m_screen_width)
thumbnail = make_bitmap_from_url( thumbnail = make_bitmap_from_url(
thumbnail_link, wx.Size(int(self.m_screen_width), 150), video_id) thumbnail_link, wx.Size(int(self.m_screen_width), 150), video_id)