Retain media fragment music playing












1















I have a BottomSheetDialogFragment I use to play recordings. But the fragment is being recreated from scratch and destroying on configuration change.



I've trying to find a lifecycle event only called when the fragment is completely destroyed. But all of onDetach() onDestroy() onDestroyView() are being called on any configuration change (e.g rotation change).



I've tried retainInstance but onDestroy() is still being called.



I've seen other players do it like Google Play Music with the small dialog. Is it because they're using an Activity instead of a fragment? Something more independent probably has more power, but it's still a full activity, harder to control.










share|improve this question

























  • Might setRetainInstance help here?

    – stkent
    Nov 25 '18 at 12:09











  • Tried it, didn't help. onDestroy() is still being called

    – Ahmad UCG
    Nov 25 '18 at 12:33
















1















I have a BottomSheetDialogFragment I use to play recordings. But the fragment is being recreated from scratch and destroying on configuration change.



I've trying to find a lifecycle event only called when the fragment is completely destroyed. But all of onDetach() onDestroy() onDestroyView() are being called on any configuration change (e.g rotation change).



I've tried retainInstance but onDestroy() is still being called.



I've seen other players do it like Google Play Music with the small dialog. Is it because they're using an Activity instead of a fragment? Something more independent probably has more power, but it's still a full activity, harder to control.










share|improve this question

























  • Might setRetainInstance help here?

    – stkent
    Nov 25 '18 at 12:09











  • Tried it, didn't help. onDestroy() is still being called

    – Ahmad UCG
    Nov 25 '18 at 12:33














1












1








1








I have a BottomSheetDialogFragment I use to play recordings. But the fragment is being recreated from scratch and destroying on configuration change.



I've trying to find a lifecycle event only called when the fragment is completely destroyed. But all of onDetach() onDestroy() onDestroyView() are being called on any configuration change (e.g rotation change).



I've tried retainInstance but onDestroy() is still being called.



I've seen other players do it like Google Play Music with the small dialog. Is it because they're using an Activity instead of a fragment? Something more independent probably has more power, but it's still a full activity, harder to control.










share|improve this question
















I have a BottomSheetDialogFragment I use to play recordings. But the fragment is being recreated from scratch and destroying on configuration change.



I've trying to find a lifecycle event only called when the fragment is completely destroyed. But all of onDetach() onDestroy() onDestroyView() are being called on any configuration change (e.g rotation change).



I've tried retainInstance but onDestroy() is still being called.



I've seen other players do it like Google Play Music with the small dialog. Is it because they're using an Activity instead of a fragment? Something more independent probably has more power, but it's still a full activity, harder to control.







android android-mediaplayer android-dialogfragment






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 25 '18 at 12:34







Ahmad UCG

















asked Nov 25 '18 at 11:43









Ahmad UCGAhmad UCG

507




507













  • Might setRetainInstance help here?

    – stkent
    Nov 25 '18 at 12:09











  • Tried it, didn't help. onDestroy() is still being called

    – Ahmad UCG
    Nov 25 '18 at 12:33



















  • Might setRetainInstance help here?

    – stkent
    Nov 25 '18 at 12:09











  • Tried it, didn't help. onDestroy() is still being called

    – Ahmad UCG
    Nov 25 '18 at 12:33

















Might setRetainInstance help here?

– stkent
Nov 25 '18 at 12:09





Might setRetainInstance help here?

– stkent
Nov 25 '18 at 12:09













Tried it, didn't help. onDestroy() is still being called

– Ahmad UCG
Nov 25 '18 at 12:33





Tried it, didn't help. onDestroy() is still being called

– Ahmad UCG
Nov 25 '18 at 12:33












1 Answer
1






active

oldest

votes


















0














Looks like the issue was from the libraries, the dialog was being dismissed even tho the fragment isn't destroyed.



override fun onDestroyView() {
if (dialog != null && retainInstance) {
dialog.setDismissMessage(null)
}
super.onDestroyView()
}


This code fixed it, now the fragment is retained and onDestroy() isn't being called anymore.






share|improve this answer























    Your Answer






    StackExchange.ifUsing("editor", function () {
    StackExchange.using("externalEditor", function () {
    StackExchange.using("snippets", function () {
    StackExchange.snippets.init();
    });
    });
    }, "code-snippets");

    StackExchange.ready(function() {
    var channelOptions = {
    tags: "".split(" "),
    id: "1"
    };
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function() {
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled) {
    StackExchange.using("snippets", function() {
    createEditor();
    });
    }
    else {
    createEditor();
    }
    });

    function createEditor() {
    StackExchange.prepareEditor({
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader: {
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    },
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    });


    }
    });














    draft saved

    draft discarded


















    StackExchange.ready(
    function () {
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53467084%2fretain-media-fragment-music-playing%23new-answer', 'question_page');
    }
    );

    Post as a guest















    Required, but never shown

























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    0














    Looks like the issue was from the libraries, the dialog was being dismissed even tho the fragment isn't destroyed.



    override fun onDestroyView() {
    if (dialog != null && retainInstance) {
    dialog.setDismissMessage(null)
    }
    super.onDestroyView()
    }


    This code fixed it, now the fragment is retained and onDestroy() isn't being called anymore.






    share|improve this answer




























      0














      Looks like the issue was from the libraries, the dialog was being dismissed even tho the fragment isn't destroyed.



      override fun onDestroyView() {
      if (dialog != null && retainInstance) {
      dialog.setDismissMessage(null)
      }
      super.onDestroyView()
      }


      This code fixed it, now the fragment is retained and onDestroy() isn't being called anymore.






      share|improve this answer


























        0












        0








        0







        Looks like the issue was from the libraries, the dialog was being dismissed even tho the fragment isn't destroyed.



        override fun onDestroyView() {
        if (dialog != null && retainInstance) {
        dialog.setDismissMessage(null)
        }
        super.onDestroyView()
        }


        This code fixed it, now the fragment is retained and onDestroy() isn't being called anymore.






        share|improve this answer













        Looks like the issue was from the libraries, the dialog was being dismissed even tho the fragment isn't destroyed.



        override fun onDestroyView() {
        if (dialog != null && retainInstance) {
        dialog.setDismissMessage(null)
        }
        super.onDestroyView()
        }


        This code fixed it, now the fragment is retained and onDestroy() isn't being called anymore.







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Nov 27 '18 at 9:07









        Ahmad UCGAhmad UCG

        507




        507
































            draft saved

            draft discarded




















































            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid



            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.


            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53467084%2fretain-media-fragment-music-playing%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            Wiesbaden

            Marschland

            Dieringhausen