getmarketimage added
This commit is contained in:
parent
0ba67be356
commit
0307cd9d23
220
stockTicker.py
220
stockTicker.py
@ -70,7 +70,7 @@ class StockTicker():
|
|||||||
'Daily Forecast':self.getDailyWeatherImage, 'Current Weather': self.getTodayWeatherImage, 'Jokes': self.getJokesImage,
|
'Daily Forecast':self.getDailyWeatherImage, 'Current Weather': self.getTodayWeatherImage, 'Jokes': self.getJokesImage,
|
||||||
'Sports (Team Stats)':lambda : self.getLeagueTableImage('premier_league'), 'Sports (Past Games)': lambda:self.getLeagueImage('NBA', 'past'),
|
'Sports (Team Stats)':lambda : self.getLeagueTableImage('premier_league'), 'Sports (Past Games)': lambda:self.getLeagueImage('NBA', 'past'),
|
||||||
'Sports (Upcoming Games)': lambda : self.getLeagueImage('NHL', 'future'), 'Sports (Live Games)': lambda: self.getLeagueImage('NBA', 'live'),
|
'Sports (Upcoming Games)': lambda : self.getLeagueImage('NHL', 'future'), 'Sports (Live Games)': lambda: self.getLeagueImage('NBA', 'live'),
|
||||||
'News':self.getNewsImage, 'Custom Messages': self.getUserMessages, 'Commodities': self.getCommoditiesImage, 'Indices': self.getIndicesImage, 'Movies': self.getMoviesImage,
|
'News':self.getNewsImage, 'Custom Messages': self.getUserMessages, 'Commodities': self.getCommoditiesImage, 'Indices': self.getIndicesImage, 'Movies': self.getMoviesImage, 'Gainers, Losers, Active': self.getMarketImage,
|
||||||
'Economic Calendar': self.getEconomicImage, 'IPO Calendar':self.getIpoImage, 'IPO Calendar Prof':self.getIpoProfessional, 'Economic Calendar Prof': self.getEconomicProfessional,
|
'Economic Calendar': self.getEconomicImage, 'IPO Calendar':self.getIpoImage, 'IPO Calendar Prof':self.getIpoProfessional, 'Economic Calendar Prof': self.getEconomicProfessional,
|
||||||
|
|
||||||
'Stocks Prof': self.getStockProfessional, 'Crypto Prof': self.getCryptoProfessional, 'Forex Prof': self.getForexProfessional, 'Jokes Prof': self.getJokesProfessional,
|
'Stocks Prof': self.getStockProfessional, 'Crypto Prof': self.getCryptoProfessional, 'Forex Prof': self.getForexProfessional, 'Jokes Prof': self.getJokesProfessional,
|
||||||
@ -85,7 +85,8 @@ class StockTicker():
|
|||||||
'News':'csv/news_settings.json', 'Custom Images': 'csv/image_settings.json', 'Custom GIFs': 'csv/GIF_settings.json', 'Custom Messages': 'csv/message_settings.json',
|
'News':'csv/news_settings.json', 'Custom Images': 'csv/image_settings.json', 'Custom GIFs': 'csv/GIF_settings.json', 'Custom Messages': 'csv/message_settings.json',
|
||||||
'Stocks Prof': 'csv/stocks_settings.json', 'Crypto Prof': 'csv/crypto_settings.json', 'Forex Prof': 'csv/forex_settings.json', 'Jokes Prof': 'csv/jokes_settings.json',
|
'Stocks Prof': 'csv/stocks_settings.json', 'Crypto Prof': 'csv/crypto_settings.json', 'Forex Prof': 'csv/forex_settings.json', 'Jokes Prof': 'csv/jokes_settings.json',
|
||||||
'Current Weather Prof': 'csv/current_weather.json', 'News Prof':'csv/news_settings.json', 'Commodities Prof':'csv/commodities_settings.json', 'Indices Prof': 'csv/indices_settings.json',
|
'Current Weather Prof': 'csv/current_weather.json', 'News Prof':'csv/news_settings.json', 'Commodities Prof':'csv/commodities_settings.json', 'Indices Prof': 'csv/indices_settings.json',
|
||||||
'Daily Forecast Prof':'csv/daily_weather.json', 'Sports (Team Stats) Prof': 'csv/league_tables.json', 'Sports (Upcoming Games) Prof': 'csv/upcoming_games.json', 'Sports (Past Games) Prof': 'csv/past_games.json', 'Custom Messages Prof': 'csv/message_settings.json', 'Custom Images Prof': 'csv/image_settings.json', 'Movies Prof': 'csv/movie_settings.json', 'Sports (Live Games) Prof': 'csv/live_games.json', 'IPO Calendar Prof': 'csv/ipo_settings.json', 'Economic Calendar Prof': 'csv/economic_settings.json'}
|
'Daily Forecast Prof':'csv/daily_weather.json', 'Sports (Team Stats) Prof': 'csv/league_tables.json', 'Sports (Upcoming Games) Prof': 'csv/upcoming_games.json', 'Sports (Past Games) Prof': 'csv/past_games.json', 'Custom Messages Prof': 'csv/message_settings.json', 'Custom Images Prof': 'csv/image_settings.json', 'Movies Prof': 'csv/movie_settings.json', 'Sports (Live Games) Prof': 'csv/live_games.json', 'IPO Calendar Prof': 'csv/ipo_settings.json', 'Economic Calendar Prof': 'csv/economic_settings.json',
|
||||||
|
'Gainers, Losers, Active':'csv/market_settings.json'}
|
||||||
|
|
||||||
|
|
||||||
def openImage(self, image_file):
|
def openImage(self, image_file):
|
||||||
@ -6460,6 +6461,216 @@ class StockTicker():
|
|||||||
|
|
||||||
return self.stitchImage(image_list)
|
return self.stitchImage(image_list)
|
||||||
|
|
||||||
|
|
||||||
|
def getMarketImage(self):
|
||||||
|
f = open('csv/market_settings.json', 'r')
|
||||||
|
market_settings = json.load(f)
|
||||||
|
f.close()
|
||||||
|
#if market_settings['title']:
|
||||||
|
# title_img = self.openImage('feature_titles/market.png')
|
||||||
|
# image_list = [title_img]
|
||||||
|
# image_list.append(self.blank)
|
||||||
|
#else:
|
||||||
|
image_list = []
|
||||||
|
|
||||||
|
active_info = market_settings['mostactive']
|
||||||
|
active_symbols = list(active_info.keys())
|
||||||
|
gainers_info = market_settings['gainers']
|
||||||
|
gainers_symbols = list(gainers_info.keys())
|
||||||
|
losers_info = market_settings['losers']
|
||||||
|
losers_symbols = list(losers_info.keys())
|
||||||
|
|
||||||
|
if not market_settings['percent']:
|
||||||
|
percent_change = False
|
||||||
|
if not market_settings['point']:
|
||||||
|
point_change = False
|
||||||
|
|
||||||
|
for category in market_settings['categories']:
|
||||||
|
if category == 'Most Active':
|
||||||
|
most_active = self.openImage('logos/active.png')
|
||||||
|
image_list.append(most_active)
|
||||||
|
for i, symbol in enumerate(active_symbols):
|
||||||
|
try:
|
||||||
|
info = active_info[symbol]
|
||||||
|
change = float(info['change']) #TEXT
|
||||||
|
ticker = symbol #TEXT
|
||||||
|
arrow, change = self.getArrow(change)
|
||||||
|
percent_change = '%.2f' % abs(float(info['percent_change'])) + '%'
|
||||||
|
point_change = '%.2f' % abs(change)
|
||||||
|
current = '%.2f' % float(info['current']) #TEXT
|
||||||
|
midFrame = self.textToImage(ticker, current, arrow, percent_change, point_change) #IMAGE THE TEXT
|
||||||
|
if market_settings['logos']:
|
||||||
|
try:
|
||||||
|
logos_path = os.path.join(os.path.join(os.path.dirname(os.path.abspath(__file__)), 'logos'), 'stocks')
|
||||||
|
logo = self.openImage(os.path.join(logos_path, ticker + '.png'))
|
||||||
|
stitchedStock = self.stitchImage([logo,midFrame])
|
||||||
|
except Exception as e:
|
||||||
|
stitchedStock = midFrame
|
||||||
|
else:
|
||||||
|
stitchedStock = midFrame
|
||||||
|
try:
|
||||||
|
if market_settings['lohivol']:
|
||||||
|
font = ImageFont.load("./fonts/5x8.pil")
|
||||||
|
try:
|
||||||
|
day_low = '%.2f' % float(info['day_low'])
|
||||||
|
day_high = '%.2f' % float(info['day_high'])
|
||||||
|
volume = info['volume']
|
||||||
|
|
||||||
|
daylow_img = self.textImage(day_low, font, r=0, g=255, b=0)
|
||||||
|
daylow_t_img = self.textImage('Lo', font, r=255, g=255, b=255)
|
||||||
|
dayhi_img = self.textImage(day_high, font, r=0,g=255,b=0)
|
||||||
|
dayhi_t_img = self.textImage('Hi', font, r=255,g=255,b=255)
|
||||||
|
vol_img = self.textImage(volume, font, r=0,g=255,b=0)
|
||||||
|
vol_t_img = self.textImage('Vol', font, r=255,g=255,b=255)
|
||||||
|
lohivol_img = Image.new('RGB', (max(daylow_img.size[0] + daylow_t_img.size[0], dayhi_img.size[0] + dayhi_t_img.size[0],
|
||||||
|
vol_img.size[0] + vol_t_img.size[0]) + 5, 32))
|
||||||
|
lohivol_img.paste(daylow_t_img, (0, 3))
|
||||||
|
lohivol_img.paste(daylow_img, (daylow_t_img.size[0],3))
|
||||||
|
lohivol_img.paste(dayhi_t_img, (0, 12))
|
||||||
|
lohivol_img.paste(dayhi_img, (dayhi_t_img.size[0], 12))
|
||||||
|
lohivol_img.paste(vol_t_img, (0, 21))
|
||||||
|
lohivol_img.paste(vol_img, (vol_t_img.size[0], 21))
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
image_list.append(stitchedStock)
|
||||||
|
try:
|
||||||
|
if market_settings['lohivol']:
|
||||||
|
try:
|
||||||
|
image_list.append(lohivol_img)
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
image_list.append(self.blank)
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
|
||||||
|
elif category == 'Top Gainers':
|
||||||
|
top_gainers = self.openImage('logos/gainers.png')
|
||||||
|
image_list.append(top_gainers)
|
||||||
|
for i, symbol in enumerate(gainers_symbols):
|
||||||
|
try:
|
||||||
|
info = gainers_info[symbol]
|
||||||
|
change = float(info['change']) #TEXT
|
||||||
|
ticker = symbol #TEXT
|
||||||
|
arrow, change = self.getArrow(change)
|
||||||
|
percent_change = '%.2f' % abs(float(info['percent_change'])) + '%'
|
||||||
|
point_change = '%.2f' % abs(change)
|
||||||
|
current = '%.2f' % float(info['current']) #TEXT
|
||||||
|
midFrame = self.textToImage(ticker, current, arrow, percent_change, point_change) #IMAGE THE TEXT
|
||||||
|
if market_settings['logos']:
|
||||||
|
try:
|
||||||
|
logos_path = os.path.join(os.path.join(os.path.dirname(os.path.abspath(__file__)), 'logos'), 'stocks')
|
||||||
|
logo = self.openImage(os.path.join(logos_path, ticker + '.png'))
|
||||||
|
stitchedStock = self.stitchImage([logo,midFrame])
|
||||||
|
except Exception as e:
|
||||||
|
stitchedStock = midFrame
|
||||||
|
else:
|
||||||
|
stitchedStock = midFrame
|
||||||
|
try:
|
||||||
|
if market_settings['lohivol']:
|
||||||
|
font = ImageFont.load("./fonts/5x8.pil")
|
||||||
|
try:
|
||||||
|
day_low = '%.2f' % float(info['day_low'])
|
||||||
|
day_high = '%.2f' % float(info['day_high'])
|
||||||
|
volume = info['volume']
|
||||||
|
|
||||||
|
daylow_img = self.textImage(day_low, font, r=0, g=255, b=0)
|
||||||
|
daylow_t_img = self.textImage('Lo', font, r=255, g=255, b=255)
|
||||||
|
dayhi_img = self.textImage(day_high, font, r=0,g=255,b=0)
|
||||||
|
dayhi_t_img = self.textImage('Hi', font, r=255,g=255,b=255)
|
||||||
|
vol_img = self.textImage(volume, font, r=0,g=255,b=0)
|
||||||
|
vol_t_img = self.textImage('Vol', font, r=255,g=255,b=255)
|
||||||
|
lohivol_img = Image.new('RGB', (max(daylow_img.size[0] + daylow_t_img.size[0], dayhi_img.size[0] + dayhi_t_img.size[0],
|
||||||
|
vol_img.size[0] + vol_t_img.size[0]) + 5, 32))
|
||||||
|
lohivol_img.paste(daylow_t_img, (0, 3))
|
||||||
|
lohivol_img.paste(daylow_img, (daylow_t_img.size[0],3))
|
||||||
|
lohivol_img.paste(dayhi_t_img, (0, 12))
|
||||||
|
lohivol_img.paste(dayhi_img, (dayhi_t_img.size[0], 12))
|
||||||
|
lohivol_img.paste(vol_t_img, (0, 21))
|
||||||
|
lohivol_img.paste(vol_img, (vol_t_img.size[0], 21))
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
image_list.append(stitchedStock)
|
||||||
|
try:
|
||||||
|
if market_settings['lohivol']:
|
||||||
|
try:
|
||||||
|
image_list.append(lohivol_img)
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
image_list.append(self.blank)
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
|
||||||
|
elif category == 'Top Losers':
|
||||||
|
top_losers = self.openImage('logos/losers.png')
|
||||||
|
image_list.append(top_losers)
|
||||||
|
for i, symbol in enumerate(losers_symbols):
|
||||||
|
try:
|
||||||
|
info = losers_info[symbol]
|
||||||
|
change = float(info['change']) #TEXT
|
||||||
|
ticker = symbol #TEXT
|
||||||
|
arrow, change = self.getArrow(change)
|
||||||
|
percent_change = '%.2f' % abs(float(info['percent_change'])) + '%'
|
||||||
|
point_change = '%.2f' % abs(change)
|
||||||
|
current = '%.2f' % float(info['current']) #TEXT
|
||||||
|
midFrame = self.textToImage(ticker, current, arrow, percent_change, point_change) #IMAGE THE TEXT
|
||||||
|
if market_settings['logos']:
|
||||||
|
try:
|
||||||
|
logos_path = os.path.join(os.path.join(os.path.dirname(os.path.abspath(__file__)), 'logos'), 'stocks')
|
||||||
|
logo = self.openImage(os.path.join(logos_path, ticker + '.png'))
|
||||||
|
stitchedStock = self.stitchImage([logo,midFrame])
|
||||||
|
except Exception as e:
|
||||||
|
stitchedStock = midFrame
|
||||||
|
else:
|
||||||
|
stitchedStock = midFrame
|
||||||
|
try:
|
||||||
|
if market_settings['lohivol']:
|
||||||
|
font = ImageFont.load("./fonts/5x8.pil")
|
||||||
|
try:
|
||||||
|
day_low = '%.2f' % float(info['day_low'])
|
||||||
|
day_high = '%.2f' % float(info['day_high'])
|
||||||
|
volume = info['volume']
|
||||||
|
|
||||||
|
daylow_img = self.textImage(day_low, font, r=0, g=255, b=0)
|
||||||
|
daylow_t_img = self.textImage('Lo', font, r=255, g=255, b=255)
|
||||||
|
dayhi_img = self.textImage(day_high, font, r=0,g=255,b=0)
|
||||||
|
dayhi_t_img = self.textImage('Hi', font, r=255,g=255,b=255)
|
||||||
|
vol_img = self.textImage(volume, font, r=0,g=255,b=0)
|
||||||
|
vol_t_img = self.textImage('Vol', font, r=255,g=255,b=255)
|
||||||
|
lohivol_img = Image.new('RGB', (max(daylow_img.size[0] + daylow_t_img.size[0], dayhi_img.size[0] + dayhi_t_img.size[0],
|
||||||
|
vol_img.size[0] + vol_t_img.size[0]) + 5, 32))
|
||||||
|
lohivol_img.paste(daylow_t_img, (0, 3))
|
||||||
|
lohivol_img.paste(daylow_img, (daylow_t_img.size[0],3))
|
||||||
|
lohivol_img.paste(dayhi_t_img, (0, 12))
|
||||||
|
lohivol_img.paste(dayhi_img, (dayhi_t_img.size[0], 12))
|
||||||
|
lohivol_img.paste(vol_t_img, (0, 21))
|
||||||
|
lohivol_img.paste(vol_img, (vol_t_img.size[0], 21))
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
image_list.append(stitchedStock)
|
||||||
|
try:
|
||||||
|
if market_settings['lohivol']:
|
||||||
|
try:
|
||||||
|
image_list.append(lohivol_img)
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
image_list.append(self.blank)
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
finalDisplayImage = self.stitchImage(image_list)
|
||||||
|
return finalDisplayImage
|
||||||
|
|
||||||
|
|
||||||
def ip_viewer(self):
|
def ip_viewer(self):
|
||||||
|
|
||||||
@ -6628,7 +6839,10 @@ class StockTicker():
|
|||||||
|
|
||||||
elif msg == 'JO': # jokes
|
elif msg == 'JO': # jokes
|
||||||
self.scrollFunctionsAnimated(['jokes', 'jokes'],animation = 'traditional')
|
self.scrollFunctionsAnimated(['jokes', 'jokes'],animation = 'traditional')
|
||||||
|
|
||||||
|
elif msg == 'MA': # market
|
||||||
|
self.scrollFunctionsAnimated(['market', 'market'],animation = 'traditional')
|
||||||
|
|
||||||
elif msg == 'A': #everything
|
elif msg == 'A': #everything
|
||||||
|
|
||||||
#userSettings = ['display_gif', 'text', 'display_image', 'stocks', 'crypto', 'forex', 'today_weather', 'daily_weather', 'league_table', 'league_games', 'news'] # these wil be read from csv, just for demo
|
#userSettings = ['display_gif', 'text', 'display_image', 'stocks', 'crypto', 'forex', 'today_weather', 'daily_weather', 'league_table', 'league_games', 'news'] # these wil be read from csv, just for demo
|
||||||
|
Loading…
Reference in New Issue
Block a user