When I play certain MP3 files (such as lessons from JapanesePod101.com) on my iPod Touch, lyrics or transcripts that are embedded in the MP3 files are displayed in the media player. The lyrics are, I believe, stored as ID3/ID4 tags in the MP3 metadata.
I find this to be an extremely useful feature, and I believe I’m not alone. Despite that, neither the stock Android media player nor any other media player I’ve downloaded from the Market seems to support this. I just have not been able to find any way to get feature on my Nexus One.
This feature is important enough to me that I’m considering learning Android development just so I can write a simple media player that displays embedded lyrics or notes. However, the fact that nobody else seems to have done this makes me wonder – is it even possible? Is there something in the Android architecture or APIs that make it difficult or impossible to read and display lyrics information from MP3 files? I’d hate to get deep into the learning process and find out what I’m aiming for can’t easily be done. (I mean, if all else fails I assume I could write my own MP3-decoder, but that’s more trouble than I’m willing to go through right now).
I’ve already asked this question on the Android Enthusiasts Stack Exchange Beta Site, but in retrospect I decided it was more of a programming question and decided it was better to ask here.
Yeah, definitely more of a programming question. Just from my brief experience of reading through the ID3 spec, I think it’s probably just that decoding ID3 tags is a complete PITA. I’m sure it can be done, as there are MP3 tag editing apps available for Android (whether any support lyrics or not, I do not know).
ID3v2.3 seems to have support for both synchronized and unsynchronized lyrics through the SYLT and USLT frames of the header. I imagine it’s just such an underused feature that it isn’t worth the effort to most to do so. Purchased MP3s don’t carry this information (I’ve always wondered why not?), so they would have to manually be added (or automatically via a lyric service API, but there’s a lot more coding involved with that).
Here is the ID3v2.3 spec if you’d like to look into it further…(abandon hope all ye who enter here)