2021-10-24 01:45:45 -06:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2021-11-20 09:17:43 -07:00
|
|
|
"github.com/aditya-K2/goMP/cache"
|
2021-12-12 13:05:40 -07:00
|
|
|
"github.com/aditya-K2/goMP/utils"
|
2021-11-05 01:10:46 -06:00
|
|
|
"github.com/spf13/viper"
|
2021-10-24 01:45:45 -06:00
|
|
|
"gitlab.com/diamondburned/ueberzug-go"
|
|
|
|
)
|
|
|
|
|
|
|
|
/*
|
|
|
|
Renderer is just a channel on which we will send the Path to the song whose
|
|
|
|
Image is to be Rendered. This channel is passed to the openImage which in turn is called
|
|
|
|
by the Start() function as a go routine.
|
|
|
|
*/
|
|
|
|
type Renderer struct {
|
|
|
|
c chan string
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
Returns a new Renderer with a string channel
|
|
|
|
*/
|
|
|
|
func newRenderer() *Renderer {
|
|
|
|
c := make(chan string)
|
|
|
|
return &Renderer{
|
|
|
|
c: c,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
Send Image Path to Renderer
|
|
|
|
*/
|
|
|
|
func (self *Renderer) Send(path string) {
|
|
|
|
self.c <- path
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|
|
|
Go Routine that will Be Called and will listen on the channel c
|
|
|
|
for changes and on getting a string over the channel will open the Image and
|
|
|
|
keep listening again. This will keep the image blocked ( i.e no need to use time.Sleep() etc. )
|
|
|
|
and saves resources too.
|
|
|
|
|
|
|
|
*/
|
|
|
|
func openImage(path string, c chan string) {
|
2021-12-12 13:05:40 -07:00
|
|
|
fw, fh := utils.GetFontWidth()
|
2021-10-24 01:45:45 -06:00
|
|
|
var im *ueberzug.Image
|
|
|
|
if path != "stop" {
|
2021-11-20 09:45:10 -07:00
|
|
|
extractedImage := getImagePath(path)
|
2021-11-12 23:14:49 -07:00
|
|
|
img2, _ := getImg(extractedImage)
|
2021-11-05 01:10:46 -06:00
|
|
|
im, _ = ueberzug.NewImage(img2, int(float32(IMG_X)*fw)+viper.GetInt("ADDITIONAL_PADDING_X"), int(float32(IMG_Y)*fh)+viper.GetInt("ADDITIONAL_PADDING_Y"))
|
2021-10-24 01:45:45 -06:00
|
|
|
}
|
|
|
|
d := <-c
|
|
|
|
if im != nil {
|
|
|
|
im.Clear()
|
|
|
|
}
|
|
|
|
if d != "stop" {
|
|
|
|
openImage(d, c)
|
|
|
|
} else {
|
|
|
|
openImage("stop", c)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
Initialises the Renderer and calls the go routine openImage and passes the channel
|
|
|
|
as argument.
|
|
|
|
*/
|
|
|
|
func (self *Renderer) Start(path string) {
|
|
|
|
go openImage(path, self.c)
|
|
|
|
}
|
2021-11-20 09:45:10 -07:00
|
|
|
|
|
|
|
/*
|
|
|
|
This Function returns the path to the image that is to be rendered it checks first for the image in the cache
|
|
|
|
else it adds the image to the cache and then extracts it and renders it.
|
|
|
|
*/
|
|
|
|
func getImagePath(path string) string {
|
|
|
|
a, err := CONN.ListInfo(path)
|
|
|
|
var extractedImage string
|
|
|
|
if err == nil && len(a) != 0 {
|
2021-12-08 14:02:02 -07:00
|
|
|
if cache.Exists(a[0]["artist"], a[0]["album"]) {
|
|
|
|
extractedImage = cache.GenerateName(a[0]["artist"], a[0]["album"])
|
2021-11-20 09:45:10 -07:00
|
|
|
} else {
|
2021-12-08 14:02:02 -07:00
|
|
|
imagePath := cache.GenerateName(a[0]["artist"], a[0]["album"])
|
2021-12-12 13:05:40 -07:00
|
|
|
absPath := utils.CheckDirectoryFmt(viper.GetString("MUSIC_DIRECTORY")) + path
|
2021-11-20 09:45:10 -07:00
|
|
|
extractedImage = extractImageFromFile(absPath, imagePath)
|
|
|
|
if extractedImage == viper.GetString("DEFAULT_IMAGE_PATH") && viper.GetString("GET_COVER_ART_FROM_LAST_FM") == "TRUE" {
|
|
|
|
downloadedImage, err := getImageFromLastFM(a[0]["artist"], a[0]["album"], imagePath)
|
|
|
|
if err == nil {
|
|
|
|
NOTIFICATION_SERVER.Send("Image From LastFM")
|
|
|
|
extractedImage = downloadedImage
|
2021-11-26 09:32:20 -07:00
|
|
|
} else {
|
2021-11-28 11:08:52 -07:00
|
|
|
NOTIFICATION_SERVER.Send("Falling Back to Default Image.")
|
2021-11-20 09:45:10 -07:00
|
|
|
}
|
2021-11-28 11:08:52 -07:00
|
|
|
} else {
|
|
|
|
NOTIFICATION_SERVER.Send("Extracted Image Successfully")
|
2021-11-20 09:45:10 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return extractedImage
|
|
|
|
}
|