Alonso
Alonso

Reputation: 141

How to order elements inside a Linear Layout?

I have an application that shows different images inside a LinearLayout (which is inside a ScrollView).

I would like to reorder the elements in the Layout when the user press a button. For example: If I have |pic1|pic2|pic3| shown in the layout but I want to reorder them so they appear as |pic2|pic1|pic3|

This is my "activity_main.xml" file where I have all my images:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@drawable/map"
    tools:context="dis2.widget.MainActivity">

    <HorizontalScrollView
        android:layout_width="fill_parent"
        android:layout_height="80dp"
        android:id="@+id/contactsScrollView"
        android:fillViewport="false"
        android:visibility="visible"
        android:layout_alignParentTop="true"
        android:layout_alignParentLeft="true"
        android:layout_alignParentStart="true"
        android:layout_marginTop="26dp">

        <LinearLayout
            android:orientation="horizontal"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:visibility="visible">

            <ImageView
                android:layout_width="100dp"
                android:layout_height="wrap_content"
                android:src="@drawable/pic1"
                android:id="@+id/pic1ID"
                android:visibility="gone" />

            <ImageView
                android:layout_width="100dp"
                android:layout_height="wrap_content"
                android:src="@drawable/pic2"
                android:id="@+id/pic2ID"
                android:visibility="gone" />

            <ImageView
                android:layout_width="100dp"
                android:layout_height="wrap_content"
                android:src="@drawable/pic3"
                android:id="@+id/pic3ID"
                android:visibility="visible" />

        </LinearLayout>
    </HorizontalScrollView>

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Reorder"
        android:id="@+id/reorderB"
        android:layout_marginBottom="114dp"
        android:onClick="reorder"
        android:layout_alignParentBottom="true" />


</RelativeLayout>

Upvotes: 1

Views: 6064

Answers (1)

Lucker10
Lucker10

Reputation: 504

set an id to your LinearLayout:

android:id="@+id/myLinearLayout

and in Java:

public void reorder() {

    LinearLayout myLinearLayout = (LinearLayout) findViewById(R.id.myLinearLayout);
    // get number of children
    int childcount = myLinearLayout.getChildCount();
    // create array
    View[] children = new View[childcount];

    // get children of linearlayout 
    for (int i=0; i < childcount; i++){
      children[i] = myLinearLayout.getChildAt(i);
    }

    //now remove all children
    myLinearLayout.removeAllViews();

    //and resort, first position
    myLinearLayout.addView(children[2]);
    //second position
    myLinearLayout.addView(children[0]);
    //etc.
}

look at Droid: How to reorder a linearlayouts contents programmatically? and Get all child views inside LinearLayout at once

Upvotes: 5

Related Questions