Is onResume() called before onActivityResult()?
The call to onActivityResult happens before onResume, actually (see the docs). Are you sure you're actually starting the activity you wanted with startActivityForResult
and that you're setting the result of the invoked activity to RESULT_OK
before returning a value to your activity? Try just putting a Log
statement in your onActivityResult
to log that value and make sure that gets hit. Also, where are you setting the value of the isLoggedIn
preference? It seems like you should be setting that to true
in your login activity before it returns anyways, but that's clearly not happening.
Edit
The docs say:
You will receive this call immediately before onResume() when your activity is re-starting.
With fragments it isn't even as simple as onActivityResult()
being called before the call to onResume()
. If the activity that you are returning to was disposed of in the interim, you will find that calls to (for example) getActivity()
from onActivityResult()
will return null. However, if the activity has not been disposed of, a call to getActivity()
will return the containing activity.
This inconsistency can be a source of hard-to-diagnose defects but you can check the behaviour of your application by enabling the developer option "Don't keep activities". I tend to keep this turned on - I'd rather see a NullPointerException
in development than in production.