API 3 de Android 3: Acceso a los componentes desde un diseño fusionado
-
26-10-2019 - |
Pregunta
Estoy codificando un tablero de ajedrez. Para el diseño, incluyo varios diseños "fusionados". Simplemente me gustaría acceder a los componentes "fusionados" del código de actividad, para cambiar algunas de sus propiedades (ImageView Background_color, ImageView Image Rath ...).
Editar: Por ejemplo, quiero pasar una ID de fila (R.ID.Row_1) e inicializar todos los componentes de esta ID de fila, con un bucle for: Las 8 celdas reciben cada una de un color de fondo diferente.
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
initializeComponents(R.id.row_2);
}
public initializeComponents(int id){
/* inflates the given layout child components
* and set their properties
*/
}
Aquí está mi main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<include layout="@layout/board"/>
</LinearLayout>
Aquí está mi tablero.xml
<?xml version="1.0" encoding="utf-8"?>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<include android:id="@+id/row_8" layout="@layout/board_line"/>
<include android:id="@+id/row_7" layout="@layout/board_line"/>
<include android:id="@+id/row_6" layout="@layout/board_line"/>
<include android:id="@+id/row_5" layout="@layout/board_line"/>
<include android:id="@+id/row_4" layout="@layout/board_line"/>
<include android:id="@+id/row_3" layout="@layout/board_line"/>
<include android:id="@+id/row_2" layout="@layout/board_line"/>
<include android:id="@+id/row_1" layout="@layout/board_line"/>
</TableLayout>
Aquí mi board_line.xml:
<?xml version="1.0" encoding="utf-8"?>
<merge xmlns:android="http://schemas.android.com/apk/res/android">
<TableRow
android:layout_width="wrap_content"
android:layout_height="wrap_content"
>
<ImageView
android:id="@+id/a"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:minWidth="@dimen/cell_dimension"
android:minHeight="@dimen/cell_dimension"
android:maxWidth="@dimen/cell_dimension"
android:maxHeight="@dimen/cell_dimension"
/>
<ImageView
android:id="@+id/b"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:minWidth="@dimen/cell_dimension"
android:minHeight="@dimen/cell_dimension"
android:maxWidth="@dimen/cell_dimension"
android:maxHeight="@dimen/cell_dimension"
/>
<ImageView
android:id="@+id/c"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:minWidth="@dimen/cell_dimension"
android:minHeight="@dimen/cell_dimension"
android:maxWidth="@dimen/cell_dimension"
android:maxHeight="@dimen/cell_dimension"
/>
<ImageView
android:id="@+id/d"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:minWidth="@dimen/cell_dimension"
android:minHeight="@dimen/cell_dimension"
android:maxWidth="@dimen/cell_dimension"
android:maxHeight="@dimen/cell_dimension"
/>
<ImageView
android:id="@+id/e"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:minWidth="@dimen/cell_dimension"
android:minHeight="@dimen/cell_dimension"
android:maxWidth="@dimen/cell_dimension"
android:maxHeight="@dimen/cell_dimension"
/>
<ImageView
android:id="@+id/f"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:minWidth="@dimen/cell_dimension"
android:minHeight="@dimen/cell_dimension"
android:maxWidth="@dimen/cell_dimension"
android:maxHeight="@dimen/cell_dimension"
/>
<ImageView
android:id="@+id/g"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:minWidth="@dimen/cell_dimension"
android:minHeight="@dimen/cell_dimension"
android:maxWidth="@dimen/cell_dimension"
android:maxHeight="@dimen/cell_dimension"
/>
<ImageView
android:id="@+id/h"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:minWidth="@dimen/cell_dimension"
android:minHeight="@dimen/cell_dimension"
android:maxWidth="@dimen/cell_dimension"
android:maxHeight="@dimen/cell_dimension"
/>
</TableRow>
Gracias de antemano por la ayuda.
Solución
Puede usar LayoutInFlater (o crear vistas completamente mediante programación) y combinar todas las necesidades. El siguiente ejemplo debe crear una placa 5x5 de color aleatorio. Dado que configurar LayoutParams en código es feo, los configuraría en XML e inflaría el diseño.
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
LayoutInflater inflater = (LayoutInflater) getSystemService(LAYOUT_INFLATER_SERVICE);
LinearLayout ll = (LinearLayout) inflater.inflate(R.layout.main, null);
TableLayout tl = (TableLayout) ll.findViewById(R.id.tableLayout);
for (int j = 0; j < 5; j++) {
TableRow tr = (TableRow) inflater.inflate(R.layout.table_row, null);
for (int i = 0; i < 5; i++) {
ImageView iv = (ImageView) inflater.inflate(R.layout.image_view, null);
iv.setBackgroundColor(new Random().nextInt());
tr.addView(iv);
}
tl.addView(tr);
}
setContentView(ll);
}
main.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<TableLayout
android:id="@+id/tableLayout"
android:layout_width="match_parent"
android:layout_height="match_parent" >
</TableLayout>
</LinearLayout>
table_row.xml
<TableRow xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
</TableRow>
image_view.xml
just one of those you defined in board_line.xml: