Awesome! I'm aware that there are plugins for Chrome to capture media keys, but they never seem to work right and intercept the keys when I don't want them to. This fixes that problem of listening to my stream and having to navigate to that tab when I don't like a song.
Usually I would choose a native app over a website for the performance and better memory management, unfortunately all that is lost with node & friends.
The browser isn't really cut-out, but that's not to say the the performance isn't better. In fact, with a lot of the "browser" side stuff, like bookmarks, extensions, etc. gone there is performance gains to be had using node-webkit/Electron, etc. in my experience using them. It also allows you to get around some security contexts that running untrusted code in a browser environment requires.
I'd be interested in seeing a benchmark of something like cmus or even Winamp vs something using browser-based tech like Spotify or this. My hunch is that it's a huge difference. I typically use my phone to play Spotify / SoundCloud to wireless headphones to save the CPU overhead at work.
I do wish the more mainstream companies stopped the JS-based-app trend. Spotify was snappy a few years ago and is now a resource hog. And don't even mention the Slack Mac app...
I agree with you but unfortunately that doesn't seem to be happening in a near future. With this BigData thing where companies want to keep track of your data, likes, etc web is their way.
I do miss old times native and robust desktop applications.
There's no reason they couldn't collect that data on 'native' apps though; we've got Google Analytics integrated in our mobile app which sends events to the same account as the website.
So far all NW.js based desktops apps felt worse to me than using the website directly. They tend to use more RAM since they each need their own browser instance.
Absolutely, let's not forget that nodejs makes it easy to do the wrong thing. While it's great to lower the bar to learning to program it also often results in great ideas that are poorly executed of which I think most of the nodejs community demonstrates.
> let's not forget that nodejs makes it easy to do the wrong thing
How exactly node.js makes it easy to do the wrong thing?
> While it's great to lower the bar to learning to program it also often results in great ideas that are poorly executed of which I think most of the nodejs community demonstrates.
What makes node.js lower the bar for programming? I personally find it not easier than C#. How is it different than, say, Python, in terms of difficulty? How is node.js community showing poorly executed ideas? Any examples or are you after FUD?
Stereotyping a community is the most unconstructive thing you can ever do to for this industry.
I hear this all the time for various webapps and I'm curious about why. Is it because you want to be able to cmd/alt-tab rather than ctrl-tab to the window?
Isolating a service to a program, as well as being able to close the browser fully without closing down music. Throughout my day I open and close my browser often enough.
SoundCloud the webapp already seems to have its UI designed for music playback (it's a very slick and responsive design, by the way).
Whether the UI of the standalone app is more polished that's debatable, but as far as "isolating a service to a program" and "being able to close the browser fully without closing down music" go - in and of themselves - using another browser in paralel looks sort of equivalent to it.
I don't rule out there could be some other advantages of this solution, like smaller memory footprint etc., I addressed the specific reasons given by the parent commenter
Depending on how your OS displays tabbed browser content it can be harder to access one tab/window of many in a single application than a single unique program. It also means that it has the same volume level as the rest of your browser using system volume (if anyone but me does..)
In general I'm a user who never downloads apps on my phone (unless there's something I find unsuited to my browser) - but for a music player I want it to be quickly isolated for skipping, pause, etc etc.
That's also another factor, in-browser stability is subject to each individual end user. A native client helps improve stability in the overall browser.
As a person consistently dealing with lots of tabs (50+) having another tab for solely playing the music is not welcomed. Tab pinning helps, but not much.
I use Chrome's Add to Desktop feature for SoundCloud and other webapps, which adds a shortcut to launch the webpage in a dedicated window (without the browser chrome, etc.) The window is managed separately from your normal browser windows (if any) and acts like a first-class native app.
Why not prefer native apps to webapps? Better performance, a better fit into the OS's look-and-feel, and ability to interface with other OS-wide features such as accessibility and automation etcetera.
Although, Soundnode doesn't seem to be a true native app, as others have pointed out.
I doubt the better performance is true since it's essentially the same technology that would be used on the web. One performance hit you take is loading the resources once.. but you also need to download the app.
Ideally web app and its data is instantly accessible anywhere, not just on your desktop. They bypass any possible install restriction (or AppStore restriction, which is why Apple is deliberately keeping Safari in 2010).
The look & feel argument is total bullshit at least for me. Every native app I am using is completely different. The only consistent look & feel is with ms office apps like excel, word and powerpoint.
Performance is also a lot about how and who wrote the app rather than if the app is native. It's just harder and requires a lot of knowledge to make javascript app perform well, but it's not some impossibility.
And yes, standards are still creating too high level APIs and it takes forever to gain more and more access to the same things native apps have. But that will get better due to extensible web manifesto.
> Ideally web app and its data is instantly accessible anywhere, not just on your desktop.
Where the data resides is not a distinction between web apps and native apps. See Apple's bundled apps, like Notes, Contacts, etc.: you can access the same data via a website or through native iOS/OS X apps.
However, one advantage that native apps have when it comes to accessing cloud data, is that you can still access and update that data even when you have no connection to the internet.
> which is why Apple is deliberately keeping Safari in 2010
What do you mean with this?
> The only consistent look & feel is with ms office apps like excel, word and powerpoint.
This sounds like you are primarily a Windows user, where indeed, MS Office apps seem to be the only ones that share a consistent look-&-feel among them. Even Windows' own applets vary wildly in how they present basic UI elements (like toolbars and Control Panels.)
The overall situation, while with its own unique flaws, is much more coherent on OS X, across all vendors.
> Performance is also a lot about how and who wrote the app rather than if the app is native.
True, but web apps will always be removed from the underlying OS's "metal" by at least one degree, no?
> Where the data resides is not a distinction between web apps and native apps.
Huh? The data is only accessible to native app after you have installed the app on a device. If you only ever use your own one desktop, then it's probably hard for you to see this. Can you even try to imagine that you cannot just install arbitrary native app on let's say, your friend's device to access your data? But you can easily "install" a web app, since technically it's just a website like this one.
> However, one advantage that native apps have when it comes to accessing cloud data, is that you can still access and update that data even when you have no connection to the internet.
genuine question - why do you not listen to music on your phone ? you get to know when you have a call coming in and not miss it..plus most phones have better audio chips than the desktops.
you can obviously connect a usb cable to your computer to keep charging the phone.
I'll answer my perspective as I use Spotify and prefer to use the desktop app when working than my phone. The reasons are:
- I use headphones, and I use Skype, so I wont use two pairs or swap them when Skyping. Skype for Desktop is easier to use than the phone (i.e. screen sharing, sharing links, etc).
- It is far easier to skip a track or pause it using a mouse when you're already using the mouse, than to take your hand away and use the phone.
- I can't watch YouTube movies on my PC when my headphones are in my phone.
I'm the opposite. I don't have to trust that a website won't enable my mic or camera without permission. Won't read my location. Won't read my contact list or .ssh folder etc... Won't have some remote explioit.
I know a couple of websites which provide music on demand and they pull their data off of soundcloud. Seeing as how successful they are, they must have grabbed Soundcloud's attention. Yet, after all these years it seems no consequences occurred.
Indeed you can, and preferably you'd use the key of an official phone app from them, so that they can't just invalidate it without releasing a new one.
There's also a chrome extension "Media Keys by Sway.fm"[1].
It can scrobble to last.fm and pause videos/music in other tabs when you start playing something else.
Is anybody aware of plans for a web API to allow reassignment of media keys? Clearly it would require strict permissions so as not to be abused, but it could be really useful.
I have waited so long for Spotify to add a feature where you can add a Soundcloud track to a playlist. I guess i have to use this until (if) that happens.
I haven't checked Soundnode App yet, but any attempt to sanitize the way you interact with SoundCloud should be appreciated, because SC web UX is bad.
Soundnode App UI looks nice. I'd add screenshot for each main view on app's home page, even if they're all similar, though. UX remains to be tested.
The only (apparent?) downside is that this app seems to be a bundled web app with web browser. I'm not that fond of such solutions. But. If it wasn't open source and GitHub page wasn't shown there, then there is a high chance I would not notice that it's built like that, at least from screenshot alone.
Writing SoundCloud client is on my ToDo list, as it would be a good way to brush up and enhance my Qt skills. Maybe I'd finally embrace QML along the way, as I'm postponing QML tinkering for far too long I guess. I'm also considering fiddling with PyQt5, as it could possibly quicken prototyping, but I'm not sure about it in my case, as I have only minor Python experience and no PyQt experience at all (well, it's like incentive to change that). There is also SoundCloud python package, so going python way is quite tempting, but I always prefer native compiled apps over scripted ones.
Okay, so I ran it with my backup account that I'm using to download stuff for free (those songs that require you to follow certain people on SoundCloud to get access to the download link), and I noticed something strange: apparently, I'm following the SoundCloud user named Flying Spaghetti Monster.
I then went to SoundCloud, logged in with the same account, opened up the list of the users I'm following, loaded until the end of the list, pressed Ctrl+F, typed in "fly", and no matches were found. I then went ahead and typed "spa", again, no matches were found. Then, I have started to be a bit suspicious about the app. Then, I started typing "Flying Spaghetti Monster" in the search bar on SoundCloud and immediately realized that I am indeed following a user named "Flying Spaghetti Monster", even though I absolutely don't see it through the list of the people I am following.
Talk about a bad user experience. I'm definitely not going to use their official website again.
The app starts by showing the login and therefore requires to be registered first. However, on the official website I can listen without registering. An API requirement I guess. A regular user will probably be registered anyway.
But the login looks exactly like the official page. So is this just a wrapper for the website or do they actually add value ?
I’ve hoped for a long time that SoundCloud would release an alternative to iTunes to capitalize on the many podcasts on their platform. iTunes is such a goddamn POS, and I wish a private company would take up the challenge, at least when it comes to podcasts.
reply