How can I align an element to the right in the FrameLayout?
Asked Answered
C

6

21

I have a FrameLayout which contains 2 views , the second is something like a Close Button (X) and i want to position it on the right.

I've tried layout_gravity = " right ", but that didn't work.

This is my layout xml :

<FrameLayout android:layout_width="320dp"
    android:layout_height="wrap_content"
    android:id="@+id/layoutSmallImg">

    <ImageView android:id="@+id/bigImage"
        android:layout_width="320dp" android:layout_height="wrap_content"/>

    <ImageView android:id="@+id/bigImage"
        android:layout_width="320dp" android:layout_height="wrap_content"/>

    <ImageButton android:id="@+id/closebutton"
        android:background="@android:color/transparent"
        android:layout_height="30dp" android:layout_marginTop="10dp"
        android:layout_alignParentRight="true"
        android:layout_width="30dp" android:paddingLeft="40dp"
        android:visibility="gone" 
        android:src="@drawable/close" />
</FrameLayout>
Cedell answered 19/5, 2011 at 15:1 Comment(0)
M
33

I recommend you to use a RelativeLayout instead

FrameLayout is designed to block out an area on the screen to display a single item. You can add multiple children to a FrameLayout and control their position within the FrameLayout using gravity. Children are drawn in a stack, with the most recently added child on top. The size of the frame layout is the size of its largest child (plus padding), visible or not (if the FrameLayout's parent permits). Views that are GONE are used for sizing only if setConsiderGoneChildrenWhenMeasuring() is set to true.

BTW, do you want the button on top of the ImageView or next to it? You're setting the width of both the layout and the imageView to the same size.


After the comment, I can see two options:

Matheny answered 19/5, 2011 at 15:12 Comment(2)
thanks for your answer, i know that is possible with relativeLayout , i want to align it in a FrameLayout , :( yes i want the imageButton on top | right of imageView , it will looks like a Close button of My image , when i click , the Image will fade outCedell
thanks for your time, i think i will work with RelativeLayout again , i didn't find my happyness with the FrameLayout :)Cedell
R
31

Read the DOCS:

FrameLayout is designed to block out an area on the screen to display a single item. Generally, FrameLayout should be used to hold a single child view, because it can be difficult to organize child views in a way that's scalable to different screen sizes without the children overlapping each other. You can, however, add multiple children to a FrameLayout and control their position within the FrameLayout by assigning gravity to each child, using the android:layout_gravity attribute.

Try:

<TextView
     .....
     android:layout_gravity="right" />

You can place a view in 9 different places within a FrameLayout

Enjoy

Rosie answered 15/9, 2014 at 18:47 Comment(2)
this works. i believe that RelativeLayouts are more expensive to layout than FrameLayout as well.Atlantis
Thanks! This fixes problem when RelativeLayout takes all the screen #6486714Remains
S
9

Just put your elements inside FrameLayout to the second RelativeLayout. And use android:layout_alignParentRight="true" for the element which you want to align right.

<FrameLayout android:layout_width="320dp" android:layout_height="wrap_content" 
                                      android:id="@+id/layoutSmallImg">
 <RelativeLayout
            android:id="@+id/content"
            android:layout_width="match_parent"
            android:layout_height="match_parent" >
    <ImageView android:id="@+id/bigImage"
            android:layout_width="320dp" 
            android:layout_height="wrap_content"/>

    <ImageButton android:id="@+id/closebutton"
            android:background="@android:color/transparent"
            android:layout_height="30dp" android:layout_marginTop="10dp"
            android:layout_alignParentRight="true"
            android:layout_width="30dp" android:paddingLeft="40dp"
            android:visibility="gone" 
            android:src="@drawable/close" />
  </RelativeLayout>
</FrameLayout>
Submicroscopic answered 23/12, 2012 at 13:44 Comment(0)
W
1

Use a RelativeLayout instead.

Weiman answered 19/5, 2011 at 15:12 Comment(2)
thanks for your answer, i know that is possible with relativeLayout , i want to align it in a FrameLayout , :(Cedell
Then add left margin to your ViewWeiman
T
1

Programatically, you can set the margin using FrameLayout.LayoutParams. The following would work to place a view on the bottom of your screen:

int desired_height_of_content = //whatever your want the height of your view to be
FrameLayout layout = new FrameLayout(this);
FrameLayout.LayoutParams flp = new FrameLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, desired_height_of_content);
int difference = screen_height - desired_height_of_content
flp.setMargins(difference, 0, 0, 0);
layout.addView(your_view, flp);
Tonneson answered 8/2, 2016 at 12:20 Comment(0)
G
0

Do you want to use FrameLayout or RelativeLayout?

My understanding says that FrameLayout is used if you want to replace your current view with another view. Your requirement can be fulfilled by RelativeLayout.

Gillispie answered 19/5, 2011 at 15:17 Comment(5)
thanks for your reply i want to use the FrameLayout , b default , the FrameLAyout positionne Views at Top left of the frameLayout , i want to do that , but in Top Right ,Cedell
you can achieve what you want with FrameLayout as well. Set the layout_gravity for the ImageButton as "right". layout_alignParentRight works with RelativeLayout, I don't know if it works with FrameLayout as well. Anyone else, throw light on this.Gillispie
thanks, but i've tried layout_gravity="right " but it didnt work :)Cedell
I actually copied your code, just removing the line, android:visibility="gone". And I added the layout_gravity="right". It works perfectly fine for me. Just the screen size of my mobile is not that big, so I get a half cut image, but i do get it aligned right, so it is working fine :)Gillispie
yes , i know that , i see that my logic is good enough to align the ImageButton to the right , but at last ,i've used the RelativeLayout , the essential that it works now :) Thanks for your time ;)Cedell

© 2022 - 2024 — McMap. All rights reserved.