Full Guide to Jetpack Compose Effect Handlers

Поділитися
Вставка
  • Опубліковано 15 жов 2024

КОМЕНТАРІ • 119

  • @thegreatwarrior4989
    @thegreatwarrior4989 2 роки тому +70

    For me you are the best channel for Android development

    • @PhilippLackner
      @PhilippLackner  2 роки тому +6

      Thanks a lot!

    • @bro_chenzox
      @bro_chenzox 2 роки тому

      +++++

    • @k4ba
      @k4ba 2 роки тому +1

      @@PhilippLackner Thanks to you bro, resourceful people are often bad teachers cause of human nature, you in other hand are damn smart and brilliant in the way you explain

    • @mithilmehta1501
      @mithilmehta1501 Рік тому +2

      Same for me.. 😂, I think this man deserves half of our salary 😂. Thanks @PhilippLackner!

  • @re7650
    @re7650 2 роки тому +19

    Philipp is forever invited to my home for dinner. Such nice content and delivery.

  • @alindo23
    @alindo23 Рік тому +31

    The only 2 I found useful were LaunchedEffect and DisposableEffect. The rest of them were created to make the interviews harder.

  • @OnlineEntrepreneurTools
    @OnlineEntrepreneurTools Рік тому +37

    Thanks for this! Although my mind couldn't absorb any of the discussed effect. Part 1 to 9 is clear and easy to follow as a newbie of Jetpack Compose. This part (Part 10) doesn't have any relevance in almost all discussed subjects in parts 1 to 9 that's why I couldn't comprehend. Maybe this should be moved in a more advanced playlist for compose. I will just skip to the next part hopefully I am not totally lost as I really love the tutorials. I'll take note on this effect handlers and when I got to the point when I already need this subject then I'll just get back here. Thanks Philipp! Cheers!

    • @brunofreitas561
      @brunofreitas561 Рік тому +4

      I had the same feeling!

    • @peterfraga4023
      @peterfraga4023 Рік тому +1

      same kinda difficult... tried finding the prepared code (samples) to go over it... and couldn't find it. The code qould help, thought of buying the premium course, but if I don't understand the frrebee, not sure I will understand the paid course...) having the code wouldn't deter me from purchasing the paid course, maybe it would motivate me more

    • @namncc5413
      @namncc5413 Рік тому

      ​ 😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😮😮😮😮😮

    • @namncc5413
      @namncc5413 Рік тому

      ​@Peter Fraga 😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮ㅣ😅😅😅😅😮😮😅😮ㅣ😮ㅣ😮😮😮😮😮😮😅😮😮😮😮😮😮😮😮😅ㅣ😅😮😮😮😮😮😮ㅑ😅😅😅😅😅😅😅😅😮😅😅😅😮😮😮😅😮😅😮😮😮😮😅😅😅😮ㅣ😮😮😅😅😅😅😅😅😅😅😅😅😅😅😅😅😅😅😮😅ㅏ😅😅😅😮😅😅😅😅😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😮😮😅😅😅😅😮ㅣ😮ㅣ😮😮😮😮😮😮😮😅😅😅😅😮😮😮😅😮😮😮😮😅😮😮😅😅😅😮😮😮😮😮😮😮😮😮😮😮😅😅😮😮😮😮😅😮😮😮😮😮😮😮😮😮

    • @namncc5413
      @namncc5413 Рік тому

      😮😮😮😮😮😮😮😮😮😮😮😮😅😮😅😅😅😅😅😮😮😮😮😮😮😮😮😮😮😮😅😅😅😅😅😅😅😅😅😅😅😅😅😅😅😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮ㅣ😅😅😮😮😮😮😮😮ㅣ😮😮😮😮😮😮😮😮😅😅😮😅😮😅😅😅😮😮😮😮😮😮😮😮😮😮😮😅😅😅😅😅😮😮😮😮😮😮😮😮😮😮😮😮😅😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😮😮😮😮😮😮😮😮😮😮😮😮ㅣ😮😮😮ㅣㅣ😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😮😮😅😅😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😮😮😮😮😮😮😅😅😅😅😅😅😅😅😮😮😮😮😮😮😮😮😮😮😮ㅑ😮😮😮😮😮😮😅😮😮😮😮😮😮😮😮😮😮😮😅😅😮😮😮😮😅😅😅😅😅😅😅😅😮😮ㅣ😮😮😮ㅣ😮😮ㅣ😮ㅣ😮😮😮😮😮😮😮😮😮😮😮ㅣ😮😮😮😮😮😮😮😮😮😮😮😮😅😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😅😅😅😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😅😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😮😅😅😅😅ㅣ😮😮
      😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😮😮😮😮😅😅😅😅😮😮😮😮😮😮😮😅😮😮😮😮😮😮😮😮😮😅😅😮😮😮ㅣ😮

  • @allanandliftedhands2669
    @allanandliftedhands2669 2 роки тому +4

    I always check on my notifications to make sure i did not miss a new video from this guy

  • @alihosseinnezhad2957
    @alihosseinnezhad2957 2 роки тому +3

    Thank you Philipp , You explain contents with interesting examples.
    Here is one of the best channel for android.
    👏👏

  • @GakisStylianos
    @GakisStylianos 2 роки тому +16

    Just be careful, think of derivedStateOf just as you would mutableStateOf in a sense that it needs to be remembered! Otherwise this isn't remembered and in case of recomposition will just be called again from scratch. And overall it feels like your explanation on derivedStateOf could be improved a bit. You didn't mention anything about how it implicitly "subscribes" to the state objects that are being accessed in there, but doesn't have any mechanism to update itself when non-state objects are being read in its lambda are changed so it would then show stale data.
    I really suggest people to read the excellent documentation on these, it does a great job explaining with examples how they work.

  • @vedx
    @vedx 2 роки тому +4

    I was struggling with this. Thanks for the video ❤️❤️

  • @kepper103
    @kepper103 Рік тому +1

    THANK YOU SO MUCH, just this afternoon i was duct taping together my own event system from snippets of code i found online, but the one you show in LaunchedEffect part is so much better and cleaner! Thanks! The rest of the video is also great as well!

  • @michaberkowicz8239
    @michaberkowicz8239 2 роки тому +1

    Compose related videos always welcome

  • @danielkeyes3931
    @danielkeyes3931 2 роки тому

    Thanks for the video. I appreciated all the examples and the simplicity of them for easier understandability.

  • @themisterravenous1785
    @themisterravenous1785 2 роки тому +1

    awesome video! just one simple thing I notest was he snapshotFlow using the distincUntilChanged(), actually the snapshotFlow itself is already handling it, so it will get the latest value of the state if its value is different, so in this case you dont need call the distinctUntilChanged. btw thanks a lot for this video it helped a lot to understand all of them

  • @Brahim-sy
    @Brahim-sy 7 днів тому

    bro you are awsome may god always send good days on your way.

  • @original_anu
    @original_anu 2 роки тому

    Months later, my webview was playing audio event after navigating away. Destroying it in DisposableEffect did the trick.
    Good thing I bookmarked this video 😁

  • @ubersticks
    @ubersticks 2 роки тому +2

    Hi Philip - excellent again! How about a quickie example explaining delegation ("by") and when to use that. I find it very confusing and maybe you could shine some light on this.

    • @PhilippLackner
      @PhilippLackner  2 роки тому

      Thanks for the idea, however right now i have tons of other videos in my pipeline 😄

  • @Soulcybering
    @Soulcybering 2 роки тому

    Thank you for the video. I will watch all the Compose serie 👍

  • @ShivamVermaokdone
    @ShivamVermaokdone 7 місяців тому

    Top channel for genuine content on android after the Google android developer channel.

  • @MetehanBOLAT
    @MetehanBOLAT 2 роки тому +2

    You are the few youtube channels that I have turned on notifications on :D You touch on very important points as always. Thanks.

  • @AhsanAli-vz6mg
    @AhsanAli-vz6mg 2 роки тому

    Seriously I was waiting for this video
    Thanks 😊

  • @techmarinar
    @techmarinar 2 роки тому

    Gem's channel , thanx man , wish you all the best in your life

  • @nCodeLab
    @nCodeLab 2 роки тому

    quality videos after long time ......need more clean architecture full apps tutorial or compose tutorial..(animation ,canvas ,custom modifiers , custom layout..etc)

  • @مہحہمہدآلمہعہلمہ
    @مہحہمہدآلمہعہلمہ Місяць тому +1

    To be honest, I didn't understand the part when you talked about the view model and other and collection of flow, I guess, if someone can give me an idea ?

  • @slobicak
    @slobicak Рік тому

    Thanks for sharing, really cool video!

  • @The-Fuse
    @The-Fuse 2 роки тому +1

    Thank you philipp 😁

  • @premi_uz
    @premi_uz 9 місяців тому

    thanks for all

  • @arthurgichuhi
    @arthurgichuhi 10 місяців тому

    This stuff would be much easier with practical uses but great content as always.

  • @rollebonmarquis7574
    @rollebonmarquis7574 2 роки тому

    In my opinion, 19:00 is missing the point.
    produceState() uses LaunchEffect in the background so that's another difference. And basically the example with the flow constructor seems to be breaking the core principles of compose, it seems like it's doing backwards writes, you are going to end up with infinite recompositions.
    Saying this as someone who is trying to wrap my head around Compose. :D

  • @JamesBond-mq7pd
    @JamesBond-mq7pd 6 місяців тому

    wow. such a good explanation.

  • @ifedayoadekoya6694
    @ifedayoadekoya6694 Рік тому +1

    I’m trying to run a recursive task every 15seconds (like call an api) on my jetpack screen, how can I achieve this with launched effect or any other Android class without using workmanager.

  • @tarsilacostalonga
    @tarsilacostalonga Рік тому

    Hi, Philipp, great video!
    What is yout Android Studio theme?
    Thanks =)

  • @iftak01
    @iftak01 4 місяці тому

    Best explanation video of this thanks bias god

  • @subindsuresh4897
    @subindsuresh4897 2 роки тому

    Gym Shark should start sponsoring Philipp !!

  • @petterstenberg617
    @petterstenberg617 Рік тому

    Thanks for your educational and helpful videos! The Android Studio theme that you’re using looks awsome, what is the name of that? ⭐️🧐 Cheers from Sweden 🍻

  • @x32gx
    @x32gx 2 роки тому +1

    Hi Phillipp!! As always, top notch videos! Thank you! I have a question, I have a Composable function that creates a JFreeChart object which basically gets recomposed when ever its DataSet values are updated. But in that case, the entire JFreeChart object gets recreated again and again with each recomposition. So it appears to be a side effect. Is LaunchedEffect the more accurate choice to prevent that? Do I create the JFreeChart object with key1 = true and then simply let it observe its DataSet updates? Thanks!

  • @koetjape4440
    @koetjape4440 2 роки тому

    Philipp, Hi! I love your content, thank you for that. I don't understand one thing. Could you please explain me ? Why cant we just use derivedStateOf everywhere since it optimizes everything ?

  • @lingviston
    @lingviston Рік тому +1

    Sadly, all `SideEffect` examples strive to be so oversimplified, that neither of them actually demonstrates the real use case of it. Like: what would happen if you do this call without wrapping in `SideEffect`? This effect handler deserves better example.

  • @original_anu
    @original_anu 2 роки тому

    Thanks a lot for this ❤️
    I'll bookmark it for future reference :P

  • @brigadir5830
    @brigadir5830 Рік тому

    Привет из России. Спасибо за понятные и хорошие уроки это лучшие курсы для начинающих💗💗💗

  • @keepgoingman5829
    @keepgoingman5829 2 роки тому

    Do you live in my head? How do you always know all subscriber's needs? Thank you!

  • @skandarsouissi7282
    @skandarsouissi7282 5 місяців тому

    I def needed this

  • @abdelsttarahmed8821
    @abdelsttarahmed8821 2 роки тому

    Really Amaizing video , thank you 😎

  • @bro_chenzox
    @bro_chenzox 2 роки тому

    Cool episode! Which one of dark themes plugin do you use?

  • @fawazmn_071
    @fawazmn_071 2 роки тому

    Omg thanks very much ! ✨

  • @スヘア
    @スヘア 2 роки тому

    As always Sir Philipp is here to save the day

  • @t_regbs
    @t_regbs 2 роки тому

    thank you so much for this

  • @mehmetpeker9047
    @mehmetpeker9047 2 роки тому

    Can you make video about usage of native ad as a up to date and how to use in jetpack compose?

  • @dev_jeongdaeri
    @dev_jeongdaeri 2 роки тому

    Super awesome!!

  • @duc-fw
    @duc-fw Рік тому

    is it acceptable to have the key be modified within the LaunchedEffect block?

  • @karamba6936
    @karamba6936 Рік тому

    Hello. I saw that people place derivedStateOf inside remember. Is that wrong?Because it cash and not calculate each run

  • @micahspecial5927
    @micahspecial5927 Рік тому +1

    Im stuck with EffectHandlersTheme not detect

    • @xCrawfly
      @xCrawfly 6 місяців тому

      So was I, but you can usually get the answers in the comments.
      This is a response from @tetsuoshiva:
      When you create a new Compose project, it creates a theme named "[ProjectName]Theme". Chances are the project was named "EffectHandlers", and "EffectHandlersTheme" is the theme that was created at project creation.
      Just write your project name instead of "EffectHandlers", followed by "Theme".

  • @ИгорьВялков-я1ф
    @ИгорьВялков-я1ф 2 роки тому

    Hey, just finished course about multimoduling. Have a question - when services are needed? For example, if there are any pros for moving api calls to service, if these are periodic calls made with workmanager? Thanks)

    • @PhilippLackner
      @PhilippLackner  2 роки тому

      Workmanager is needed when you have work that needs to be done reliably, even when your app is closed or the device restarted. Not for user initiated network calls

  • @mustafaammar551
    @mustafaammar551 2 роки тому

    very cool video thank you bro

  • @youngtigersivateja
    @youngtigersivateja 2 роки тому

    In your MVVM News App, how to refresh the news list using swiprefershlayout listener or when call news list api from onresume override method?
    I am new to MVVM architecture, please help me as i am calling the news list api in onresume but not in oncreate as i need to refresh the news list every time i came back to breakingnews fragment.

  • @leonardovalle2763
    @leonardovalle2763 2 роки тому

    Hi Philipp, awesome video, thanks for the great content!
    Just a question, how would you implement a snackbar call after navigation? when i perform an action, the app navigates up and need to show a snackbar, but i am just not being able to do it...
    how would you do it?

    • @PhilippLackner
      @PhilippLackner  2 роки тому +1

      Have it in a launched effect block in the screen you're navigating to if it should always show up or based on some kind of nav parameter

    • @12Playmobil
      @12Playmobil 2 роки тому

      What you can also do is have a scope = rememberCoroutineScope and a scaffoldState = rememebreScaffoldState in your App() composable and a Scaffold. Your composables should expect a
      showSnackbar: (String, SnackbarDuration) -> Unit
      parameter, that you can call (for example when navigating up) like
      showSnackbar ("Your snack message", SnackbarDuration.Short).
      Your navigation composable should expect the same function parameter so you can just pass it on to your actual screen composables when creating the instances. In the end your Scaffold in App can look like this:
      Scaffold(
      ..
      state= scaffoldState
      ..
      ) {
      ..
      YourNavigationComp(
      navHost =...
      showSnackbar = { message, duration ->
      scope.launch {
      scaffoldState.showSnackbar(message, duration)
      }
      })
      }
      With this solution you have a snackbarScope scoped to the App() so your snackbar is still visible during navigation and in the new screen. (Obviously if you need a snackbar scoped to your screen you can implement the scope and Scaffold there). Hope I could explain it well and could help.

    • @12Playmobil
      @12Playmobil 2 роки тому

      Your question inspired me to write an article about about the topic in Medium, because I had this same struggle some time ago. I can not post the link here but added it to my youtube bio.

  • @cristianovecchi
    @cristianovecchi 2 роки тому

    Great! So much useful!

  • @azatnabiullin2263
    @azatnabiullin2263 11 місяців тому

    On 7:02 you said that code in LaunchedEffect only once when screen composed for the first time. How another Event can happen in this case? E.g. it collects first event - ShowSnackbar and then Navigate event happens but you told that code executed only once

    • @PhilippLackner
      @PhilippLackner  11 місяців тому +1

      The launch effect block is executed once, so it subscribes to the flow once. But once a subscription is established the collect block will trigger with each event

    • @azatnabiullin2263
      @azatnabiullin2263 11 місяців тому

      @@PhilippLackner thank you

    • @teeesen
      @teeesen 10 місяців тому

      @PhilippLackner In the LaunchedEffectAnimation example. How can `counter` change? It’s just an Int parameter and is never assigned to. Would the example work the same if the first argument to LaunchedEffect were `true`? Great videos, by the way; I’m working my way through the original Compose series and have learned a lot.

  • @abada-s
    @abada-s 2 роки тому

    Is it good to use derucedStateOf instead of rememberStateOf in all cases?

  • @mertozankahraman
    @mertozankahraman Рік тому +1

    Adam geldi ADAM

  • @akshaytyagi9791
    @akshaytyagi9791 2 роки тому

    at 3:00 you said its a terrible practise to directly call api inside composable. Can you please tell what is the best practise ?

    • @slobicak
      @slobicak Рік тому

      Call it from a viewmodel / use case / repository

  • @rsufiyand
    @rsufiyand 2 роки тому

    Sir Complete jetpack compose course.

  • @NaveenKumarChallaboyana
    @NaveenKumarChallaboyana 22 години тому

    Thankyou

  • @user-sb5ud7ek9c
    @user-sb5ud7ek9c Рік тому

    what's the hotkey that you use at 15:28 to move the line up, through a brace, into onDispose scope?

  • @tetsuoshiva
    @tetsuoshiva Рік тому +1

    Wait, you never explained what EffectHandlersTheme is.

    • @ArthurRousseau2
      @ArthurRousseau2 Рік тому +5

      When you create a new Compose project, it creates a theme named "[ProjectName]Theme". Chances are the project was named "EffectHandlers", and "EffectHandlersTheme" is the theme that was created at project creation.

    • @AnhBaGopDon
      @AnhBaGopDon 6 місяців тому

      @@ArthurRousseau2 It has me stumped for an hour searching google, thank alot man.

    • @xCrawfly
      @xCrawfly 6 місяців тому

      @@ArthurRousseau2 Thanks! I started to come to the comments before googling stuff and I'm so happy for that.

  • @ravi_sorathiya
    @ravi_sorathiya 2 роки тому

    What's the name of your android studio theme?
    Philip

  • @Daaaaaaavid
    @Daaaaaaavid Рік тому

    I find scopes a really hard concept to get.

  • @pfrost982yt
    @pfrost982yt Рік тому +3

    Not clear without examples

  • @lmgeektalk
    @lmgeektalk 2 роки тому

    Love that content...

  • @vladalexeev8529
    @vladalexeev8529 7 місяців тому

    I'm so stupid, I still can't grasp what is it

  • @be_like__prateek
    @be_like__prateek 2 роки тому

    Respect++ 🔥🚀

  • @testg4andmmm129
    @testg4andmmm129 Рік тому

    This side effect makes me think twice whet i should use this or maui csharpmarkup.
    Compose makes it so much complicated especially in example.
    Why not make normal oop. İnstead of frp
    in order to conpansate for downside of functional programming,
    they added remember state etc.
    How to cover a hole
    with another thing that also has a hole. Total bullshit..

  • @yonghunchoi8944
    @yonghunchoi8944 2 роки тому

    형 너무 사랑해❤️❤️

  • @pavlopavlov5169
    @pavlopavlov5169 Рік тому

    Very cool lessons, please add Ukrainian subtitles.

  • @gilbartodepiento7584
    @gilbartodepiento7584 10 місяців тому

    Until video 9 in this playlist, I was more or less understanding the concept. After watching this one, I feel like I have totally lost the plot

  • @marvelrivera1194
    @marvelrivera1194 Рік тому

    Cool

  • @likatest7718
    @likatest7718 10 місяців тому

    Just example, therw is no practice :(

  • @martinstreif2879
    @martinstreif2879 2 роки тому

    At 23:44 I noticed you're german

  • @rabaka7899
    @rabaka7899 2 роки тому

  • @Alexandr234
    @Alexandr234 Рік тому

    nice rewriting google guides

  • @gofudgeyourselves9024
    @gofudgeyourselves9024 2 роки тому

    Thank you re baba Thank you