UBports Robot Logo UBports Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Groups
    • Search
    • Register
    • Login

    ALAC audio file support?

    Scheduled Pinned Locked Moved Support
    26 Posts 4 Posters 4.7k Views 3 Watching
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
      Reply
      • Reply as topic
      Log in to reply
      This topic has been deleted. Only users with topic management privileges can see it.
      • advocatuxA Offline
        advocatux @nekojet
        last edited by

        @nekojet fwiw I've just installed a .m4a file on my BQ E4.5 (running edge) and on my Nexus 5 (running rc) to test that and it works in both of them.

        nekojetN 2 Replies Last reply Reply Quote 0
        • nekojetN Offline
          nekojet @advocatux
          last edited by nekojet

          @advocatux I'm running OTA-10 stable on a OnePlus One. Assuming it's not hardware-related, I'll wait for OTA-11 and see if it works.

          Thanks for the info!

          advocatuxA 1 Reply Last reply Reply Quote 1
          • advocatuxA Offline
            advocatux @nekojet
            last edited by

            @nekojet have you tried to play a .m4a file with the 'multimedia player' or open it with the filemanager preview?

            nekojetN 1 Reply Last reply Reply Quote 0
            • nekojetN Offline
              nekojet @advocatux
              last edited by

              @advocatux I just thought of something. Can you confirm that the .m4a file that works for you is using the ALAC (lossless) codec and not the AAC (lossy) codec? Thanks!

              advocatuxA 1 Reply Last reply Reply Quote 0
              • advocatuxA Offline
                advocatux @nekojet
                last edited by advocatux

                @nekojet I downloaded a random sample file, and yes, it seems it's AAC unfortunately (I didn't check it beforehand :rolling_eyes:)

                nekojetN 1 Reply Last reply Reply Quote 0
                • nekojetN Offline
                  nekojet @advocatux
                  last edited by nekojet

                  @advocatux When I try to open the file using "Media Player" or the File Manager preview (which seems to call up the same "Media Player"), I get an error that says "Error playing video - Video format not supported.", which makes sense I guess.

                  Thanks for trying to work this out with me.

                  advocatuxA 1 Reply Last reply Reply Quote 1
                  • advocatuxA Offline
                    advocatux @nekojet
                    last edited by

                    @nekojet you're welcome!

                    1 Reply Last reply Reply Quote 0
                    • nekojetN Offline
                      nekojet @advocatux
                      last edited by

                      @advocatux Well, now I know UT can play AAC files. πŸ˜€
                      I wonder if ALAC support is coming in the future?

                      Thanks again.

                      advocatuxA 1 Reply Last reply Reply Quote 0
                      • advocatuxA Offline
                        advocatux @nekojet
                        last edited by

                        @nekojet no idea about that, sorry

                        nekojetN 1 Reply Last reply Reply Quote 0
                        • nekojetN Offline
                          nekojet @advocatux
                          last edited by

                          @advocatux No worries. I was just wondering that out loud. Thanks.

                          nekojetN 1 Reply Last reply Reply Quote 1
                          • nekojetN Offline
                            nekojet @nekojet
                            last edited by nekojet

                            The package that is providing ALAC support on Xenial (16.04.6 LTS) desktop is:

                            gstreamer1.0-libav (1.8.3-1ubuntu0.2)

                            https://packages.ubuntu.com/xenial-updates/gstreamer1.0-libav

                            I was able to confirm this by removing:
                            gstreamer1.0-libav

                            and autoremoving its (orphaned) dependencies:
                            libavfilter-ffmpeg5
                            libavresample-ffmpeg2
                            libpostproc-ffmpeg53
                            libsodium18
                            libzmq5

                            and then trying to play my ALAC .m4a files again. Rhythmbox did a bit of searching and popped up a dialog that said:


                            Install extra multimedia plugin?

                            Rhythmbox requires to install plugins to play media files of the following type: Apple Lossless Audio (ALAC) decoder

                            gstreamer1.0-libav
                            libav plugin for GStreamer

                            [ Cancel ] [ Install ]


                            As far as I can tell, Ubuntu Touch (OTA-10) stable does not come with this package installed. I guess my next step is to do a bunch of reading to figure out if I can install this package myself, and/or request that it be included in a future UT release.

                            It's possible that gstreamer1.0-libav brings with it a bunch of baggage that might negatively impact UT...or something. Beats me.

                            Working this out has been fun (so far). Cheers!

                            dobeyD 1 Reply Last reply Reply Quote 3
                            • dobeyD Offline
                              dobey @nekojet
                              last edited by

                              @nekojet I suspect it is not something we can ship in UT. We only ship free codec support, and the hybris backend which uses hardware decoding from the Android side, for licensed codecs.

                              It would probably be better to convert your files to a free codec instead.

                              nekojetN 1 Reply Last reply Reply Quote 0
                              • nekojetN Offline
                                nekojet @dobey
                                last edited by nekojet

                                @dobey Makes senses. Thanks for the info!

                                I'm not fluent in the different software licenses. Is something released under the Apache License considered non-free? Thanks.

                                dobeyD 1 Reply Last reply Reply Quote 0
                                • dobeyD Offline
                                  dobey @nekojet
                                  last edited by

                                  @nekojet libav isn't solely a port of the original ALAC source code to Linux. libav/ffmpeg implements several encumbered codecs. So there may be issues with shipping those.

                                  If there were a totally free implementation of ALAC by itself, for GStreamer, we could possibly include it, but one only available with support for other codecs which are encumbered, is not really feasible.

                                  Best option really, is to transcode audio to a codec that is supported by the hardware decoder on the portable device you're putting them on, as this will save battery power by not having to do all the decoding in software on the CPU.

                                  nekojetN 1 Reply Last reply Reply Quote 0
                                  • nekojetN Offline
                                    nekojet @dobey
                                    last edited by nekojet

                                    @dobey Yes! After doing more (and more) reading, I almost wrote a long post (or two) about:

                                    1. Apple open sourced ALAC in 2011 under the Apache License 2.0, so that probably isn't so much of an issue πŸ‘

                                    but

                                    1. gstreamer1.0-libav (built on libav/ffmpeg) includes wayyyyyyyy more than just ALAC, and that quickly becomes problematic if you look at the huge list of codecs it packages πŸ‘Ž

                                    I also want to thank the UBports community for all of the great work y'all are doing. It's really appreciated. πŸ‘ πŸ‘

                                    I'm a new UT user (and Patron) and this project is very exciting.

                                    Thanks!

                                    1 Reply Last reply Reply Quote 2
                                    • flohackF Offline
                                      flohack
                                      last edited by

                                      Well its hard for me too to live without m4a now, since 2 of my band members use iPhones and any recording they do will come over the wire as m4a format. I have no idea if and how they can influence the recording codec on their side. Until that I can only listn to this on my desktop. Which is boring.

                                      Consumers are trapped in stuff they don't understand and also they are just no giving choices. We got along way to go...

                                      My languages: πŸ‡¦πŸ‡Ή πŸ‡©πŸ‡ͺ πŸ‡¬πŸ‡§ πŸ‡ΊπŸ‡Έ

                                      dobeyD 1 Reply Last reply Reply Quote 0
                                      • flohackF Offline
                                        flohack
                                        last edited by

                                        @nekojet said in ALAC audio file support?:

                                        gstreamer1.0-libav

                                        Oh and by the way, definitely need encoding support for opus when we ever want Telegram voice messages to be a thing. How could we get this in @dobey

                                        My languages: πŸ‡¦πŸ‡Ή πŸ‡©πŸ‡ͺ πŸ‡¬πŸ‡§ πŸ‡ΊπŸ‡Έ

                                        dobeyD 1 Reply Last reply Reply Quote 0
                                        • dobeyD Offline
                                          dobey @flohack
                                          last edited by

                                          @Flohack m4a is the MPEG-4 container format. It's not related to the codec for the audio embedded in the file, which can be ALAC, AAC, or numerous other things.

                                          flohackF 1 Reply Last reply Reply Quote 0
                                          • dobeyD Offline
                                            dobey @flohack
                                            last edited by

                                            @Flohack Well, Opus is an open codec, and it seems to already be implemented in the gstreamer1.0-plugins-base package, which should already be in the image, so I guess it should just work.

                                            1 Reply Last reply Reply Quote 0
                                            • flohackF Offline
                                              flohack @dobey
                                              last edited by

                                              @dobey Seems you are right, its AAC internally, but it still cannot be played back by UT...

                                              My languages: πŸ‡¦πŸ‡Ή πŸ‡©πŸ‡ͺ πŸ‡¬πŸ‡§ πŸ‡ΊπŸ‡Έ

                                              dobeyD 1 Reply Last reply Reply Quote 0
                                              • First post
                                                Last post