Explanation: Why FrameLayout for Fragment
What is FrameLayout
:
According to Google Documentation on Commons Layouts and this answer of What are the differences between LinearLayout, RelativeLayout, and AbsoluteLayout?, the ViewGroup
s as LinearLayout
, RelativeLayout
, AbsoluteLayout
(decrepated), TableLayout
, etc. are allow to display views:
- LinearLayout: "displays views one by one"
- RelativeLayout: "displays views regarding to another view"
- TableLayout: "displays views in a table"
etc.
FrameLayout
displays views by overlap the other. It is generally use to contain layouts:
"Frame layouts are one of the simplest and most efficient types of layouts used by Android developers to organize view controls. They are used less often than some other layouts, simply because they are generally used to display only one view, or views which overlap. The frame layout is often used as a container layout, as it generally only has a single child view (often another layout, used to organize more than one view)."
source: FrameLayout MobilTuts
"The Frame layout allows developers to display only a single or multiple UI elements within Frame Layout but each element will be positioned based on the top left of the screen, and elements that overlap will be displayed overlapping."
source: Android Frame Layout For Absolute Beginner
OK but, why do I need this for Fragment
? (vs LinearLayout or <fragment>)
The Google Documentation of FrameLayout says:
"FrameLayout is designed to block out an area on the screen to display a single item."
FrameLayout
will host a layout and it is willing for it. Whereas the rest of ViewGroup
s just display views. You can make a Fragment
in all ViewGroup
s (I tested that, it was a surprise for me) but it will not a proper way to do this. The FrameLayout
are:
"...the normal layout of choice when you want to overlap views."
If you create a layout with a <fragment .../>
, your fragment will be not replace by another, because it is displayed, it is "attached" with its id on the view. To replace a fragment, you need to host it: "By encapsulating the Fragment within a FrameLayout, you can replace just the details" (see this answer).
Then, keep in mind that FrameLayout
s are empties and can host a layout. Fragment
s (Fragment Documentation from Google, it explains very simply the facts to how use a fragment), when they are declared in xml, they must to have a class attached (an id), which cannot be replaced.
That's why we need a container to host this fragment and overlap the view of the activity!
Hope this will be helpful.
Note: If someone wants to edit this answer, because something it's not explain or badly explain, she/he could with heartily.
FrameLayout
instead of LinearLayout. And remove theandroid:visiblity="gone"
because of this, your layout will not display. – Naosreplace()
instead ofremove() + add()
? – NaosFrameLayout
is "willing" to host Fragment not other ViewGroups. I'll post an answer to understand this if I found a good explanation. ;) – Naos