准备布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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:orientation="vertical"
android:layout_marginTop="20dp"
tools:context=".fragment.addaccount.AddExchangeFragment">
<LinearLayout
android:id="@+id/exchange_out_layout"
android:layout_width="match_parent"
android:layout_height="50dp"
android:gravity="center_vertical"
android:background="@drawable/selec_tab"
android:layout_marginRight="10dp"
android:layout_marginLeft="10dp"
android:paddingLeft="10dp"
android:paddingRight="10dp"
android:orientation="horizontal">
<TextView
android:id="@+id/change_out_tv"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="2"
android:text="请选择转出账户" />
<TextView
android:id="@+id/change_out_money"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginRight="5dp"
android:text="¥10.00" />
<TextView
android:id="@+id/change_out_all"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="4dp"
android:background="@drawable/add_tab_background"
android:text="全部转出" />
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="20dp"
android:orientation="horizontal">
<ImageView
android:id="@+id/exchange_icon"
android:layout_width="20dp"
android:layout_height="20dp"
android:src="@drawable/exchange_down"/>
</LinearLayout>
<LinearLayout
android:id="@+id/exchange_in_layout"
android:layout_width="match_parent"
android:layout_height="50dp"
android:layout_marginLeft="10dp"
android:layout_marginRight="10dp"
android:background="@drawable/selec_tab"
android:gravity="center_vertical"
android:orientation="horizontal"
android:paddingLeft="10dp"
android:paddingRight="10dp">
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="2"
android:text="请选择转入账户" />
<TextView
android:id="@+id/textView3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginRight="5dp"
android:text="¥10.00" />
<TextView
android:id="@+id/textView6"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/add_tab_background"
android:padding="2dp"
android:text="全部转出" />
</LinearLayout>
</LinearLayout>
设计点击方法
为图片设计一个点击方法
exchange_icon = getView().findViewById(R.id.exchange_icon);
exchange_icon.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
// 交换逻辑
}
});
交换逻辑:
1.获取父组件
2.找到在父组件中,这两个子布局的位序
3.在父组件中移除这两个子布局
4. 再将这两个子布局添加到对方的位置上,通过比较两个索引的大小来确定需要交换的两个布局的顺序。
exchange_icon.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if (parentLayout != null && linearLayout_in != null && linearLayout_out != null) {
int index1 = parentLayout.indexOfChild(linearLayout_out);
int index2 = parentLayout.indexOfChild(linearLayout_in);
parentLayout.removeViewInLayout(linearLayout_out);
parentLayout.removeViewInLayout(linearLayout_in);
if(index1 < index2) {
parentLayout.addView(linearLayout_in, index1);
parentLayout.addView(linearLayout_out, index2);
} else {
parentLayout.addView(linearLayout_out, index2);
parentLayout.addView(linearLayout_in, index1);
}
parentLayout.requestLayout();
}
}
});
效果: